view level1/modules/dw4write.asm @ 3154:d29a92fff7f2

coco3fpga: Rename SD disk images to .img To avoid confusion since they are not bootable disks, but to be raw copied to the /sd0 partition on the CoCo3FPGA SD card.
author Tormod Volden <debian.tormod@gmail.com>
date Tue, 07 Feb 2017 00:37:28 +0100
parents 28ed72477814
children
line wrap: on
line source

	IFEQ	H6309-1

*******************************************************
*
* DWWrite  -  6309 native Turbo Edition  115k / 230k
*    Send a packet to the DriveWire server.
*    Serial data format:  8-N-2
*
* Entry:
*    X  = address of the data to be sent
*    Y  = number of bytes to send
*
* Exit:
*    X  = address of last byte sent + 1
*    Y  = 0
*    All others preserved
*
BBOUT	equ	$FF20		; bit banger output port

DWWrite	pshs	u,d,cc		; preserve registers
	orcc	#$50		; mask interrupts
	ldu	#BBOUT		; point U to output port
	aim	#$F7,3,u		; disable sound output

* Wait for serial input line to become idle
wait1	lda	2,u		; sample input
	ldb	#$80		; setup ACCB as a shift counter
wait2	eora	2,u		; look for changing input
	lsra			; shift 'changed' bit into Carry
	lda	2,u		; sample input
	rorb			; rotate 'changed' bit into ACCB
	bcc	wait2		; loop for 8 samples
	bne	wait1		; try again if changes seen in the input

* Byte transmitter loop
	incb			; ACCB = 1 (start bit / byte incrementor)
txByte	lda	,x		; get data byte
	stb	,u		; send start bit
	asla			; move bit 0 into position
	abx			; increment data ptr
	sta	,u++		; bit 0
	rora
	nop
	sta	,--u		; bit 1
	lsra
	sta	,u++		; bit 2
	lsra
	nop
	sta	,--u		; bit 3
	lsra
	nop
	sta	,u++		; bit 4
	lsra
	nop
	sta	,--u		; bit 5
	lsra
	sta	,u++		; bit 6
	lsra
	aslb			; ACCB = 2 (stop bit)
	sta	,--u		; bit 7
	leau	,u
	stb	,u		; send stop bit
	lsrb			; ACCB = 1 (start bit / byte incrementor)
	leay	-1,y		; decrement counter
	bne	txByte		; loop if more bytes to send

	puls	cc,d,u,pc		; restore registers and return

        ELSE

*******************************************************
*
* DWWrite  -  6809 Turbo Edition  115k / 230k
*    Send a packet to the DriveWire server.
*    Serial data format:  8-N-2
*
* Entry:
*    X  = address of the data to be sent
*    Y  = number of bytes to send
*
* Exit:
*    X  = address of last byte sent + 1
*    Y  = 0
*    All others preserved
*
*BBOUT	equ	$FF20		; bit banger output port

DWWrite	pshs	u,d,cc		; preserve registers
	orcc	#$50		; mask interrupts
	ldu	#BBOUT		; point U to output port
	lda	3,u		; read PIA 1-B control register
	anda	#$F7		; clear sound enable bit
	sta	3,u		; disable sound output

* Wait for serial input line to become idle
wait1	lda	2,u		; sample input
	ldb	#$80		; setup ACCB as a shift counter
wait2	eora	2,u		; look for changing input
	lsra			; shift 'changed' bit into Carry
	lda	2,u		; sample input
	rorb			; rotate 'changed' bit into ACCB
	bcc	wait2		; loop for 8 samples
	bne	wait1		; try again if changes seen in the input

* Byte transmitter loop
 	ldb	#2
   	lda	,x		; retrieve first byte from buffer
txByte	decb			; ACCB = 1 (start bit / byte incrementor)
	abx			; increment data ptr
	stb	,u		; send start bit
	asla			; move bit 0 into position
	nop
	sta	,u		; bit 0
	rora
	sta	,u+		; bit 1
	lsra
	sta	-1,u		; bit 2
	lsra
	sta	,-u		; bit 3
	lsra
	incb			; ACCB = 2 (stop bit)
	sta	,u		; bit 4
	lsra
	sta	,u+		; bit 5
	lsra
	sta	-1,u		; bit 6
	lsra
	sta	,-u		; bit 7
	lda	,x		; fetch next byte
	stb	,u		; send stop bit
	leay	-1,y		; decrement counter
	bne	txByte		; loop if more bytes to send

	puls	cc,d,u,pc		; restore registers and return

        ENDC