2017-12-22 22:24:30 +01:00
|
|
|
|
NEW
|
2017-03-29 17:48:15 +02:00
|
|
|
|
PREFIX /A2OSX.BUILD
|
2017-12-22 22:24:30 +01:00
|
|
|
|
AUTO 4,1
|
2016-06-07 08:10:18 +02:00
|
|
|
|
*--------------------------------------
|
2016-09-26 18:00:52 +02:00
|
|
|
|
* SYSCALL (AUXLC to AUXLC)
|
|
|
|
|
* Used by user & kernel for inter bank Calls
|
2016-06-07 08:10:18 +02:00
|
|
|
|
* In:
|
|
|
|
|
* X = SYSfnc.Index
|
|
|
|
|
* Y,A = free for Inline param
|
|
|
|
|
*--------------------------------------
|
2018-04-27 15:43:40 +02:00
|
|
|
|
GP.CodeStart jmp GP.SysCall
|
2016-06-07 08:10:18 +02:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
* LIBCALL (AUXLC to AUXLC)
|
2016-09-26 18:00:52 +02:00
|
|
|
|
* Used by user
|
2016-06-07 08:10:18 +02:00
|
|
|
|
* In:
|
|
|
|
|
* Y = LIB.ID
|
|
|
|
|
* X = LIBfnc.Index
|
|
|
|
|
* A = free for Inline param
|
|
|
|
|
*--------------------------------------
|
2017-10-27 16:56:46 +02:00
|
|
|
|
jmp GP.LibCall
|
2016-06-07 08:10:18 +02:00
|
|
|
|
*--------------------------------------
|
2017-11-05 22:23:21 +01:00
|
|
|
|
* AppleTalk MLICALL (AUXLC to MAINLC)
|
|
|
|
|
* Used by user
|
2016-06-07 08:10:18 +02:00
|
|
|
|
* In:
|
2017-11-05 22:23:21 +01:00
|
|
|
|
* Y,A = Params
|
2016-06-07 08:10:18 +02:00
|
|
|
|
*--------------------------------------
|
2017-11-05 22:23:21 +01:00
|
|
|
|
jmp GP.AtkCall
|
2016-11-25 17:20:28 +01:00
|
|
|
|
*--------------------------------------
|
2018-06-14 17:31:36 +02:00
|
|
|
|
* ROMCALL (AUXLC to ROMLC)
|
2017-08-31 17:35:15 +02:00
|
|
|
|
* Used by Kernel
|
|
|
|
|
* In:
|
2018-06-14 17:31:36 +02:00
|
|
|
|
* X = ROM Function
|
|
|
|
|
* Y,A = Param
|
2017-08-31 17:35:15 +02:00
|
|
|
|
*--------------------------------------
|
2018-04-10 16:03:29 +01:00
|
|
|
|
jmp GP.RomCall
|
2017-07-01 15:44:40 +02:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
* BADCALL
|
|
|
|
|
*--------------------------------------
|
2017-10-26 18:01:54 +02:00
|
|
|
|
lda #MLI.E.BADCALL
|
2017-07-01 15:44:40 +02:00
|
|
|
|
sec
|
|
|
|
|
rts
|
2017-11-22 17:27:50 +01:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
* SLEEP
|
2017-11-17 17:16:05 +01:00
|
|
|
|
*--------------------------------------
|
2018-04-28 14:10:58 +02:00
|
|
|
|
php
|
|
|
|
|
|
|
|
|
|
sei
|
|
|
|
|
|
|
|
|
|
phy
|
|
|
|
|
ldy #S.PS.A
|
|
|
|
|
sta (pPs),y
|
|
|
|
|
|
|
|
|
|
txa
|
|
|
|
|
iny #S.PS.X
|
|
|
|
|
sta (pPs),y
|
|
|
|
|
|
|
|
|
|
pla
|
|
|
|
|
iny #S.PS.Y
|
|
|
|
|
sta (pPs),y
|
|
|
|
|
|
|
|
|
|
pla
|
|
|
|
|
iny #S.PS.P
|
|
|
|
|
sta (pPs),y
|
|
|
|
|
|
|
|
|
|
pla get PC LO
|
|
|
|
|
plx get PC HI
|
|
|
|
|
|
|
|
|
|
inc Advance one byte because of return by RTI
|
|
|
|
|
bne .1
|
|
|
|
|
inx
|
|
|
|
|
|
|
|
|
|
.1 iny #S.PS.PC
|
|
|
|
|
sta (pPs),y
|
|
|
|
|
|
|
|
|
|
txa
|
|
|
|
|
iny #S.PS.PC+1
|
|
|
|
|
sta (pPs),y
|
|
|
|
|
|
|
|
|
|
tsx
|
|
|
|
|
|
|
|
|
|
inx skip P
|
|
|
|
|
inx skip PC HI,LO
|
|
|
|
|
inx
|
|
|
|
|
|
|
|
|
|
txa
|
|
|
|
|
|
|
|
|
|
beq .8
|
|
|
|
|
|
|
|
|
|
tay Save !Byte count for later
|
|
|
|
|
|
|
|
|
|
.2 pla
|
|
|
|
|
>PUSHA
|
|
|
|
|
inx
|
|
|
|
|
bne .2
|
|
|
|
|
|
|
|
|
|
tya
|
|
|
|
|
|
|
|
|
|
.8 >PUSHA push CPU Stack BC to restore on top of Soft Stack
|
|
|
|
|
|
|
|
|
|
lda (pPs)
|
|
|
|
|
ora #S.PS.F.SLEEP
|
|
|
|
|
sta (pPs)
|
|
|
|
|
|
|
|
|
|
lda #0 cld,clc,cli
|
|
|
|
|
pha
|
|
|
|
|
rti exit to kernel with CC
|
2016-06-07 08:10:18 +02:00
|
|
|
|
*--------------------------------------
|
2016-09-26 18:00:52 +02:00
|
|
|
|
* *** MUST BE REINTRANT ***
|
|
|
|
|
*--------------------------------------
|
2018-04-10 16:03:29 +01:00
|
|
|
|
GP.SysCall dec IRQ.InKernel
|
|
|
|
|
|
|
|
|
|
bit K.SYSCALL.BANK,x
|
2018-04-12 16:45:31 +01:00
|
|
|
|
bmi .1
|
2016-09-26 18:00:52 +02:00
|
|
|
|
|
2018-04-12 16:45:31 +01:00
|
|
|
|
jsr .8 in $E000, no BNK change
|
|
|
|
|
|
|
|
|
|
inc IRQ.InKernel
|
|
|
|
|
rts
|
|
|
|
|
|
|
|
|
|
.1 sta .7+1 save A (Func Arg)
|
2016-09-26 18:00:52 +02:00
|
|
|
|
|
2017-08-25 17:02:16 +02:00
|
|
|
|
lda K.SYSCALL.BANK,x Get Target BNK
|
2016-09-26 18:00:52 +02:00
|
|
|
|
|
|
|
|
|
cmp $D000 #RRAMWRAMBNK1 or #RRAMWRAMBNK2
|
2018-04-12 16:45:31 +01:00
|
|
|
|
bne .2
|
|
|
|
|
|
|
|
|
|
jsr .7 same as actual BNK...go restore A and JMP
|
|
|
|
|
|
|
|
|
|
inc IRQ.InKernel
|
|
|
|
|
rts
|
2016-09-26 18:00:52 +02:00
|
|
|
|
|
2018-04-12 16:45:31 +01:00
|
|
|
|
.2 stx .6+1 save X (Func ID)
|
2016-09-26 18:00:52 +02:00
|
|
|
|
|
|
|
|
|
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 08:26:54 +02:00
|
|
|
|
jsr .6 go to kernel.....
|
2016-09-26 18:00:52 +02:00
|
|
|
|
|
|
|
|
|
stx .5+1 save X
|
|
|
|
|
plx get back Source BNK
|
2016-09-05 18:00:11 +02:00
|
|
|
|
bit $C000,x
|
|
|
|
|
bit $C000,x
|
2016-09-26 18:00:52 +02:00
|
|
|
|
.5 ldx #$FF Self Modified
|
2018-04-10 16:03:29 +01:00
|
|
|
|
|
|
|
|
|
inc IRQ.InKernel
|
2016-09-26 18:00:52 +02:00
|
|
|
|
rts Unmodified Carry
|
|
|
|
|
|
|
|
|
|
.6 ldx #$FF Self Modified
|
|
|
|
|
.7 lda #$FF Self Modified
|
2017-07-01 15:44:40 +02:00
|
|
|
|
.8 jmp (K.SYSCALL.JMP,x)
|
2016-09-26 18:00:52 +02:00
|
|
|
|
*--------------------------------------
|
2018-04-10 16:03:29 +01:00
|
|
|
|
GP.LibCall dec IRQ.InKernel
|
|
|
|
|
|
2018-06-21 17:12:10 +02:00
|
|
|
|
pha No need to save X, K.GetMemPtr will leave it unmodified
|
2016-09-26 18:00:52 +02:00
|
|
|
|
tya Get LIB hMem in A
|
2018-06-21 17:12:10 +02:00
|
|
|
|
jsr K.GetMemPtr Get LIB Code Segment (MemMgr in $E000, no BNK change)
|
2017-03-27 17:32:30 +02:00
|
|
|
|
>STYA .1+1
|
2016-06-07 08:10:18 +02:00
|
|
|
|
pla
|
2018-04-10 16:03:29 +01:00
|
|
|
|
.1 jsr * SELF MODIFIED
|
|
|
|
|
|
|
|
|
|
inc IRQ.InKernel
|
|
|
|
|
|
|
|
|
|
rts
|
2016-06-07 08:10:18 +02:00
|
|
|
|
*--------------------------------------
|
2018-04-10 16:03:29 +01:00
|
|
|
|
GP.AtkCall dec IRQ.InKernel
|
|
|
|
|
|
|
|
|
|
>STYA .1
|
2016-09-26 18:00:52 +02:00
|
|
|
|
jsr GO.ProDOS
|
2016-06-07 08:10:18 +02:00
|
|
|
|
jsr MLI
|
2017-11-05 22:23:21 +01:00
|
|
|
|
.DA #MLIATALK
|
|
|
|
|
.1 .DA *
|
2016-09-26 18:00:52 +02:00
|
|
|
|
jsr GO.A2osX
|
2018-04-10 16:03:29 +01:00
|
|
|
|
|
|
|
|
|
inc IRQ.InKernel
|
2016-06-07 08:10:18 +02:00
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
2018-04-10 16:03:29 +01:00
|
|
|
|
GP.RomCall dec IRQ.InKernel
|
|
|
|
|
|
|
|
|
|
phx
|
2017-10-16 17:41:48 +02:00
|
|
|
|
ldx $D000
|
|
|
|
|
stx .8+1
|
|
|
|
|
|
|
|
|
|
bit RROMBNK1
|
|
|
|
|
|
|
|
|
|
plx
|
|
|
|
|
jsr .1
|
|
|
|
|
|
|
|
|
|
.8 ldx #$ff
|
|
|
|
|
bit $C000,x
|
|
|
|
|
bit $C000,x
|
2018-04-10 16:03:29 +01:00
|
|
|
|
|
|
|
|
|
inc IRQ.InKernel
|
|
|
|
|
|
2017-10-16 17:41:48 +02:00
|
|
|
|
rts
|
2017-10-26 18:01:54 +02:00
|
|
|
|
|
2017-10-16 17:41:48 +02:00
|
|
|
|
.1 jmp (.2,x)
|
2017-10-26 18:01:54 +02:00
|
|
|
|
|
|
|
|
|
* http://www.txbobsc.com/scsc/scdocumentor/E7A0.html
|
|
|
|
|
|
2017-10-30 17:11:07 +01:00
|
|
|
|
.2 .DA $E7AA FSUBT
|
|
|
|
|
.DA $E7C1 FADDT
|
2017-10-27 08:36:46 +02:00
|
|
|
|
.DA $E82E NORMALIZE.FAC.2 (L->F)
|
2017-10-18 17:32:56 +02:00
|
|
|
|
.DA $E941 LOG
|
2017-10-30 17:11:07 +01:00
|
|
|
|
.DA $E987 FMULTT.1
|
2017-10-27 16:56:46 +02:00
|
|
|
|
.DA $E9E7 LOAD.ARG.FROM.INDEX
|
2017-10-30 17:11:07 +01:00
|
|
|
|
.DA $EA6B FDIVT+2
|
2017-10-27 16:56:46 +02:00
|
|
|
|
.DA $EAFD LOAD.FAC.FROM.INDEX
|
2017-10-27 08:36:46 +02:00
|
|
|
|
|
2017-11-05 22:23:21 +01:00
|
|
|
|
.DA $EB27 SETFOR (GETFAC)
|
2017-10-27 08:36:46 +02:00
|
|
|
|
.DA $EBB2 FCOMP
|
|
|
|
|
.DA $EBF2 QINT (F->L)
|
2017-10-27 16:56:46 +02:00
|
|
|
|
.DA $EC4A FIN StrToF
|
|
|
|
|
.DA $ED36 FOUT.1 PrintF
|
2017-10-18 17:32:56 +02:00
|
|
|
|
.DA $EE8D SQR
|
|
|
|
|
.DA $EE97 FPWRT
|
|
|
|
|
.DA $EF09 EXP
|
2017-10-27 08:36:46 +02:00
|
|
|
|
|
2017-10-18 17:32:56 +02:00
|
|
|
|
.DA $EFEA COS
|
|
|
|
|
.DA $EFF1 SIN
|
|
|
|
|
.DA $F03A TAN
|
|
|
|
|
.DA $F09E ATN
|
|
|
|
|
*--------------------------------------
|
2017-11-05 22:23:21 +01:00
|
|
|
|
GP.MLICall stx .1
|
|
|
|
|
sta K.MLI.PARAMS
|
|
|
|
|
jsr GO.ProDOS
|
|
|
|
|
jsr MLI
|
|
|
|
|
.1 .BS 1
|
|
|
|
|
.DA K.MLI.PARAMS
|
|
|
|
|
jsr GO.A2osX
|
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
2017-03-31 17:24:42 +02:00
|
|
|
|
GO.ProDOS pha
|
|
|
|
|
lda $D000 We re coming from AUXLC, saving bank...
|
2016-09-26 18:00:52 +02:00
|
|
|
|
sta GO.A2osX.BNK+1
|
2017-03-31 17:24:42 +02:00
|
|
|
|
pla
|
2016-09-05 18:00:11 +02:00
|
|
|
|
php
|
2016-06-07 08:10:18 +02:00
|
|
|
|
clc
|
|
|
|
|
.HS 2C bit abs
|
|
|
|
|
|
2016-09-26 18:00:52 +02:00
|
|
|
|
GO.A2osX php
|
2016-06-07 08:10:18 +02:00
|
|
|
|
sec
|
2016-09-05 18:00:11 +02:00
|
|
|
|
|
2016-06-07 08:10:18 +02:00
|
|
|
|
sei
|
|
|
|
|
|
2017-05-03 17:40:02 +02:00
|
|
|
|
sta GO.EXIT.SaveA+1
|
|
|
|
|
stx GO.EXIT.SaveX+1
|
|
|
|
|
sty GO.EXIT.SaveY+1
|
2016-09-05 18:00:11 +02:00
|
|
|
|
|
|
|
|
|
pla Restore P in A for later
|
|
|
|
|
|
|
|
|
|
plx Get PC and add 1 for return
|
2016-06-07 08:10:18 +02:00
|
|
|
|
ply
|
|
|
|
|
inx
|
|
|
|
|
bne .1
|
|
|
|
|
iny
|
2016-09-05 18:00:11 +02:00
|
|
|
|
|
2016-06-07 08:10:18 +02:00
|
|
|
|
.1 stx GO.EXIT.JMP+1
|
|
|
|
|
sty GO.EXIT.JMP+2
|
|
|
|
|
|
2016-09-26 18:00:52 +02:00
|
|
|
|
bcs GO.A2osX.BNK if CS, go AUXLC
|
2016-09-05 18:00:11 +02:00
|
|
|
|
|
|
|
|
|
bit RRAMWRAMBNK1 Go MAINLC (ProDOS), always BNK1
|
|
|
|
|
bit RRAMWRAMBNK1
|
|
|
|
|
|
|
|
|
|
tsx
|
2016-06-07 08:10:18 +02:00
|
|
|
|
stx A2osX.SaveSX
|
|
|
|
|
ldx A2osX.SaveSM
|
|
|
|
|
txs
|
2016-09-05 18:00:11 +02:00
|
|
|
|
sta CLRALTZP
|
2016-06-07 08:10:18 +02:00
|
|
|
|
bra GO.EXIT
|
2016-09-05 18:00:11 +02:00
|
|
|
|
|
2016-09-28 17:34:15 +02:00
|
|
|
|
GO.A2osX.BNK ldx #RRAMWRAMBNK1 Self Modified, initialized to BNK1 for INIT3
|
2016-09-05 18:00:11 +02:00
|
|
|
|
|
|
|
|
|
bit $C000,x
|
|
|
|
|
bit $C000,x
|
|
|
|
|
|
|
|
|
|
sta SETALTZP
|
2016-06-07 08:10:18 +02:00
|
|
|
|
tsx
|
|
|
|
|
stx A2osX.SaveSM
|
|
|
|
|
ldx A2osX.SaveSX
|
|
|
|
|
txs
|
|
|
|
|
*--------------------------------------
|
2017-09-12 17:24:36 +02:00
|
|
|
|
GO.EXIT pha push P on stack
|
2017-05-03 17:40:02 +02:00
|
|
|
|
GO.EXIT.SaveY ldy #$ff
|
|
|
|
|
GO.EXIT.SaveX ldx #$ff
|
|
|
|
|
GO.EXIT.SaveA lda #$ff
|
2016-06-07 08:10:18 +02:00
|
|
|
|
plp
|
2016-09-26 18:00:52 +02:00
|
|
|
|
GO.EXIT.JMP jmp $FFFF Self Modified
|
2016-06-07 08:10:18 +02:00
|
|
|
|
*--------------------------------------
|
2017-11-23 17:51:52 +01:00
|
|
|
|
* Called from ProDOS IRQ Manager (LCBNK1)
|
2017-01-25 17:18:35 +01:00
|
|
|
|
* 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
|
|
|
|
|
*--------------------------------------
|
2018-04-10 16:03:29 +01:00
|
|
|
|
GP.IrqH cld
|
2018-04-05 21:32:22 +01:00
|
|
|
|
|
2018-04-10 16:03:29 +01:00
|
|
|
|
bit IRQ.SkipA2osX After A2osX IRQ.H ?
|
2018-04-27 16:35:55 +02:00
|
|
|
|
bmi GP.IrqH.Exit
|
2018-04-10 16:03:29 +01:00
|
|
|
|
|
2018-04-27 16:35:55 +02:00
|
|
|
|
sta SETALTZP switch to aux LC
|
2017-01-25 17:18:35 +01:00
|
|
|
|
tsx
|
|
|
|
|
stx A2osX.SaveSM
|
|
|
|
|
ldx A2osX.SaveSX
|
|
|
|
|
txs
|
2018-04-27 16:35:55 +02:00
|
|
|
|
|
|
|
|
|
GP.IrqH.JSR jsr K.IrqH.DEV SELF MODIFIED
|
2018-04-05 21:32:22 +01:00
|
|
|
|
|
2018-04-27 15:43:40 +02:00
|
|
|
|
tsx go back to Main
|
2017-01-25 17:18:35 +01:00
|
|
|
|
stx A2osX.SaveSX
|
|
|
|
|
ldx A2osX.SaveSM
|
|
|
|
|
txs
|
|
|
|
|
sta CLRALTZP
|
2018-04-05 21:32:22 +01:00
|
|
|
|
|
2018-04-27 16:35:55 +02:00
|
|
|
|
rts
|
|
|
|
|
|
|
|
|
|
GP.IrqH.Exit stz IRQ.SkipA2osX reset flag
|
|
|
|
|
sec
|
2018-04-05 21:32:22 +01:00
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
2018-04-10 16:03:29 +01:00
|
|
|
|
IRQ.SkipA2osX .BS 1
|
|
|
|
|
IRQ.Tick .BS 1
|
|
|
|
|
IRQ.InKernel .BS 1
|
2018-04-05 21:32:22 +01:00
|
|
|
|
IRQ.IntNum .BS 1
|
|
|
|
|
IRQ.VBL.n0 .BS 1
|
|
|
|
|
IRQ.VBL.0n .BS 1
|
2017-01-25 17:18:35 +01:00
|
|
|
|
*--------------------------------------
|
2017-10-18 17:32:56 +02:00
|
|
|
|
*GO.Reset jsr GO.A2osX
|
|
|
|
|
* jmp CORE.Run
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
*BrkHandler bra *
|
2017-05-03 17:40:02 +02:00
|
|
|
|
*--------------------------------------
|
2018-04-27 15:43:40 +02:00
|
|
|
|
GP.CodeEnd .BS $BEE0-*
|
2017-10-27 16:56:46 +02:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
* $BEE0->$BEEF : Public Variables
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
.BS 16
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
* $BEF0->$BEFF : Kernel Config Block
|
2017-05-03 17:40:02 +02:00
|
|
|
|
*--------------------------------------
|
2018-04-28 14:10:58 +02:00
|
|
|
|
.DA #6 A2osX.HZ=60hz
|
|
|
|
|
.HS 00000000000000
|
2018-04-27 16:35:55 +02:00
|
|
|
|
.DA #0 ChRoot/Preemptive Disabled
|
|
|
|
|
.HS 00000000000000 All Slots marked as "Free"
|
2016-06-07 08:10:18 +02:00
|
|
|
|
*--------------------------------------
|
2018-05-26 19:25:04 +02:00
|
|
|
|
GP.End .EQ *
|
2016-06-07 08:10:18 +02:00
|
|
|
|
MAN
|
2017-03-29 17:48:15 +02:00
|
|
|
|
SAVE /A2OSX.SRC/SYS/KERNEL.S.GP
|
|
|
|
|
LOAD /A2OSX.SRC/SYS/KERNEL.S
|
2016-06-07 08:10:18 +02:00
|
|
|
|
ASM
|