Mercurial > hg > Members > kono > nitros9-code
changeset 2634:a34c08cdfcb2
Stable dwread/dwrite... pipeman also assembles.
author | Boisy Pitre <boisy.pitre@nuance.com> |
---|---|
date | Mon, 27 Feb 2012 19:54:55 -0600 (2012-02-28) |
parents | 41313184bd78 |
children | 1a75c932f607 |
files | defs/atari.d defs/drivewire.d level1/atari/bootfiles/makefile level1/atari/bootroms/liber809.asm level1/atari/modules/dwread.asm level1/atari/modules/dwwrite.asm level1/modules/clock2_dw3.asm level1/modules/pipeman.asm |
diffstat | 8 files changed, 173 insertions(+), 99 deletions(-) [+] |
line wrap: on
line diff
--- a/defs/atari.d Sun Feb 26 23:34:13 2012 -0600 +++ b/defs/atari.d Mon Feb 27 19:54:55 2012 -0600 @@ -216,6 +216,15 @@ RANDOM EQU $D20A ;random number generator SERIN EQU $D20D ;serial port input IRQST EQU $D20E ;IRQ interrupt status +IRQST.BREAKDOWN equ %10000000 +IRQST.KEYDOWN equ %01000000 +IRQST.SERINRDY equ %00100000 +IRQST.SEROUTNEEDED equ %00010000 +IRQST.SEROUTDONE equ %00001000 +IRQST.TIMER4 equ %00000100 +IRQST.TIMER2 equ %00000010 +IRQST.TIMER1 equ %00000001 + SKSTAT EQU $D20F ;serial port and keyboard status * Write Addresses @@ -237,8 +246,22 @@ POTGO EQU $D20B ;start potentiometer scan sequence SEROUT EQU $D20D ;serial port output IRQEN EQU $D20E ;IRQ interrupt enable +IRQEN.BREAKDOWN equ %10000000 +IRQEN.KEYDOWN equ %01000000 +IRQEN.SERINRDY equ %00100000 +IRQEN.SEROUTNEEDED equ %00010000 +IRQEN.SEROUTDONE equ %00001000 +IRQEN.TIMER4 equ %00000100 +IRQEN.TIMER2 equ %00000010 +IRQEN.TIMER1 equ %00000001 + SKCTL EQU $D20F ;serial port and keyboard control - +SKCTL.FORECEBREAK equ %10000000 +SKCTL.SERMODECTRLMASK equ %01110000 +SKCTL.TWOTONEMODE equ %00001000 +SKCTL.FASTPOTSCAN equ %00000100 +SKCTL.KEYBRDSCAN equ %00000010 +SKCTL.KEYDEBOUNCE equ %00000001 ** PIA Address Equates PIA EQU $D300 ;PIA area
--- a/defs/drivewire.d Sun Feb 26 23:34:13 2012 -0600 +++ b/defs/drivewire.d Mon Feb 27 19:54:55 2012 -0600 @@ -22,8 +22,9 @@ OP_RESET1 equ $FE Server Reset OP_RESET2 equ $FF Server Reset OP_RESET3 equ $F8 Server Reset -OP_DWINIT equ 'Z DriveWire dw3 init/OS9 boot +OP_DWINIT equ 'Z DriveWire dw3 init/OS9 boot OP_TIME equ '# Current time requested +OP_SETTIME equ '$ Current time requested OP_INIT equ 'I Init routine called OP_READ equ 'R Read one sector OP_REREAD equ 'r Re-read one sector @@ -74,8 +75,20 @@ DW.VIRQPkt rmb Vi.PkSz DW.VIRQNOP rmb 1 + +***************************************** +* dw3 subroutine module entry points +* +DW$Init equ 0 +DW$Read equ 3 +DW$Write equ 6 +DW$Term equ 9 + + + +***************************************** * SCF Multi Terminal Driver Definitions - +* org V.SCF ;V.SCF: free memory for driver to use SSigID rmb 1 ;process ID for signal on data ready SSigSg rmb 1 ;signal on data ready code
--- a/level1/atari/bootfiles/makefile Sun Feb 26 23:34:13 2012 -0600 +++ b/level1/atari/bootfiles/makefile Mon Feb 27 19:54:55 2012 -0600 @@ -11,13 +11,13 @@ BOOTFILE_P1 = $(MD)/krnp2 $(MD)/init \ $(MD)/ioman $(MD)/scf.mn $(MD)/vtio.dr $(MD)/term.dt \ $(MD)/sysgo \ - $(MD)/clock_60hz $(MD)/clock2_dw3 \ + $(MD)/clock_60hz $(MD)/clock2_soft \ $(MD)/krn BOOTFILE_P2 = $(MD)/rbf.mn $(MD)/rbdw3.dr \ $(MD)/x0.dd $(MD)/x1.dd $(MD)/dw3.sb \ $(MD)/scdwp.dr $(MD)/p_scdwp.dd \ - $(CD)/shell_21 $(CD)/date + $(CD)/shell_21 $(CD)/ded BOOTFILES = bootfile
--- a/level1/atari/bootroms/liber809.asm Sun Feb 26 23:34:13 2012 -0600 +++ b/level1/atari/bootroms/liber809.asm Mon Feb 27 19:54:55 2012 -0600 @@ -131,7 +131,7 @@ green clra gl@ inca sta COLBK - lbsr Wait + lbrn $0000 cmpx ,s bra gl@
--- a/level1/atari/modules/dwread.asm Sun Feb 26 23:34:13 2012 -0600 +++ b/level1/atari/modules/dwread.asm Mon Feb 27 19:54:55 2012 -0600 @@ -33,7 +33,7 @@ inloop@ ora #%00100000 sta IRQEN - lda 1,s + lda #$20 clrb loop@ subd #$0001
--- a/level1/atari/modules/dwwrite.asm Sun Feb 26 23:34:13 2012 -0600 +++ b/level1/atari/modules/dwwrite.asm Mon Feb 27 19:54:55 2012 -0600 @@ -11,38 +11,54 @@ * Y = 0 * All others preserved * -SKSEND equ $23 -MSKSEND equ %00010000 -DWWrite +* Based on the hipatch source for the Atari and translated +* into 6809 assembly language by Boisy G. Pitre. +* +RMSEND equ %11101111 +SKSEND equ $23 +MSKSEND equ %00010000 +IMSEND equ %00010000 +IMSCPL equ $08 +DWWrite + andcc #^$01 ; clear carry to assume no error pshs d,cc - orcc #$50 -* lda #SKSEND -* sta SKCTL -* sta SKRES - lda D.IRQENSHDW -byteloop@ - ora #%00001000 +; setup pokey + lda #$28 + sta AUDCTL +* lda #$A0 + lda #$A8 + sta AUDC4 +* short delay before send + clra +shortdelay@ + deca + bne shortdelay@ + orcc #$50 ; mask interrupts + lda #SKSEND ; set pokey to transmit data mode + sta SKCTL + sta SKRES + lda #MSKSEND sta IRQEN lda ,x+ sta SEROUT + leay -1,y + beq ex@ +byteloop@ + lda ,x+ + ldb #IMSEND waitloop@ - ldb IRQST - bitb #%00001000 + bitb IRQST bne waitloop@ - lbsr Wait - lda D.IRQENSHDW - sta IRQEN + ldb #RMSEND + stb IRQEN + ldb D.IRQENSHDW + orb #MSKSEND + stb IRQEN + sta SEROUT leay -1,y bne byteloop@ ex@ - clrb + lda #IMSCPL +wt bita IRQST ; wait until transmit complete + bne wt puls cc,d,pc - -Wait - pshs x - ldx #$100 -wait@ - leax -1,x - bne wait@ - puls x,pc -
--- a/level1/modules/clock2_dw3.asm Sun Feb 26 23:34:13 2012 -0600 +++ b/level1/modules/clock2_dw3.asm Mon Feb 27 19:54:55 2012 -0600 @@ -12,88 +12,110 @@ * 2 2010/01/02 Boisy G. Pitre * Saved some bytes by optimizing - nam Clock2 - ttl DriveWire 3 RTC Driver + nam Clock2 + ttl DriveWire 3 RTC Driver - ifp1 - use defsfile - endc + ifp1 + use defsfile + use drivewire.d + endc -tylg set Sbrtn+Objct -atrv set ReEnt+rev -rev set $00 -edition set 2 +tylg set Sbrtn+Objct +atrv set ReEnt+rev +rev set $00 +edition set 2 -RTC.Base equ $0000 +RTC.Base equ $0000 - mod eom,name,tylg,atrv,JmpTable,RTC.Base + mod eom,name,tylg,atrv,JmpTable,RTC.Base -name fcs "Clock2" - fcb edition +name fcs "Clock2" + fcb edition -subname fcs "dw3" +subname fcs "dw3" * Three Entry Points: * - Init * - GetTime * - SetTIme JmpTable - bra Init - nop - bra GetTime RTC Get Time - nop -ex rts RTC Set Time + bra Init + nop + bra GetTime RTC Get Time + -GetTime pshs u,y,x,b - lda #'# Time packet - sta ,s - leax ,s - ldy #$0001 - IFGT Level-1 - ldu <D.DWSubAddr - ELSE - ldu >D.DWSubAddr - ENDC - beq UpdLeave in case we failed to link it, just exit - jsr 6,u -* Consider the following optimization - ldx #D.Year - ldy #$0006 - jsr 3,u -UpdLeave puls b,x,y,u,pc +SetTime pshs u,y,x,d + IFGT Level-1 + ldu <D.DWSubAddr + ELSE + ldu >D.DWSubAddr + ENDC + beq UpdLeave in case we failed to link it, just exit + ldx #D.Year + ldd 4,x + pshs d + ldd 2,x + pshs d + ldd ,x + pshs d + lda #OP_SETTIME + pshs a + leax ,s + ldy #$0007 + jsr DW$Write,u + leas 7,s + bra UpdLeave + + +GetTime pshs u,y,x,d + IFGT Level-1 + ldu <D.DWSubAddr + ELSE + ldu >D.DWSubAddr + ENDC + beq UpdLeave in case we failed to link it, just exit + lda #OP_TIME Time packet + sta ,s + leax ,s + ldy #$0001 + beq UpdLeave in case we failed to link it, just exit + jsr DW$Write,u + ldx #D.Year + ldy #$0006 + jsr DW$Read,u +UpdLeave puls d,x,y,u,pc Init * Check if subroutine already linked - IFGT Level-1 - ldx <D.DWSubAddr - ELSE - ldx >D.DWSubAddr - ENDC - bne leave - IFGT Level-1 - ldx <D.Proc - pshs x - ldx <D.SysPrc - stx <D.Proc - ENDC - leax subname,pcr - clra - os9 F$Link - IFGT Level-1 - puls x - stx <D.Proc - bcs ex - sty <D.DWSubAddr - ELSE - bcs ex - sty >D.DWSubAddr - ENDC - jmp ,y call initialization routine -leave rts + IFGT Level-1 + ldx <D.DWSubAddr + ELSE + ldx >D.DWSubAddr + ENDC + bne leave + IFGT Level-1 + ldx <D.Proc + pshs x + ldx <D.SysPrc + stx <D.Proc + ENDC + leax subname,pcr + clra + os9 F$Link + IFGT Level-1 + puls x + stx <D.Proc + bcs leave + sty <D.DWSubAddr + ELSE + bcs leave + sty >D.DWSubAddr + ENDC + jmp ,y call initialization routine +leave rts - emod -eom equ * - end - + emod +eom equ * + end