A2osX/SHARED/X.BB.FX.S.txt

583 lines
12 KiB
Plaintext
Raw Normal View History

2020-05-08 21:02:27 +02:00
NEW
AUTO 3,1
*--------------------------------------
2020-05-12 17:17:25 +02:00
dcmd .EQ $42 disk command (=1 for read)
unit .EQ $43 (16*slot)+(128*(drive-1))
buff .EQ $44 ram address
blok .EQ $46 disk address
dent .EQ $48 device call entry address
idxl .EQ $4a pointer to low page of index block
idxh .EQ $4c pointer to high page of index block
idxp .EQ $4e index byte pointer
2020-05-13 19:00:37 +02:00
2020-05-12 17:17:25 +02:00
iobuff .EQ $60
* the following are for disk ii only
dbuf .EQ $26
2020-06-13 21:27:06 +02:00
BB.Slotn0 .EQ $2b
2020-05-12 17:17:25 +02:00
oddbits .EQ $3c
sector .EQ $3d
2020-05-13 19:00:37 +02:00
BB.RetryCnt .EQ $40
2020-05-12 17:17:25 +02:00
BB.TargetTrk .EQ $41
2020-06-07 10:06:51 +02:00
BB.CurrentQTrack .EQ $50
BB.TargetQTrack .EQ $51
2020-05-13 19:00:37 +02:00
BB.HdrPtr .EQ $52
2020-05-12 17:17:25 +02:00
BB.Hdr .EQ $54
BB.HdrTrk .EQ $55
BB.HdrVol .EQ $56
BB.Hdr96 .EQ $57
2020-06-22 07:59:53 +02:00
2022-05-25 20:46:02 +02:00
BB.tmpTrk .EQ $58
2020-05-12 17:17:25 +02:00
nbuf1 .EQ $300
dnib .EQ $2d6
clrscrn .EQ $fc58
2022-05-25 20:46:02 +02:00
2020-05-12 17:17:25 +02:00
sosid .EQ $c00
entlen .EQ sosid+$23
kernel .EQ $2000
2020-05-08 21:02:27 +02:00
*--------------------------------------
.PH $800
xboot .DA #1
2020-05-13 19:00:37 +02:00
sec apple iii enters xboot 'ora $38'
2020-06-07 10:06:51 +02:00
* bcs BB.AppleII branch if not apple iii native mode
bcc *
2020-05-12 17:17:25 +02:00
*--------------------------------------
2020-06-07 10:06:51 +02:00
*BB.AppleIII lda #$9f make apple iii boot using block 1
2020-05-28 23:13:52 +02:00
* pha the return address is $a000
* lda #$ff
* pha
* inc
* tax ldx #0
2020-06-22 07:59:53 +02:00
2020-05-28 23:13:52 +02:00
* inc lda #1 (read block 1)
2020-06-22 07:59:53 +02:00
2020-05-28 23:13:52 +02:00
* jmp $f479
2020-05-12 17:17:25 +02:00
*--------------------------------------
2020-05-13 19:00:37 +02:00
BB.AppleII stx unit save unit number
2020-05-12 17:17:25 +02:00
cmp #$03 for disk ii
php save result, it may be irrelevant
txa find out if disk ii
and #$70 strip drive # if any
lsr
lsr get slot address
lsr
2020-05-08 21:02:27 +02:00
lsr
ora #$c0
2020-05-12 17:17:25 +02:00
sta dent+1
ldy #$ff look at last byte
2020-05-08 21:02:27 +02:00
sty dent
2020-06-22 07:59:53 +02:00
2020-05-12 17:17:25 +02:00
plp restore carry (if disk ii & sect 0&2 read)
2020-05-08 21:02:27 +02:00
2020-05-12 17:17:25 +02:00
iny make y=0
lda (dent),y get device entry addr
bne ndsk2 branch if not disk ii (16 sector)
bcs isdsk2 branch if it is disk ii, but block 0 read
lda #3 make rom read only sector 2
sta xboot to complete block 0
2020-05-08 21:02:27 +02:00
inc sector was = 1
2020-05-13 19:00:37 +02:00
2020-05-12 17:17:25 +02:00
lda dent+1 do rts to re-enter rom
pha
2020-05-08 21:02:27 +02:00
lda #$5b
pha
rts go read sector 2 into $900
*--------------------------------------
2020-06-22 07:59:53 +02:00
isdsk2 sta BB.HdrTrk A=0, make sure previous track =0
sta dent and dent points at beginning of slot
2020-05-12 17:17:25 +02:00
2020-06-22 07:59:53 +02:00
ldy #$63 move code from card to ram
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
mvboot lda (dent),y
2020-05-08 21:02:27 +02:00
sta zzstart-$5e,y
2020-06-22 07:59:53 +02:00
iny
cpy #$eb have we moved enough?
2020-05-08 21:02:27 +02:00
bne mvboot
2020-06-22 07:59:53 +02:00
2020-06-11 23:04:56 +02:00
ldx #mods.cnt now modify code to handle errors.
2020-06-22 07:59:53 +02:00
2020-06-11 23:04:56 +02:00
modboot ldy mods-1,x
lda chgs-1,x
sta zzstart,y
2020-05-12 17:17:25 +02:00
2020-06-11 23:04:56 +02:00
cpx #8
bcs .1
2020-05-12 17:17:25 +02:00
2020-06-13 21:27:06 +02:00
lda endcode-1,x
sta zzzend-1,x
2020-06-11 23:04:56 +02:00
.1 dex
bne modboot
2020-06-22 07:59:53 +02:00
2020-05-12 17:17:25 +02:00
lda #BB.Hdr
sta BB.HdrPtr
2020-05-13 19:00:37 +02:00
stx BB.HdrPtr+1 X=0
2020-06-22 07:59:53 +02:00
lda /BB.ReadBlock reset device entry
sta dent+1 to point at disk ii routines.
lda #BB.ReadBlock get low addr (must be <$80)
2020-05-13 19:00:37 +02:00
*--------------------------------------
2020-09-20 20:35:54 +02:00
ndsk2 sta dent save low adr of device call entry.
2020-05-08 21:02:27 +02:00
2022-05-25 20:46:02 +02:00
stz iobuff
stz idxl
stz idxh
stz idxp
stz blok+1
2020-09-20 20:35:54 +02:00
2022-05-25 20:46:02 +02:00
ldy #1
2020-06-22 07:59:53 +02:00
sty dcmd set read command.
2020-09-20 20:35:54 +02:00
iny y=2
2020-06-22 07:59:53 +02:00
sty blok to read directory blocks
2020-09-20 20:35:54 +02:00
2020-06-22 07:59:53 +02:00
lda #$c 2-5 at $c00
sta iobuff+1
sta idxl+1
rddir jsr goread call read block routine.
bcs bterr2 give up on error.
2022-05-25 20:46:02 +02:00
* inc iobuff+1
* inc iobuff+1
2020-06-22 07:59:53 +02:00
inc blok
lda blok have all directory blocks been read?
cmp #6
bcc rddir loop if not.
2020-06-07 10:06:51 +02:00
*--------------------------------------
2020-06-22 07:59:53 +02:00
lda #4 begin look-up with first entry past header.
2020-06-07 10:06:51 +02:00
.HS 2C BIT ABS
2020-06-22 07:59:53 +02:00
nxdent lda idxl
nxdent1 clc
adc entlen bump to next directory entry.
tay save in y for now.
bcc nxdent2 branch if not a page cross.
inc idxl+1
lda idxl+1 check for new block.
lsr if even then new block.
bcs nxdent2
cmp #$a have all file names been compared?
2020-05-12 17:17:25 +02:00
beq booterr branch if no pro.kernel.
2020-06-22 07:59:53 +02:00
ldy #4 else, begin at block beginning.
2020-06-07 10:06:51 +02:00
nxdent2 sty idxl
2020-05-13 19:00:37 +02:00
2020-06-13 21:27:06 +02:00
ldy #6
2020-06-22 07:59:53 +02:00
lookpro lda (idxl),y look for matching name.
2022-05-25 20:46:02 +02:00
cmp BB.FX.ProDOS,y
2020-06-22 07:59:53 +02:00
bne nxdent branch if no match.
2020-06-13 21:27:06 +02:00
dey
bpl lookpro
2020-06-22 07:59:53 +02:00
* ldy #$10 get file type & index block addr.
* lda (idxl),y
* cmp #S.FI.T.SYS is it a system file?
* bne booterr
* iny
2020-06-13 21:27:06 +02:00
ldy #$11
2020-06-22 07:59:53 +02:00
lda (idxl),y
sta blok
iny
lda (idxl),y
sta blok+1
2022-05-25 20:46:02 +02:00
stz idxl
2020-06-22 07:59:53 +02:00
ldy #$1e read index block at $1e00 and
sty idxl+1 kernel at $2000
sty iobuff+1
iny
sty idxh+1
2020-09-22 07:56:28 +02:00
*--------------------------------------
2020-06-22 07:59:53 +02:00
rdkernl jsr goread read index block.
bterr2 bcs booterr
2022-05-25 20:46:02 +02:00
* inc iobuff+1
* inc iobuff+1
2020-06-22 07:59:53 +02:00
ldy idxp get index pointer
inc idxp bump for next time.
lda (idxl),y
sta blok
lda (idxh),y high disk addr.
sta blok+1
ora (idxl),y if both=0 then done.
bne rdkernl branch if more to read.
jmp kernel go execute kernel code.
2020-05-12 17:17:25 +02:00
*--------------------------------------
2020-09-22 07:56:28 +02:00
booterr jsr clrscrn clear video
2020-06-29 07:49:24 +02:00
ldy #BB.MSG.ERR.Len-1
2020-05-08 21:02:27 +02:00
2020-06-29 07:49:24 +02:00
.1 lda BB.MSG.ERR,y
2022-05-25 20:46:02 +02:00
sta $5b6,y
2020-06-29 07:49:24 +02:00
dey
bpl .1
2020-06-22 07:59:53 +02:00
2020-05-14 13:47:46 +02:00
jmp $ff69
2020-05-12 17:17:25 +02:00
*--------------------------------------
2022-05-25 20:46:02 +02:00
goread
* lda iobuff
stz buff
2020-06-22 07:59:53 +02:00
lda iobuff+1
sta buff+1
2022-05-25 20:46:02 +02:00
inc iobuff+1
inc iobuff+1
2020-06-22 07:59:53 +02:00
jmp (dent)
2020-05-08 21:02:27 +02:00
*--------------------------------------
2020-05-12 17:17:25 +02:00
mods .DA #mod1,#mod2,#mod3,#mod4,#mod5,#mod6,#mod7,#mod8,#mod8+1,#mod9
2020-05-13 19:00:37 +02:00
mods.cnt .EQ *-mods
2020-05-12 17:17:25 +02:00
chgs .DA #chg1,#chg2,#chg3,#chg4,#chg5,#chg6,#chg7,#$91,#BB.HdrPtr,#BB.HdrTrk
2020-06-22 07:59:53 +02:00
endcode ldx BB.Slotn0
clc
rts
2020-05-08 21:02:27 +02:00
2022-05-25 20:46:02 +02:00
jmp BB.FX.SeekRead
2020-05-08 21:02:27 +02:00
*--------------------------------------
2020-06-29 07:49:24 +02:00
BB.MSG.ERR .AS -"BOOT ERROR"
BB.MSG.ERR.Len .EQ *-BB.MSG.ERR
2022-05-25 20:46:02 +02:00
BB.FX.ProDOS .DA #$26 $20 = storage type + 6 = "PRODOS" len
2020-05-13 19:00:37 +02:00
.AS "PRODOS"
2020-05-08 21:02:27 +02:00
*--------------------------------------
2020-06-22 07:59:53 +02:00
BB.ReadBlock lda blok figure out track & sector.
and #7 strip track for now.
cmp #4
and #3
php
2020-05-08 21:02:27 +02:00
asl
2020-06-22 07:59:53 +02:00
plp
rol now we have the first sector of block.
sta sector
lda blok+1 get high block #
lsr shift hi addr to carry.
lda blok now figure track #
ror
lsr
lsr
2020-05-12 17:17:25 +02:00
sta BB.TargetTrk
2021-03-27 22:59:59 +01:00
*--------------------------------------
2020-06-22 07:59:53 +02:00
lda buff+1
2020-05-12 17:17:25 +02:00
sta dbuf+1
2020-06-22 07:59:53 +02:00
ldx BB.Slotn0
lda IO.D2.DrvOn,x
2020-06-29 07:49:24 +02:00
2022-05-25 20:46:02 +02:00
jsr BB.FX.SeekRead
2020-05-12 17:17:25 +02:00
2020-06-22 07:59:53 +02:00
inc dbuf+1 bump address
inc sector
inc sector and sector #
bcs .9 branch if error.
2020-05-12 17:17:25 +02:00
2022-05-25 20:46:02 +02:00
jsr BB.FX.Read
2020-06-22 07:59:53 +02:00
.9 ldy IO.D2.DrvOff,x
rts return error status in carry.
2020-05-12 17:17:25 +02:00
*--------------------------------------
2021-03-26 18:30:56 +01:00
BB.Wait100usecA phx (3)
2021-02-11 23:08:22 +01:00
.1 ldx #20 (2)
2021-02-11 23:08:22 +01:00
.2 dex (2)
bne .2 (3)
dec (2)
bne .1 (3)
2021-06-11 19:20:35 +02:00
2021-02-11 23:08:22 +01:00
plx (4)
rts (6)
*--------------------------------------
2022-05-25 20:46:02 +02:00
BB.Trk2Qtrk ldy BB.HdrVol
beq .5
cpy #$85
bcs .5 > 192 ? must be a buggy 254
sta BB.tmpTrk
2021-02-11 23:08:22 +01:00
2022-05-25 20:46:02 +02:00
tya
bpl .1
2021-06-11 19:20:35 +02:00
2022-05-25 20:46:02 +02:00
lsr BB.HdrVol 2 sides
2021-02-11 23:08:22 +01:00
2022-05-25 20:46:02 +02:00
.1 and #%00000111 stepping
2021-03-26 18:30:56 +01:00
2022-05-25 20:46:02 +02:00
tay
lda #0
clc
.2 adc BB.tmpTrk
dey
bne .2
rts
.5 asl
asl
2021-03-26 18:30:56 +01:00
BB.Trk2Qtrk.RTS rts
2021-02-11 23:08:22 +01:00
*--------------------------------------
2022-05-25 20:46:02 +02:00
BB.FX.SeekRead lda BB.TargetTrk
2020-05-12 17:17:25 +02:00
jsr BB.Trk2Qtrk
2022-05-25 20:46:02 +02:00
sta BB.TargetQTrack
2020-06-22 07:59:53 +02:00
2022-05-25 20:46:02 +02:00
lda BB.HdrTrk get track we're on
2020-06-07 10:06:51 +02:00
jsr BB.Trk2Qtrk
2022-05-25 20:46:02 +02:00
sta BB.CurrentQTrack
2020-05-12 17:17:25 +02:00
2020-07-25 09:05:25 +02:00
cmp BB.TargetQTrack
2022-05-25 20:46:02 +02:00
beq BB.FX.Read
2020-07-25 09:05:25 +02:00
2021-03-26 18:30:56 +01:00
bit #1
bne .1
2021-02-11 23:08:22 +01:00
2021-06-03 19:43:28 +02:00
jsr .20 we are on 0/4 or 2/4 track
2021-06-11 19:20:35 +02:00
2022-04-07 19:19:48 +02:00
bra .10 no wait, next operation will be phy/plx/Ph0On,y
2021-06-11 19:20:35 +02:00
2021-04-08 22:30:18 +02:00
.1 cmp BB.TargetQTrack we are on 1/4 or 3/4
2021-03-26 18:30:56 +01:00
bcs .2 if CS, C > T, must move out
2021-06-11 19:20:35 +02:00
2021-03-26 18:30:56 +01:00
inc CC: C < T, ON next PH
2020-07-25 09:05:25 +02:00
2021-03-26 18:30:56 +01:00
.HS B0 BCS
2020-07-25 09:05:25 +02:00
2021-03-26 18:30:56 +01:00
.2 dec CS: C > T, ON prev PH
2020-07-25 09:05:25 +02:00
2021-03-26 18:30:56 +01:00
sta BB.CurrentQTrack
2020-07-25 09:05:25 +02:00
2021-04-08 22:30:18 +02:00
bra .6 Ph ON to go to 0/4 or 2/4, then wait
*--------------------------------------
2021-06-03 19:43:28 +02:00
.20 and #6
2021-04-08 22:30:18 +02:00
ora BB.Slotn0
tay
lda IO.D2.Ph0On,y
rts
2021-03-26 18:30:56 +01:00
*--------------------------------------
.3 bcs .4 if CS, C > T, must move out
inc CC: C < T, ON next PH
2020-07-25 09:05:25 +02:00
2021-03-26 18:30:56 +01:00
.HS B0 BCS
.4 dec CS: C > T, ON prev PH
2020-07-25 09:05:25 +02:00
sta BB.CurrentQTrack
2020-11-24 18:49:46 +01:00
2021-03-26 18:30:56 +01:00
bit #1
bne .5 we must go to 1/4 or 3/4
2020-11-24 18:49:46 +01:00
2021-03-26 18:30:56 +01:00
lda IO.D2.Ph0Off,x we must go to 0/4 or 2/4 : Off Prev Ph
bra .8 go wait....
2021-06-11 19:20:35 +02:00
2021-03-26 18:30:56 +01:00
.5 phy we must go on 1/4 or 3/4
plx Y already ON, -> X for Ph0Off,x
2021-06-11 19:20:35 +02:00
2021-03-26 18:30:56 +01:00
bcs .6 if CS, C > T, must move out
inc CC: C < T, ON next PH
2021-06-03 19:43:28 +02:00
.6 jsr .20 now X and Y on
2020-11-24 18:49:46 +01:00
2021-03-26 18:30:56 +01:00
.8 lda #IO.D2.SeekTimeB
2020-09-20 20:35:54 +02:00
2021-06-11 19:20:35 +02:00
.9 jsr BB.Wait100usecA ...wait...
2022-04-07 19:19:48 +02:00
.10 lda BB.CurrentQTrack
2020-09-11 20:43:24 +02:00
cmp BB.TargetQTrack
2021-03-26 18:30:56 +01:00
bne .3
2020-09-20 20:35:54 +02:00
2021-06-22 20:59:02 +02:00
lsr CS if X,Y on
2020-09-20 20:35:54 +02:00
lda #0
2021-03-26 18:30:56 +01:00
jsr BB.Wait100usecA
2020-05-28 23:13:52 +02:00
2022-04-19 20:24:34 +02:00
lda IO.D2.Ph0Off,y
2022-04-07 19:19:48 +02:00
bcc .11
2021-06-11 19:20:35 +02:00
2022-04-07 19:19:48 +02:00
lda IO.D2.Ph0Off,x
2022-04-19 20:24:34 +02:00
.11
2020-05-12 17:17:25 +02:00
*--------------------------------------
2022-05-25 20:46:02 +02:00
BB.FX.Read ldx BB.Slotn0
2020-05-08 21:02:27 +02:00
2020-09-20 20:35:54 +02:00
stz BB.RetryCnt
2020-06-22 07:59:53 +02:00
php
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
tryread plp fix stack.
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
rdhead sec anticipate error.
2020-09-20 20:35:54 +02:00
inc BB.RetryCnt if = 0 then give up!
2020-10-22 08:08:25 +02:00
beq BB.Trk2Qtrk.RTS branch if can't fine/read sector.
2020-06-13 21:27:06 +02:00
2020-06-22 07:59:53 +02:00
clc indicate reading header.
2020-10-06 08:27:35 +02:00
ldy #0 Retry cnt waiting D5
2021-06-11 19:20:35 +02:00
2020-06-22 07:59:53 +02:00
rddata php carry set if reading sector.
2020-05-08 21:02:27 +02:00
2020-10-22 08:08:25 +02:00
rd0 iny
2020-06-22 07:59:53 +02:00
beq tryread
2020-05-12 17:17:25 +02:00
*--------------------------------------
2020-06-22 07:59:53 +02:00
* from zzstart to zzend code is moved from rom and modified to match this code...
2020-05-12 17:17:25 +02:00
*--------------------------------------
zzstart .EQ *
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
rd1 lda IO.D2.RData,x read a byte from the state machine.
2020-05-12 17:17:25 +02:00
bpl rd1 loop until ready.
2020-06-22 07:59:53 +02:00
2020-05-12 17:17:25 +02:00
.DUMMY
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
rd1a eor #$d5 mark 1?
mod1 .EQ *-zzstart+1
bne rd0 branch if not.
chg1 .EQ rd0-*
rd2 lda IO.D2.RData,x
bpl rd2
cmp #$aa mark 2?
bne rd1a
nop waste a little time.
rd3 lda IO.D2.RData,x
bpl rd3
cmp #$96 header mark 3?
beq rdhd1 branch if it is.
plp were we looking for data mark 3?
mod2 .EQ *-zzstart+1
bcc rdhead branch if not.
chg2 .EQ rdhead-*
eor #$ad data mark 3?
beq rddt1 go read data field if true...
mod3 .EQ *-zzstart+1
rdhd0 bne rdhead otherwise, start over.
2020-05-08 21:02:27 +02:00
2020-05-12 17:17:25 +02:00
chg3 .EQ rdhead-*
2020-06-22 07:59:53 +02:00
rdhd1 ldy #3 read in trk,sect,&volume #.
2020-05-08 21:02:27 +02:00
2020-05-12 17:17:25 +02:00
mod8 .EQ *-zzstart
rdhd2 sta (BB.HdrPtr),y save last result in .. , BB.HdrTrk , BB.HdrVol , ..
2020-06-13 21:27:06 +02:00
rdhd3 lda IO.D2.RData,x
2020-06-22 07:59:53 +02:00
bpl rdhd3
2020-05-08 21:02:27 +02:00
rol
2020-06-22 07:59:53 +02:00
sta oddbits save odd bits (7,5,3,1)
2020-05-08 21:02:27 +02:00
2020-06-13 21:27:06 +02:00
rdhd4 lda IO.D2.RData,x
2020-06-22 07:59:53 +02:00
bpl rdhd4
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
and oddbits combine even and odd to form value.
dey
bne rdhd2 read in next pair.
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
plp
cmp sector last byte formed is sector#
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
mod4 .EQ *-zzstart+1
bne rdhead branch if target sector not found.
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
chg4 .EQ rdhead-*
2020-05-08 21:02:27 +02:00
2020-05-12 17:17:25 +02:00
mod9 .EQ *-zzstart+1
2020-06-22 07:59:53 +02:00
lda BB.HdrTrk previous result is track #
cmp BB.TargetTrk is desired track found?
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
mod5 .EQ *-zzstart+1
bne goseek re-seek if mismatch.
2020-05-12 17:17:25 +02:00
2020-06-22 07:59:53 +02:00
chg5a .EQ *
mod6 .EQ *-zzstart+1
bcs rddata branch if proper track always.
chg6 .EQ rddata-*
2020-05-12 17:17:25 +02:00
*--------------------------------------
2020-06-22 07:59:53 +02:00
rddt1 ldy #$56 read 2 bit groupings first.
rddt1a sty oddbits
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
rddt2 ldy IO.D2.RData,x
bpl rddt2
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
eor dnib,y denibblize using table left from boot rom.
ldy oddbits save in nbuf1
dey
sta nbuf1,y
bne rddt1a loop until all 86 groups are read.
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
rddt3 sty oddbits now count up for 6-bit groups.
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
rddt4 ldy IO.D2.RData,x
bpl rddt4
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
eor dnib,y
ldy oddbits save result to specified buffer.
sta (dbuf),y
iny
bne rddt3 loop for 256 bytes.
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
rdchk ldy IO.D2.RData,x now verify checksum...
bpl rdchk
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
eor dnib,y must be equal...
mod7 .EQ *-zzstart+1
bne rdhd0 branch if error.
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
chg7 .EQ rdhd0-*
ldy #0 make y=0
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
nxttwo ldx #$56 now combine 2-bit group with 6 bit group
2020-05-08 21:02:27 +02:00
2020-06-22 07:59:53 +02:00
twobit dex all done with this group?
bmi nxttwo branch if so.
2020-05-08 21:02:27 +02:00
2020-05-12 17:17:25 +02:00
lda (dbuf),y
2020-06-22 07:59:53 +02:00
lsr nbuf1,x
rol
lsr nbuf1,x
rol
2020-05-12 17:17:25 +02:00
sta (dbuf),y
2020-06-22 07:59:53 +02:00
iny
bne twobit
2020-05-12 17:17:25 +02:00
*--------------------------------------
2020-06-13 21:27:06 +02:00
zzzend ldx BB.Slotn0
2020-06-22 07:59:53 +02:00
clc indicate good read.
rts
2020-05-08 21:02:27 +02:00
2020-05-12 17:17:25 +02:00
chg5 .EQ *-chg5a
2022-05-25 20:46:02 +02:00
goseek jmp BB.FX.SeekRead
2020-05-12 17:17:25 +02:00
.ED
*--------------------------------------
.LIST ON
BB.Free .EQ $a00-*
.BS BB.Free
.LIST OFF
2020-05-08 21:02:27 +02:00
.EP
*--------------------------------------
MAN
2022-05-25 20:46:02 +02:00
SAVE usr/src/shared/x.bb.fx.s