2016-06-07 06:10:18 +00:00
|
|
|
|
PR#3
|
|
|
|
|
PREFIX /A2OSX.SRC
|
2017-03-15 16:44:15 +00:00
|
|
|
|
LOMEM $A00
|
2016-06-07 06:10:18 +00:00
|
|
|
|
INC 1
|
|
|
|
|
AUTO 6
|
|
|
|
|
*--------------------------------------
|
2016-09-26 16:00:52 +00:00
|
|
|
|
* SYSCALL (AUXLC to AUXLC)
|
|
|
|
|
* Used by user & kernel for inter bank Calls
|
2016-06-07 06:10:18 +00:00
|
|
|
|
* In:
|
|
|
|
|
* X = SYSfnc.Index
|
|
|
|
|
* Y,A = free for Inline param
|
|
|
|
|
*--------------------------------------
|
2016-09-26 16:00:52 +00:00
|
|
|
|
jmp A2osX.SYSCALL1
|
2016-06-07 06:10:18 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
* LIBCALL (AUXLC to AUXLC)
|
2016-09-26 16:00:52 +00:00
|
|
|
|
* Used by user
|
2016-06-07 06:10:18 +00:00
|
|
|
|
* In:
|
|
|
|
|
* Y = LIB.ID
|
|
|
|
|
* X = LIBfnc.Index
|
|
|
|
|
* A = free for Inline param
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
jmp A2osX.LIBCALL1
|
|
|
|
|
*--------------------------------------
|
2016-09-26 16:00:52 +00:00
|
|
|
|
* MLICALL (AUXLC to MAINLC)
|
|
|
|
|
* Used by Kernel
|
2016-06-07 06:10:18 +00:00
|
|
|
|
* In:
|
|
|
|
|
* X = MLI Function
|
|
|
|
|
* A = Param Count
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
jmp A2osX.MLICALL1
|
2016-11-25 16:20:28 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
.BS $BD10-*
|
2016-06-07 06:10:18 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
jmp (pCode) pCodeJmp
|
|
|
|
|
jmp (pLib) pLibJmp
|
2016-08-17 06:25:58 +00:00
|
|
|
|
jmp (pDrv) pDrvJmp
|
|
|
|
|
jmp (pDev) pDevJmp
|
2016-11-25 16:20:28 +00:00
|
|
|
|
.BS $BD20-*
|
2016-06-07 06:10:18 +00:00
|
|
|
|
*--------------------------------------
|
2016-09-26 16:00:52 +00:00
|
|
|
|
GO.Reset jsr GO.A2osX
|
2016-09-21 15:20:37 +00:00
|
|
|
|
jmp K.KernelRun
|
2016-06-07 06:10:18 +00:00
|
|
|
|
*--------------------------------------
|
2016-09-26 16:00:52 +00:00
|
|
|
|
* *** MUST BE REINTRANT ***
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
A2osX.SYSCALL1 bit KERNEL.SYSCALL.FLAGS,x
|
|
|
|
|
bpl .8 in $E000, no BNK change
|
|
|
|
|
|
|
|
|
|
sta .7+1 save A (Func Arg)
|
|
|
|
|
|
|
|
|
|
lda KERNEL.SYSCALL.FLAGS+1,x Get Target BNK
|
|
|
|
|
|
|
|
|
|
cmp $D000 #RRAMWRAMBNK1 or #RRAMWRAMBNK2
|
|
|
|
|
beq .7 same as actual BNK...go restore A and JMP
|
|
|
|
|
|
|
|
|
|
stx .6+1 save X (Func ID)
|
|
|
|
|
|
|
|
|
|
tax set Target BNK in x
|
|
|
|
|
lda $D000 get source BNK
|
|
|
|
|
bit $C000,x switch to Target BNK
|
|
|
|
|
bit $C000,x
|
|
|
|
|
pha
|
|
|
|
|
|
2016-09-29 06:26:54 +00:00
|
|
|
|
jsr .6 go to kernel.....
|
2016-09-26 16:00:52 +00:00
|
|
|
|
|
|
|
|
|
stx .5+1 save X
|
|
|
|
|
plx get back Source BNK
|
2016-09-05 16:00:11 +00:00
|
|
|
|
bit $C000,x
|
|
|
|
|
bit $C000,x
|
2016-09-26 16:00:52 +00:00
|
|
|
|
.5 ldx #$FF Self Modified
|
|
|
|
|
rts Unmodified Carry
|
|
|
|
|
|
|
|
|
|
.6 ldx #$FF Self Modified
|
|
|
|
|
.7 lda #$FF Self Modified
|
|
|
|
|
.8 jmp (KERNEL.SYSCALL,x)
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
A2osX.LIBCALL1 pha No need to save X, K.GetMemPtrA will leave it unmodified
|
|
|
|
|
tya Get LIB hMem in A
|
|
|
|
|
jsr K.GetMemPtrA Get LIB Code Segment (MemMgr in $E000, no BNK change)
|
|
|
|
|
>STYA pLib
|
2016-06-07 06:10:18 +00:00
|
|
|
|
pla
|
2016-09-26 16:00:52 +00:00
|
|
|
|
jmp (pLib)
|
2016-06-07 06:10:18 +00:00
|
|
|
|
*--------------------------------------
|
2016-09-26 16:00:52 +00:00
|
|
|
|
A2osX.MLICALL1 stx .1
|
2016-06-07 06:10:18 +00:00
|
|
|
|
sta MLICALL.PARAMS
|
2016-09-26 16:00:52 +00:00
|
|
|
|
jsr GO.ProDOS
|
2016-06-07 06:10:18 +00:00
|
|
|
|
jsr MLI
|
|
|
|
|
.1 .BS 1
|
|
|
|
|
.DA MLICALL.PARAMS
|
2016-09-26 16:00:52 +00:00
|
|
|
|
jsr GO.A2osX
|
2016-06-07 06:10:18 +00:00
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
2017-03-20 16:54:27 +00:00
|
|
|
|
* A2osX.DIIDrv,A2osX.BlkDrv
|
|
|
|
|
* X = DEVMGR.cmd
|
|
|
|
|
* Y,A = PTR to Params
|
|
|
|
|
* pDev -> Dev Header
|
2016-11-25 16:20:28 +00:00
|
|
|
|
* $42 Command Number
|
|
|
|
|
* $43 Unit Number
|
|
|
|
|
* $44-$45 Buffer Pointer
|
|
|
|
|
* $46-$47 Block Number
|
|
|
|
|
*--------------------------------------
|
2017-03-20 16:54:27 +00:00
|
|
|
|
A2osX.DIIDrv .DA A2osX.DIIDrv.S status
|
|
|
|
|
.DA A2osX.DIIDrv.RW Read
|
|
|
|
|
.DA A2osX.DIIDrv.RW Write
|
|
|
|
|
.DA A2osX.DRV.BadCall Format
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
A2osX.DIIDrv.S >LDYAI A2osx.DIIStat
|
|
|
|
|
clc
|
2016-11-25 16:20:28 +00:00
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
2017-03-21 16:29:15 +00:00
|
|
|
|
A2osX.DIIDrv.RW jsr A2osX.Blk.GetParam
|
2017-03-14 16:47:02 +00:00
|
|
|
|
|
|
|
|
|
jsr GO.ProDOS
|
|
|
|
|
jsr $D000
|
|
|
|
|
jsr GO.A2osX
|
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
2017-03-20 16:54:27 +00:00
|
|
|
|
A2osx.DIIStat .DA #S.DEVSTAT.S.BLOCK+S.DEVSTAT.S.WRITE+S.DEVSTAT.S.READ
|
2017-03-14 16:47:02 +00:00
|
|
|
|
.DA 280
|
|
|
|
|
.DA #0
|
2017-03-21 21:53:17 +00:00
|
|
|
|
>PSTR "Disk II 5.25"
|
2017-03-14 16:47:02 +00:00
|
|
|
|
.BS 4
|
2017-03-21 21:53:17 +00:00
|
|
|
|
.DA #S.DEVSTAT.TYPE.DISKII
|
2017-03-14 16:47:02 +00:00
|
|
|
|
.DA #0
|
|
|
|
|
.DA #0,#9
|
|
|
|
|
*--------------------------------------
|
2017-03-20 16:54:27 +00:00
|
|
|
|
* Generic Blk Device
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
A2osX.BlkDrv .DA A2osX.BlkDrv.S status
|
|
|
|
|
.DA A2osX.BlkDrv.RW
|
|
|
|
|
.DA A2osX.BlkDrv.RW
|
|
|
|
|
.DA A2osX.BlkDrv.F
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
.DA A2osX.DRV.BadCall
|
|
|
|
|
*--------------------------------------
|
2017-03-21 16:29:15 +00:00
|
|
|
|
A2osX.BlkDrv.S jsr A2osX.Blk.GetDev
|
2017-03-20 16:54:27 +00:00
|
|
|
|
|
|
|
|
|
jsr A2osX.BlkDrv.Go
|
|
|
|
|
bcs *
|
|
|
|
|
stx A2osx.BlkStat+S.DEVSTAT.SIZE
|
|
|
|
|
sty A2osx.BlkStat+S.DEVSTAT.SIZE+1
|
|
|
|
|
|
2017-03-21 16:29:15 +00:00
|
|
|
|
>LDYAI A2osX.BlkStat
|
2017-03-20 16:54:27 +00:00
|
|
|
|
clc
|
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
2017-03-21 16:29:15 +00:00
|
|
|
|
A2osX.BlkDrv.RW jsr A2osX.Blk.GetParam
|
2017-03-20 16:54:27 +00:00
|
|
|
|
bra A2osX.BlkDrv.Go
|
|
|
|
|
*--------------------------------------
|
2017-03-21 16:29:15 +00:00
|
|
|
|
A2osX.BlkDrv.F jsr A2osX.Blk.GetDev
|
2017-03-20 16:54:27 +00:00
|
|
|
|
A2osX.BlkDrv.Go ldy #S.DEV.ROM.JMP
|
|
|
|
|
lda (pDev),y
|
|
|
|
|
sta .8+1
|
|
|
|
|
iny
|
|
|
|
|
lda (pDev),y
|
|
|
|
|
sta .8+2
|
|
|
|
|
.8 jmp $ffff
|
|
|
|
|
*--------------------------------------
|
2017-03-21 16:29:15 +00:00
|
|
|
|
A2osX.BlkStat .DA #S.DEVSTAT.S.BLOCK+S.DEVSTAT.S.WRITE+S.DEVSTAT.S.READ
|
2017-03-14 16:47:02 +00:00
|
|
|
|
.BS 3
|
2017-03-21 21:53:17 +00:00
|
|
|
|
>PSTR "ProDOS Block Dev"
|
|
|
|
|
.DA #S.DEVSTAT.TYPE.PRODOS
|
2017-03-14 16:47:02 +00:00
|
|
|
|
.DA #0
|
|
|
|
|
.DA #0,#9
|
|
|
|
|
*--------------------------------------
|
2017-03-21 16:29:15 +00:00
|
|
|
|
A2osX.Blk.GetParam
|
|
|
|
|
>STYA ZPDRV Get Ptr To ParamList
|
|
|
|
|
jsr A2osX.Blk.GetDev
|
2017-03-20 16:54:27 +00:00
|
|
|
|
|
|
|
|
|
ldy #3
|
|
|
|
|
|
|
|
|
|
.1 lda (ZPDRV),y
|
2017-03-21 16:29:15 +00:00
|
|
|
|
sta $44,y
|
2017-03-20 16:54:27 +00:00
|
|
|
|
dey
|
|
|
|
|
bpl .1
|
|
|
|
|
rts
|
2017-03-21 16:29:15 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
A2osX.Blk.GetDev
|
2017-01-12 17:43:45 +00:00
|
|
|
|
txa
|
2017-03-20 16:54:27 +00:00
|
|
|
|
asl
|
|
|
|
|
sta $42 CMD
|
|
|
|
|
|
|
|
|
|
ldy #S.DEV.DEVID Drive 1, or 2
|
|
|
|
|
lda (pDev),y
|
|
|
|
|
dec O or 1
|
|
|
|
|
lsr in Carry
|
|
|
|
|
php
|
|
|
|
|
|
|
|
|
|
ldy #S.DEV.BUSID
|
|
|
|
|
lda (pDev),y
|
|
|
|
|
asl
|
|
|
|
|
asl
|
|
|
|
|
asl
|
|
|
|
|
asl
|
|
|
|
|
asl
|
|
|
|
|
plp
|
|
|
|
|
ror
|
|
|
|
|
sta $43 DSSS0000
|
|
|
|
|
|
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
A2osX.DRV.BadCall
|
|
|
|
|
lda #MLI.ERR.BADCALL
|
|
|
|
|
sec
|
2016-11-25 16:20:28 +00:00
|
|
|
|
rts
|
2016-11-24 17:00:03 +00:00
|
|
|
|
*--------------------------------------
|
2016-09-26 16:00:52 +00:00
|
|
|
|
GO.ProDOS lda $D000 We re coming from AUXLC, saving bank...
|
|
|
|
|
sta GO.A2osX.BNK+1
|
2016-09-05 16:00:11 +00:00
|
|
|
|
|
|
|
|
|
php
|
2016-06-07 06:10:18 +00:00
|
|
|
|
clc
|
|
|
|
|
.HS 2C bit abs
|
|
|
|
|
|
2016-09-26 16:00:52 +00:00
|
|
|
|
GO.A2osX php
|
2016-06-07 06:10:18 +00:00
|
|
|
|
sec
|
2016-09-05 16:00:11 +00:00
|
|
|
|
|
2016-06-07 06:10:18 +00:00
|
|
|
|
sei
|
|
|
|
|
|
|
|
|
|
sta A2osX.SaveA
|
|
|
|
|
stx A2osX.SaveX
|
|
|
|
|
sty A2osX.SaveY
|
2016-09-05 16:00:11 +00:00
|
|
|
|
|
|
|
|
|
pla Restore P in A for later
|
|
|
|
|
|
|
|
|
|
plx Get PC and add 1 for return
|
2016-06-07 06:10:18 +00:00
|
|
|
|
ply
|
|
|
|
|
inx
|
|
|
|
|
bne .1
|
|
|
|
|
iny
|
2016-09-05 16:00:11 +00:00
|
|
|
|
|
2016-06-07 06:10:18 +00:00
|
|
|
|
.1 stx GO.EXIT.JMP+1
|
|
|
|
|
sty GO.EXIT.JMP+2
|
|
|
|
|
|
|
|
|
|
ldy pStack
|
|
|
|
|
|
2016-09-26 16:00:52 +00:00
|
|
|
|
bcs GO.A2osX.BNK if CS, go AUXLC
|
2016-09-05 16:00:11 +00:00
|
|
|
|
|
|
|
|
|
bit RRAMWRAMBNK1 Go MAINLC (ProDOS), always BNK1
|
|
|
|
|
bit RRAMWRAMBNK1
|
|
|
|
|
|
|
|
|
|
tsx
|
2016-06-07 06:10:18 +00:00
|
|
|
|
stx A2osX.SaveSX
|
|
|
|
|
ldx A2osX.SaveSM
|
|
|
|
|
txs
|
2016-09-05 16:00:11 +00:00
|
|
|
|
sta CLRALTZP
|
2016-06-07 06:10:18 +00:00
|
|
|
|
bra GO.EXIT
|
2016-09-05 16:00:11 +00:00
|
|
|
|
|
2016-09-28 15:34:15 +00:00
|
|
|
|
GO.A2osX.BNK ldx #RRAMWRAMBNK1 Self Modified, initialized to BNK1 for INIT3
|
2016-09-05 16:00:11 +00:00
|
|
|
|
|
|
|
|
|
bit $C000,x
|
|
|
|
|
bit $C000,x
|
|
|
|
|
|
|
|
|
|
sta SETALTZP
|
2016-06-07 06:10:18 +00:00
|
|
|
|
tsx
|
|
|
|
|
stx A2osX.SaveSM
|
|
|
|
|
ldx A2osX.SaveSX
|
|
|
|
|
txs
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
GO.EXIT sty pStack
|
|
|
|
|
pha push P on stack
|
|
|
|
|
ldy A2osX.SaveY
|
|
|
|
|
ldx A2osX.SaveX
|
|
|
|
|
lda A2osX.SaveA
|
|
|
|
|
plp
|
2016-09-26 16:00:52 +00:00
|
|
|
|
GO.EXIT.JMP jmp $FFFF Self Modified
|
2016-06-07 06:10:18 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
A2osX.SaveA .BS 1
|
|
|
|
|
A2osX.SaveX .BS 1
|
|
|
|
|
A2osX.SaveY .BS 1
|
|
|
|
|
*--------------------------------------
|
2017-01-25 16:18:35 +00:00
|
|
|
|
* Called for ProDOS IRQ Manager (LCBNK1)
|
|
|
|
|
* A,X,Y, $FA->$FF Already Saved
|
|
|
|
|
* Main RAM,ZP/LC selected
|
|
|
|
|
* must begin with CLD
|
|
|
|
|
* must exit with RTS
|
|
|
|
|
* - CC if IRQ cleared, CS if NOT
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
ProDOS.INTNUM .BS 1
|
2016-06-07 06:10:18 +00:00
|
|
|
|
*--------------------------------------
|
2017-01-25 16:18:35 +00:00
|
|
|
|
IrqHandler cld
|
2017-02-08 16:42:32 +00:00
|
|
|
|
lda RDALTZP
|
|
|
|
|
sta .2+1
|
2017-01-25 16:18:35 +00:00
|
|
|
|
|
2017-03-02 22:14:04 +00:00
|
|
|
|
bmi .1 we are already in AuxZP/LC
|
|
|
|
|
|
|
|
|
|
sta SETALTZP coming from MainLC, switch to aux
|
2017-01-25 16:18:35 +00:00
|
|
|
|
tsx
|
|
|
|
|
stx A2osX.SaveSM
|
|
|
|
|
ldx A2osX.SaveSX
|
|
|
|
|
txs
|
2017-02-06 17:04:03 +00:00
|
|
|
|
|
2017-02-08 16:42:32 +00:00
|
|
|
|
.1 jsr K.IrqHandler
|
|
|
|
|
|
2017-03-02 22:14:04 +00:00
|
|
|
|
.2 lda #$ff get back ZP status when called
|
|
|
|
|
bmi .3 we were coming from AuxZP/LC
|
2017-01-25 16:18:35 +00:00
|
|
|
|
|
2017-03-02 22:14:04 +00:00
|
|
|
|
tsx go back to Main
|
2017-01-25 16:18:35 +00:00
|
|
|
|
stx A2osX.SaveSX
|
|
|
|
|
ldx A2osX.SaveSM
|
|
|
|
|
txs
|
|
|
|
|
sta CLRALTZP
|
|
|
|
|
|
2017-02-08 16:42:32 +00:00
|
|
|
|
.3 rts
|
2017-01-25 16:18:35 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
BrkHandler bra *
|
2016-06-07 06:10:18 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
MAN
|
|
|
|
|
SAVE SYS/KERNEL.S.GP
|
|
|
|
|
LOAD SYS/KERNEL.S
|
|
|
|
|
ASM
|