A2osX/SYS/KERNEL.S.INIT.txt

1240 lines
24 KiB
Plaintext
Raw Normal View History

2017-12-22 22:24:30 +01:00
NEW
2019-04-30 18:08:47 +02:00
AUTO 3,1
*--------------------------------------
2018-07-10 17:33:13 +02:00
Kernel.Init2 sei
ldx #$FF
txs
sta SETALTZP
stx A2osX.SaveSM
stx A2osX.SaveSX
2018-07-11 17:13:29 +02:00
ldx #Kernel.ZP.S-1
.1 lda Kernel.ZP,x
sta CHARGET,x
dex
bpl .1
sta CLRALTZP
2018-07-12 17:20:39 +02:00
>LDYAI MSG.Init2
jsr PrintFYA
2017-12-22 22:24:30 +01:00
>LDYAI A2osX.MAIN
>STYA ZPPtr1
>LDYAI CORE.Run
>STYA ZPPtr2
2017-12-22 22:24:30 +01:00
>LDYAI A2osX.MAIN.S^$FFFF
2018-07-10 17:33:13 +02:00
jsr Kernel.Move
2017-12-22 22:24:30 +01:00
>LDYAI A2osX.AUX
>STYA A1L Src Start Address (MAIN)
>LDYAI A2osX.GP
>STYA A2L Src End Address (MAIN)
2019-07-26 16:23:07 +02:00
>LDYAI X.OSD
2017-12-22 22:24:30 +01:00
>STYA A4L Dst Address (AUX)
2019-07-26 16:23:07 +02:00
sec Main To Aux
2017-12-22 22:24:30 +01:00
jsr AuxMove
>LDYAI A2osX.GP
>STYA ZPPtr1
>LDYAI A2osX.SYSCALL
>STYA ZPPtr2
>LDYAI A2osX.GP.S^$FFFF
2018-07-10 17:33:13 +02:00
jsr Kernel.Move
2019-07-29 17:38:55 +02:00
>LDYAI A2osX.GPX
>STYA A1L Src Start Address (MAIN)
>LDYAI A2osX.D1
>STYA A2L Src End Address (MAIN)
>LDYAI A2osX.SYSCALL
>STYA A4L Dst Address (AUX)
sec Main To Aux
jsr AuxMove
sta SETALTZP
bit RRAMWRAMBNK2
bit RRAMWRAMBNK2
>LDYAI A2osX.D2
>STYA ZPPtr1
>LDYAI $D000
>STYA ZPPtr2
>LDYAI A2osX.D2.S^$FFFF
2018-07-10 17:33:13 +02:00
jsr Kernel.Move
bit RRAMWRAMBNK1
bit RRAMWRAMBNK1
>LDYAI A2osX.D1
>STYA ZPPtr1
>LDYAI $D000
>STYA ZPPtr2
>LDYAI A2osX.D1.S^$FFFF
2018-07-10 17:33:13 +02:00
jsr Kernel.Move
>LDYAI A2osX.E0
>STYA ZPPtr1
>LDYAI $E000
>STYA ZPPtr2
>LDYAI A2osX.E0.S^$FFFF
2018-07-10 17:33:13 +02:00
jsr Kernel.Move
2018-07-12 17:20:39 +02:00
bit RROMBNK1
sta CLRALTZP
cli
2018-07-12 17:20:39 +02:00
jsr KConfigLoad
lda A2osX.HZ
2018-07-12 17:20:39 +02:00
pha
>LDYAI MSG.HZ
jsr PrintFYA
2018-07-12 17:20:39 +02:00
>LDYAI MSG.Init2.OK
jsr PrintFYA
*--------------------------------------
>DEBUGOA
*--------------------------------------
Kernel.Init3 sta SETALTZP
bit RRAMWRAMBNK1
bit RRAMWRAMBNK1
lda #$ff Make sure we are in Kernel Mode during setup
sta IRQ.InKernel
2019-03-27 17:01:01 +00:00
stz IRQ.InLib
2019-04-09 16:47:33 +01:00
sta SETALTCHAR
2018-12-14 08:32:20 +01:00
sta CLRMIXED
sta CLRHIRES
sta SET80STORE
sta CLRPAGE2
2019-04-09 16:47:33 +01:00
sta SETDHIRES
2018-12-14 08:32:20 +01:00
jsr MemMgrInit
2018-12-10 17:45:37 +01:00
2019-01-13 13:10:14 +00:00
>LDYAI S.PS Select Process 0 (Kernel)
jsr K.GetMem0
2018-12-18 15:37:07 +01:00
>STYA pPs
2019-01-24 13:53:29 +00:00
stx PS.Table.hPS
2018-12-18 15:37:07 +01:00
2019-08-02 22:55:43 +02:00
jsr Mem.SetOwner
2019-01-24 13:53:29 +00:00
lda #1
sta CORE.PSCount
2018-12-18 15:37:07 +01:00
>LDYAI K.STACKTOP
>STYA pStack
2019-02-24 22:11:52 +00:00
sta pLocal+1
2018-12-18 15:37:07 +01:00
2018-12-11 17:41:25 +01:00
>PUSHWI FD.NULL.NAME
2018-07-12 17:20:39 +02:00
>LDYAI FD.NULL
2019-06-10 15:52:20 +02:00
>SYSCALL2 MKDev
2018-12-03 14:56:52 +01:00
2018-12-10 17:45:37 +01:00
jsr SysScrInit
2018-12-13 17:39:24 +01:00
bcs *
2019-01-07 15:48:25 +00:00
2019-06-07 17:02:51 +02:00
>PUSHWZ Aux type
2019-01-13 13:10:14 +00:00
>PUSHBI S.FI.T.TXT
>PUSHBI O.RDWR
>LDYAI DEV.CONSOLE
2019-06-10 15:52:20 +02:00
>SYSCALL2 fopen
2018-12-03 14:56:52 +01:00
bcs *
2019-01-13 13:10:14 +00:00
ldy #S.PS.hStdIn
sta (pPs),y
iny #S.PS.hStdOut
sta (pPs),y
iny #S.PS.hStdErr
sta (pPs),y
2019-01-06 09:58:49 +00:00
*--------------------------------------
2019-01-13 13:10:14 +00:00
Kernel.Init3C >LDYAI MSG.Init3
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
2018-12-03 14:56:52 +01:00
2018-07-13 16:38:24 +02:00
jsr CPU.Init.6502
2018-12-03 14:56:52 +01:00
2018-07-13 16:38:24 +02:00
jsr CPU.Init.Z80
2018-12-03 14:56:52 +01:00
jsr DevMgrInit
2018-12-03 14:56:52 +01:00
jsr IrqMgrInit
bcs *
2018-12-03 14:56:52 +01:00
jsr EvtMgrInit
2018-12-03 14:56:52 +01:00
jsr TskMgrInit
bcs *
2018-12-03 14:56:52 +01:00
2019-04-09 16:47:33 +01:00
jsr PwdMgrInit
2019-02-01 16:32:29 +00:00
lda KBD
bpl .7
sta KBDSTROBE
cmp #146 CTRL-R for ROOT mode
bne .7
2018-07-17 17:45:59 +02:00
2018-10-17 17:31:29 +02:00
>PUSHBI 0
2018-12-15 21:34:55 +01:00
>LDYAI MSG.CTRLR
2019-06-10 15:52:20 +02:00
>SYSCALL2 printf
2018-10-15 08:25:40 +02:00
2018-10-25 17:31:41 +02:00
>PUSHBI 0 PS Flags
2018-12-14 17:19:05 +01:00
>LDYAI CTRLR.SHELL
2018-07-17 17:45:59 +02:00
bra .8
2019-01-07 15:48:25 +00:00
.7 >PUSHWI ETCINIT.CMDLINE
2018-08-22 17:23:27 +02:00
>PUSHBI 2
2018-11-16 23:43:12 +01:00
>LDYAI MSG.EtcInit
2019-06-10 15:52:20 +02:00
>SYSCALL2 printf
2019-05-03 15:08:12 +02:00
2018-10-25 17:31:41 +02:00
>PUSHBI 0 PS Flags
2018-11-16 23:43:12 +01:00
>LDYAI ETCINIT.CMDLINE
2018-07-17 17:45:59 +02:00
2019-06-10 15:52:20 +02:00
.8 >SYSCALL2 ExecL
2018-11-30 08:42:49 +01:00
2018-12-03 07:59:30 +01:00
bcs Kernel.Init3.Err
2018-10-25 17:31:41 +02:00
>PUSHBI 0
>LDYAI MSG.Init3.OK
2019-06-10 15:52:20 +02:00
>SYSCALL2 printf
>DEBUGOA
jmp CORE.Run
2018-12-03 07:59:30 +01:00
Kernel.Init3.Err
>PUSHA
2018-08-22 17:23:27 +02:00
>PUSHBI 1
>LDYAI MSG.StartupErr
2019-06-10 15:52:20 +02:00
>SYSCALL2 printf
bra * No need to discard Expanded CMDLINE
*--------------------------------------
2018-07-12 17:20:39 +02:00
* INIT2 Subs
*--------------------------------------
2018-07-10 17:33:13 +02:00
Kernel.Move >STYA ZPPtr3
ldy #0
.1 inc ZPPtr3
bne .2
inc ZPPtr3+1
beq .9
.2 lda (ZPPtr1),y
sta (ZPPtr2),y
iny
bne .1
inc ZPPtr1+1
inc ZPPtr2+1
bne .1
2018-07-10 17:33:13 +02:00
.9 rts
*--------------------------------------
2018-07-12 17:20:39 +02:00
KConfigLoad >LDYAI MSG.KCREAD
jsr PrintFYA
2018-07-10 17:33:13 +02:00
jsr MLI
.DA #MLIOPEN
.DA MLIOPEN00
bcs .9
lda MLIOPEN00+5
sta MLIREAD00+1
sta MLICLOSE00+1
jsr MLI
.DA #MLIREAD
.DA MLIREAD00
php
pha
jsr MLI
.DA #MLICLOSE
.DA MLICLOSE00
pla
plp
bcs .9
2018-07-12 17:20:39 +02:00
>LDYAI MSG.KCREAD.OK
jsr PrintFYA
2018-07-10 17:33:13 +02:00
rts
2018-07-12 17:20:39 +02:00
.9 >LDYAI MSG.KCREAD.KO
jsr PrintFYA
2018-07-10 17:33:13 +02:00
rts
*--------------------------------------
2018-07-12 17:20:39 +02:00
* INIT3 Subs
*--------------------------------------
2018-12-10 17:45:37 +01:00
MemMgrInit >LDYAI Mem.MHiMem
>STYA Mem.HiMem
>STYA Mem.Free
>LDYAI Mem.MLoMem
>STYA Mem.LoMem
stz Mem.LastSlot Reserve Slot #0
sta SETWRITEAUX
2018-12-17 15:24:39 +01:00
2018-12-10 17:45:37 +01:00
>LDYAI Mem.XLoMem
>STYA Mem.LoMem
2018-12-17 15:24:39 +01:00
2018-12-10 17:45:37 +01:00
stz Mem.LastSlot Reserve Slot #0
sta CLRWRITEAUX
ldx #K.DEV.MAX*2-1
2019-01-13 13:10:14 +00:00
.1 stz Dev.Table,x
2018-12-10 17:45:37 +01:00
dex
bpl .1
2018-12-21 15:32:45 +01:00
ldx #K.FLT.MAX*2-1
.11 stz Flt.Table.hPath,x
dex
bpl .11
2018-12-10 17:45:37 +01:00
ldx #K.NOD.MAX*2-1
.2 stz Nod.Table.hPath,x
dex
bpl .2
ldx #K.PS.MAX*4-1
.3 stz PS.Table.PID,x
dex
bpl .3
ldx #K.OF.MAX*2-1
.4 stz OF.Table.hPath,x
dex
bpl .4
ldx #K.EVT.MAX*S.EVT-1
.5 stz Evt.Table,x
dex
bpl .5
2019-04-15 06:40:13 +01:00
ldx #K.USR.MAX*2-1
2019-04-17 07:22:23 +01:00
.6 stz S.Table.hSession,x
2019-04-15 06:40:13 +01:00
dex
bpl .6
2018-12-10 17:45:37 +01:00
rts
*--------------------------------------
2019-04-30 18:08:47 +02:00
SysScrInit >LDYAI Mem.XHiMem
2018-12-17 15:24:39 +01:00
>STYA FD.TTY+S.FD.DEV.BUFPTR
jsr SysScrInit.TTYPtrs
2018-12-10 17:45:37 +01:00
2018-12-13 17:39:24 +01:00
>PUSHWI FD.CONSOLE.NAME
>LDYAI FD.TTY
2019-06-10 15:52:20 +02:00
>SYSCALL2 MKDev
2018-12-13 17:39:24 +01:00
bcs .9
2018-12-17 15:24:39 +01:00
ldx A2osX.TTYDEVS
2018-12-10 17:45:37 +01:00
2018-12-17 15:24:39 +01:00
.1 phx
2018-12-10 17:45:37 +01:00
inc FD.TTY+S.FD.DEV.DEVID
2018-12-11 17:41:25 +01:00
inc FD.TTY.NAME+3
2018-12-13 17:39:24 +01:00
2018-12-17 15:24:39 +01:00
jsr SysScrInit.TTYPtrs
2018-12-13 17:39:24 +01:00
2018-12-11 17:41:25 +01:00
>PUSHWI FD.TTY.NAME
2018-12-10 17:45:37 +01:00
>LDYAI FD.TTY
2019-06-10 15:52:20 +02:00
>SYSCALL2 MKDev
2018-12-10 17:45:37 +01:00
2018-12-17 15:24:39 +01:00
plx
bcs .9
dex
2018-12-10 17:45:37 +01:00
bne .1
2018-12-17 15:24:39 +01:00
>LDYA FD.TTY+S.FD.DEV.BUFPTR
sta SETWRITEAUX
>STYA Mem.HiMem
>STYA Mem.Free
sta CLRWRITEAUX
2018-12-13 17:39:24 +01:00
clc
.9 rts
2018-07-12 17:20:39 +02:00
*--------------------------------------
2018-12-17 15:24:39 +01:00
SysScrInit.TTYPtrs
2018-12-13 17:39:24 +01:00
lda DevMgr.Free
sta FD.TTY+S.FD.DEV.DCBPTR
2019-01-07 15:48:25 +00:00
sta .1+1
2018-12-17 15:24:39 +01:00
clc
2018-12-13 17:39:24 +01:00
adc #S.DCB.TTY
sta DevMgr.Free
lda DevMgr.Free+1
sta FD.TTY+S.FD.DEV.DCBPTR+1
2019-01-07 15:48:25 +00:00
sta .1+2
2018-12-17 15:24:39 +01:00
2018-12-13 17:39:24 +01:00
adc /S.DCB.TTY
sta DevMgr.Free+1
2018-12-17 15:24:39 +01:00
2019-01-07 15:48:25 +00:00
ldx #S.DCB.TTY-1
.1 stz $ffff,x SELF MODIFIED
dex
bpl .1
2018-12-17 15:24:39 +01:00
lda FD.TTY+S.FD.DEV.BUFPTR
sec
sbc #TTY.BUF.SIZE
sta FD.TTY+S.FD.DEV.BUFPTR
2018-12-13 17:39:24 +01:00
2018-12-17 15:24:39 +01:00
lda FD.TTY+S.FD.DEV.BUFPTR+1
sbc /TTY.BUF.SIZE
sta FD.TTY+S.FD.DEV.BUFPTR+1
2018-12-13 17:39:24 +01:00
rts
*--------------------------------------
2018-10-02 17:52:30 +02:00
CPU.Init.6502 >PUSHBI 0
>LDYAI MSG.CPU
2019-06-10 15:52:20 +02:00
>SYSCALL2 printf
jsr Detect6502 A = CPU type
sta A2osX.CPUTYPE
2018-07-12 17:20:39 +02:00
2018-07-13 16:38:24 +02:00
and #$F
asl
tax
ldy MSG.CPUTYPE,x
lda MSG.CPUTYPE+1,x
2018-07-12 17:20:39 +02:00
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
lda MACHID
2017-10-27 16:56:46 +02:00
and #MACHID.T
cmp #MACHID.T.IIc
2018-10-02 17:52:30 +02:00
bne .10
jmp CPU.Init.Z80
2018-10-02 17:52:30 +02:00
.10 >PUSHBI 0
2018-07-12 17:20:39 +02:00
>LDYAI MSG.CPU.SPEED
2019-06-10 15:52:20 +02:00
>SYSCALL2 printf
stz A2osX.RANDOM16
stz A2osX.RANDOM16+1
php
sei
.1 bit VBL
bpl .2
.2 bit VBL
bmi .2
ldx #0 Count LO
lda #0 Count HI
.3 ldy #3 (2)
.4 nop (2)
dey (2)
bne .4 (2*)
inc A2osX.RANDOM16 (6)
bne .5 (2*)
inc A2osX.RANDOM16+1 (6)
bit VBL (4)
bpl .3 (2*)
bmi .6
.5 nop (2)
nop (2)
nop (2)
bit VBL (4)
bpl .3 (2*)
.6 plp
stz A2osX.CPUSPEED
.7 sec
lda A2osX.RANDOM16
sbc #100
tax
lda A2osX.RANDOM16+1
sbc /100
bcc .8
stx A2osX.RANDOM16
sta A2osX.RANDOM16+1
inc A2osX.CPUSPEED
bra .7
.8 lda A2osX.RANDOM16
sta A2osX.CPUSPEED+1
2018-07-13 16:38:24 +02:00
>PUSHA push CPU speed LO
lda A2osX.CPUSPEED
2018-07-13 16:38:24 +02:00
>PUSHA push CPU speed HI
2018-08-22 17:23:27 +02:00
>PUSHBI 2
2018-07-12 17:20:39 +02:00
>LDYAI MSG.CPU.SPEEDOK
2019-06-10 15:52:20 +02:00
>SYSCALL2 printf
2018-07-13 16:38:24 +02:00
rts
*--------------------------------------
2018-10-02 17:52:30 +02:00
CPU.Init.Z80 >PUSHBI 0
>LDYAI MSG.Z80
2019-06-10 15:52:20 +02:00
>SYSCALL2 printf
2018-07-12 17:20:39 +02:00
jsr DetectZ80
bcs .9
sta A2osX.Z80SLOT
2018-07-13 16:38:24 +02:00
>PUSHA
tax
lda #A2osX.S.Z80
sta A2osX.S,x
2018-08-22 17:23:27 +02:00
>PUSHBI 1
2018-07-12 17:20:39 +02:00
>LDYAI MSG.Z80.OK
2019-06-10 15:52:20 +02:00
>SYSCALL2 printf
rts
2018-07-12 17:20:39 +02:00
.9 >LDYAI MSG.Z80.KO
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
rts
*--------------------------------------
* Out:
* A = $60, 6502
* A = $61, 65C02
* A = $62, 65R02
* A = $63, 65816
*--------------------------------------
Detect6502 ldy #0 Test 6502 BCD bug
sed
lda #$99
clc
adc #$01
cld
bmi .9 BUG!, we have 6502
ldy #3 test 65C816 TYX Instruction
ldx #0
.OP 65816
tyx TYX: if 65C816, x becomes non-zero
.OP 65C02
bne .9 worked! 65C816
dey y=2 -> R65C02
ldx $EA save zp $EA
stz $EA store 0 in $EA
* .OP 65R02
.HS F7EA For compatibility with A2osX.ASM
* smb 7,$EA if not Rockwell, assemble as nop nop
* .OP 65C02
asl $EA cs if Rockwell
stx $EA restore zp $EA
bcs .9
dey y=1 -> 65C02
.9 tya
ora #$60
rts
*--------------------------------------
* Out:
* A = Z80 Slot
*--------------------------------------
DetectZ80 ldx #Z80Code.Size
.1 lda Z80Code.Start-1,x
2018-07-04 16:59:12 +02:00
sta Z80CODE-1,x 00000H for Z80
dex
bne .1
stz ZPPtr1
lda #$C1
sta ZPPtr1+1
.2 sta (ZPPtr1)
lda $100D
bmi .8
inc ZPPtr1+1
lda ZPPtr1+1
cmp #$C8
beq .9 CS
clc
adc #$20
sta $100A
bra .2
.8 lda ZPPtr1+1
and #$0F
clc
.9 rts
*--------------------------------------
2019-07-23 08:13:03 +02:00
DevMgrInit >LDYAI MSG.DEV
>SYSCALL2 puts
lda DEVCNT
sta .1+1
.1 ldx #$ff SELF MODIFIED
lda DEVLST,x
and #$F0
asl
php Save Drive 1/2 in C
ror DSSS0000
lsr
lsr
lsr
tax 000DSSS0
lsr 0000DSSS
and #$7
sta FD.BDEV+S.FD.DEV.BUSID
ora #$30
sta FD.BDEV.NAME+1 SnDy
lda DEVPTRS,x
sta FD.BDEV+S.FD.DEV.BUSPTR
lda DEVPTRS+1,x
sta FD.BDEV+S.FD.DEV.BUSPTR+1
sta ZPPtr1+1
stz ZPPtr1 Cn00
plp
lda #0
adc #1 Make DevID 1 or 2
sta FD.BDEV+S.FD.DEV.DEVID
ora #$30
sta FD.BDEV.NAME+3 SxDn
lda ZPPtr1+1
cmp #$FF /RAM is always $FF00
bne .2
jsr DevMgrInit.RAM
bra .8 keep slot free
.2 cmp #$D0 Disk II Driver is $D000
bne .3
jsr DevMgrInit.DII
lda #A2osX.S.DII
bra .7 Go mark slot as USED
.3 bcs .53 > $D0, Some BLK remapped DRV
cmp #$C0
bcs .4 $C0 .. $CF, in slot ROM
jsr DevMgrInit.USR Outside ROM/LC space, User loaded BLK dev
bra .8 keep slot free
.4 ldx #SmartPort.SIG-SmartPort.OFS-1
.5 ldy SmartPort.OFS,x Check if there is a smartport firmware
lda (ZPPtr1),y
cmp SmartPort.SIG,x
bne .8 not a Disk Controller...
dex
bpl .5
ldy #7
lda (ZPPtr1),y
beq .51 $Cn07=00 : SmartPort
ldx #AWSmartPort.SIG-AWSmartPort.OFS-1
.50 ldy AWSmartPort.OFS,x Check if there is AWsmartport firmware
lda (ZPPtr1),y
cmp AWSmartPort.SIG,x
bne .6 not on AW
dex
bpl .50
.51 lda ZPPtr1+1 get $Cn
and #$f get $0n
cmp FD.BDEV+S.FD.DEV.BUSID same as SSS ?
beq .52
inc FD.BDEV+S.FD.DEV.DEVID Remapped SP devices....
inc FD.BDEV+S.FD.DEV.DEVID Add 2 to DEVID (2 & 3)
jsr DevMgrInit.SP
bra .8 Phantom slot...
.52 jsr DevMgrInit.SP
lda #A2osX.S.SP
bra .7
.53 inc FD.BDEV+S.FD.DEV.DEVID Remapped BLK devices....
inc FD.BDEV+S.FD.DEV.DEVID Add 2 to DEVID (2 & 3)
.6 jsr DevMgrInit.BLK
lda #A2osX.S.BLK
.7 ldx FD.BDEV+S.FD.DEV.BUSID
sta A2osX.S,x
.8 dec .1+1
bmi .80
jmp .1
.80 clc
rts
*--------------------------------------
DevMgrInit.RAM ldx #0
>LDYAI DRV.RamDrive
bra DevMgrInit.AddBDev
*--------------------------------------
DevMgrInit.DII ldx #2
>LDYAI DRV.DiskII
bra DevMgrInit.AddBDev
*--------------------------------------
DevMgrInit.USR ldx #4
>LDYAI DRV.BlkDevice
bra DevMgrInit.AddBDev
*--------------------------------------
DevMgrInit.BLK ldy #$ff
lda (ZPPtr1),y
sta FD.BDEV+S.FD.DEV.BUSPTR
ldx #6
>LDYAI DRV.BlkDevice
bra DevMgrInit.AddBDev
*--------------------------------------
DevMgrInit.SP ldy #$ff
lda (ZPPtr1),y
clc
adc #3 Compute smartport entry point
sta FD.BDEV+S.FD.DEV.BUSPTR
ldx #8
>LDYAI DRV.SmartPort
*--------------------------------------
DevMgrInit.AddBDev
>STYA FD.BDEV+S.FD.DEV.DRVPTR
>PUSHW MSG.BLKDEV.TBL,x
>PUSHWI FD.BDEV.NAME
>PUSHBI 4
>LDYAI MSG.BLKDEV
>SYSCALL2 printf
>PUSHWI FD.BDEV.NAME
2019-07-24 07:53:09 +02:00
>LDYAI FD.BDEV
2019-07-23 08:13:03 +02:00
>SYSCALL2 MKDev
DevMgrInit.AddBDev.RTS
rts
*--------------------------------------
* Setup AuxLC $FFFE->Kernel IRQ Handler
* if irq not handled, jmp (S.IrqMgrOldFFFE)
*--------------------------------------
IrqMgrInit >LDYAI MSG.IRQ
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
php
sei
>LDYA $FFFE
>STYA K.IrqHAuxLC.JMP+1
>LDYAI K.IrqHAuxLC
>STYA $FFFE
>LDYAI GP.IrqH
>STYA K.MLI.PARAMS+2
>MLICALL MLIALLOCIRQ
bcs .90
lda K.MLI.PARAMS+1
sta IRQ.INTNUM
plp
jsr IrqMgrInit.TClock
bcs .1
lda #"C"
2018-12-17 08:02:03 +01:00
sta IRQ.Mode
>LDYAI K.IrqH.TCLOCK
>STYA K.IrqHAuxLC.JSR+1
>STYA GP.IrqH.JSR+1
>LDYAI MSG.IRQ.CLOCK
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
clc
rts
.1 jsr IrqMgrInit.Mouse
bcs .8
lda #"V"
2018-12-17 08:02:03 +01:00
sta IRQ.Mode
>LDYAI K.IrqH.VBL
>STYA K.IrqHAuxLC.JSR+1
>STYA GP.IrqH.JSR+1
>LDYAI MSG.IRQ.VBL
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
clc
rts
.8 jsr IrqMgrInit.HZ2Tick
lda #"P"
2018-12-17 08:02:03 +01:00
sta IRQ.Mode
>LDYAI MSG.IRQ.POLL
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
clc
rts
.90 plp
.9 sec
rts
*--------------------------------------
IrqMgrInit.TClock
2019-01-04 13:17:31 +00:00
stz ZPPtr1 Try finding a TClock Card...
lda #$C1
sta ZPPtr1+1
2018-10-15 08:25:40 +02:00
.1 ldy #TClock.SIG.Cnt-1
.2 lda (ZPPtr1),y
cmp TClock.SIG,y
bne .3
dey
bpl .2
bra .4
.3 inc ZPPtr1+1 no match, try next slot....
lda ZPPtr1+1
cmp #$C8
bne .1
sec
rts
.4 lda ZPPtr1+1 get $Cn
and #$f
tax get $0n
asl
asl
asl
asl
tay get $n0
sty IRQ.VBL.n0
2018-12-01 20:39:44 +01:00
lda #A2osX.S.CLK
sta A2osX.S,x
php
sei
2018-12-01 20:39:44 +01:00
lda #$40+$20 Enable interrupt + 64Hz
sta $c080,y
2018-12-01 20:39:44 +01:00
lda #$40
sta CLRPAGE2
sta $478,x
sta $7f8,x
lda #64
sta CORE.TickPerSec
sta CORE.TickSec
lda #11
sta CORE.TickPer10t
sta CORE.Tick10t
dec CORE.IRQMode
plp
clc
rts
*--------------------------------------
IrqMgrInit.Mouse
stz ZPPtr1 Try finding a Mouse Card...
lda #$C1
sta ZPPtr1+1
.1 ldx #Mouse.SIG-Mouse.OFS-1
.2 ldy Mouse.OFS,x
lda (ZPPtr1),y
cmp Mouse.SIG,x
bne .3
dex
bpl .2
bra .4
.3 inc ZPPtr1+1 no match, try next slot....
lda ZPPtr1+1
cmp #$C8
bne .1
sec
rts
.4 lda ZPPtr1+1
sta .11+2
sta K.IrqH.VBL.MSM+2
sta K.IrqH.VBL.MRM+2
and #$0f
2017-10-27 16:56:46 +02:00
sta IRQ.VBL.0n
asl
asl
asl
asl
2017-10-27 16:56:46 +02:00
sta IRQ.VBL.n0
php
sei
bit RROMBNK2 Renable ROM to allow MOUSE II firmware works properly
ldy #INITMOUSE
jsr .10
ldy #SETMOUSE
lda #MOUSEMODx.INTVBL+MOUSEMODx.ACTIVE
jsr .10
bit RRAMWRAMBNK1 Back To LC Ram
bit RRAMWRAMBNK1
ldy #SERVEMOUSE
lda (ZPPtr1),y
sta K.IrqH.VBL.MSM+1
ldy #READMOUSE
lda (ZPPtr1),y
sta K.IrqH.VBL.MRM+1
jsr IrqMgrInit.HZ2Tick
dec CORE.IRQMode
plp
clc
rts
.9 plp
sec
rts
.10 pha
lda (ZPPtr1),y
sta .11+1
pla
ldx .11+2 Cn
ldy IRQ.VBL.n0
.11 jmp $ffff SELF MODIFIED
*--------------------------------------
IrqMgrInit.HZ2Tick
ldx #50
lda A2osX.HZ
sta CORE.TickPer10t
sta CORE.Tick10t
cmp #5
beq .1
ldx #60
.1 stx CORE.TickPerSec
stx CORE.TickSec
rts
*--------------------------------------
EvtMgrInit >LDYAI MSG.EVT
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
2018-07-12 17:20:39 +02:00
2019-01-24 13:53:29 +00:00
stz CORE.EvtCount
lda #$A5
sta A2osX.TIMER16
lda #$9B
sta A2osX.TIMER16+1
lda /Evt.Table
sta pEvent+1
clc
2019-04-30 18:08:47 +02:00
EvtMgrInit.RTS rts
*--------------------------------------
TskMgrInit >LDYAI MSG.TSK
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
>LDYAI K.ENV.SIZE get a buffer for ENV
2019-01-22 16:35:42 +00:00
jsr K.GetMem
2019-04-30 18:08:47 +02:00
bcs EvtMgrInit.RTS
2019-01-22 16:35:42 +00:00
>STYA ZPPtr1
ldy #S.PS.ENVPAGECNT
lda /K.ENV.SIZE
sta (pPs),y
txa
2019-01-22 16:35:42 +00:00
* ldy #S.PS.hENV
iny
sta (pPs),y
2019-01-22 16:35:42 +00:00
lda #0
sta (ZPPtr1) make sure blank!!
2019-04-30 18:08:47 +02:00
>LDYAI $2E0 Get ROOT from QC
2019-06-10 15:52:20 +02:00
>SYSCALL2 strdup
bcs .9
txa
2019-07-22 18:28:44 +02:00
ldy #S.PS.hCWD
2019-07-19 08:41:33 +02:00
sta (pPs),y
2019-04-30 18:08:47 +02:00
>PUSHWI $2C0 Get BOOT from QC
>LDYAI I.ENV.BOOT
2019-06-10 15:52:20 +02:00
>SYSCALL2 SetEnv
2019-04-30 18:08:47 +02:00
bcs .9
2019-04-30 18:08:47 +02:00
>PUSHWI $2E0 Get ROOT from QC
>LDYAI I.ENV.ROOT
2019-06-10 15:52:20 +02:00
>SYSCALL2 SetEnv
bcs .9
>LDYAI I.ENV.PATH
2019-06-10 15:52:20 +02:00
>SYSCALL2 PutEnv
bcs .9
>LDYAI I.ENV.LIB
2019-06-10 15:52:20 +02:00
>SYSCALL2 PutEnv
bcs .9
>LDYAI I.ENV.DRV
2019-06-10 15:52:20 +02:00
>SYSCALL2 PutEnv
.9 rts
*--------------------------------------
2019-04-09 16:47:33 +01:00
PwdMgrInit >LDYAI MSG.PWD
2019-06-10 15:52:20 +02:00
>SYSCALL2 puts
2019-06-07 17:02:51 +02:00
>PUSHWZ Aux type
2019-04-09 16:47:33 +01:00
>PUSHBI S.FI.T.TXT
>PUSHBI O.RDONLY
>LDYAI ETCPASSWD
2019-06-10 15:52:20 +02:00
>SYSCALL2 LoadStkObj
2019-04-15 06:40:13 +01:00
bcs .1
2019-04-11 16:59:57 +01:00
stx PWD.hDB
>STYA PWD.DBSize
2019-04-09 16:47:33 +01:00
*--------------------------------------
2019-04-15 06:40:13 +01:00
.1 >LDYAI PwdMgr.ROOT.Size
jsr K.Getmem
2019-04-15 16:29:07 +01:00
>STYA pSession
2019-04-17 07:22:23 +01:00
stx S.Table.hSession
2019-04-15 06:40:13 +01:00
2019-07-19 16:05:22 +02:00
phy
ldy #S.PS.ZP.SESSION+1
sta (pPS),y
dey
pla
sta (pPS),y
2019-05-22 17:46:20 +02:00
lda #1
ldy #S.PS.hSID
sta (pPS),y
2019-04-15 06:40:13 +01:00
ldy #PwdMgr.ROOT.Size-1
.2 lda PwdMgr.ROOT,y
2019-04-15 16:29:07 +01:00
sta (pSession),y
2019-04-15 06:40:13 +01:00
dey
bpl .2
ldy #S.PS.hStdIn
lda (pPS),y
2019-04-15 16:29:07 +01:00
sta S.Table.hFile
2019-04-15 06:40:13 +01:00
rts
*--------------------------------------
2019-04-19 06:42:43 +01:00
PwdMgr.ROOT .DA #S.SESSION.P.ROOT
2019-04-15 16:29:07 +01:00
.DA #0 UID
2019-04-15 06:40:13 +01:00
.DA #0 GID
.AZ "ROOT" NAME
.AZ "Root User" GECOS
.AZ "${ROOT}ROOT/" DIR
.AZ "${ROOT}BIN/SH" SHELL
PwdMgr.ROOT.Size .EQ *-PwdMgr.ROOT
*--------------------------------------
2018-07-11 17:13:29 +02:00
* Modified CHARGET/CHARGOT for ROM CALL
* CHRGET .EQ $B1 - C8
*--------------------------------------
Kernel.ZP .PH $B1
CHARGET inc TXTPTR
bne CHARGOT
inc TXTPTR+1
CHARGOT lda $ffff
2019-07-28 22:39:30 +02:00
beq ZP.IsDigit.9
2018-07-11 17:13:29 +02:00
2019-07-28 22:39:30 +02:00
ZP.IsDigit cmp #'0'
bcc ZP.IsDigit.9
2018-07-11 17:13:29 +02:00
cmp #'9'+1
rts
2019-07-28 22:39:30 +02:00
ZP.IsDigit.9 sec
2018-07-11 17:13:29 +02:00
rts
.EP
Kernel.ZP.S .EQ *-Kernel.ZP
*--------------------------------------
Z80Code.Start .HS 31FF00 START: LD SP,000FFH Init Stack
.HS 3EFF LD A,0FFH Set Flag
.HS 320D00 LD (FLAG),A
.HS 3200E1 LD (0E100H),A Back to 6502
.HS 18F3 JR START Loop
.HS 00 FLAG: .DB 0
Z80Code.Size .EQ *-Z80Code.Start
*--------------------------------------
Mouse.OFS .HS 05070B0CFB
Mouse.SIG .HS 38180120D6
*--------------------------------------
TClock.SIG .HS 0878282c58ff700538b00118b8087848
.HS 8a489848adffcf201ac86868ba8df807
2019-03-29 07:46:36 +00:00
TClock.SIG.Cnt .EQ *-TClock.SIG
2018-07-11 17:13:29 +02:00
*--------------------------------------
2018-07-12 17:20:39 +02:00
MSG.Init2 .AZ "A2osX[Stage2]:Init\nRelocating Kernel...\n"
MSG.HZ .AZ "Kernel SYS Timer Set For %d0 hz Machine.\n"
2018-07-13 16:38:24 +02:00
MSG.KCREAD .AZ "Reading Kernel Config File..."
MSG.KCREAD.OK .AZ "OK\n"
MSG.KCREAD.KO .AZ "\nError While Reading Kernel Config File, Using Default.\n"
MSG.Init2.OK .AZ "A2osX[Stage2]:Complete.\n"
*--------------------------------------
2019-05-02 17:59:11 +02:00
SYSSCREEN.TOP .AZ "A2osX 0.93 Console"
2018-12-14 17:19:05 +01:00
MSG.Init3 .AZ "A2osX[Stage3]:Init *** Press Ctrl-R for ROOT Mode ***"
2018-08-22 17:23:27 +02:00
MSG.DEV .AZ "Device Manager..."
2019-05-06 14:58:15 +02:00
MSG.BLKDEV .AZ " Adding Device: /DEV/%s, Type: %s\r\n"
2019-05-07 10:26:14 +02:00
MSG.BLKDEV.TBL .DA MSG.BLKDEV.RAM
.DA MSG.BLKDEV.DII
2019-05-06 14:58:15 +02:00
.DA MSG.BLKDEV.USR
.DA MSG.BLKDEV.BLK
.DA MSG.BLKDEV.SP
MSG.BLKDEV.RAM .AZ "/RAM Disk"
2019-05-07 10:26:14 +02:00
MSG.BLKDEV.DII .AZ "Disk ]["
2019-05-06 14:58:15 +02:00
MSG.BLKDEV.USR .AZ "User"
MSG.BLKDEV.BLK .AZ "Generic Block"
MSG.BLKDEV.SP .AZ "Smartport"
2018-08-22 17:23:27 +02:00
MSG.IRQ .AZ "Interrupt Manager..."
MSG.IRQ.VBL .AZ " Mouse VBL IRQ Activated."
MSG.IRQ.CLOCK .AZ " Clock Card IRQ Activated."
MSG.IRQ.POLL .AZ " Polling Mode."
MSG.EVT .AZ "Event Manager..."
MSG.TSK .AZ "Task Manager..."
2019-04-09 16:47:33 +01:00
MSG.PWD .AZ "Password Manager..."
2019-05-01 21:16:15 +02:00
MSG.BOOTROOT .AZ "Boot Path:%S\r\nRoot Path:%S\r\n"
2018-12-15 21:34:55 +01:00
MSG.CTRLR .AZ "Ctrl-R Pressed, entering ROOT mode..."
2019-04-09 16:47:33 +01:00
MSG.PWDINIT .AZ "Loading ETC/PASSWD file..."
2019-01-04 13:17:31 +00:00
MSG.ETCINIT .AZ "Executing %s..."
MSG.StartupErr .AZ "Failed : [$%h]\r\n"
2018-10-05 16:58:38 +02:00
MSG.Init3.OK .AZ "OK\r\nA2osX[Stage3]:Complete.\r\n"
*--------------------------------------
MSG.CPU .AZ "Checking CPU..."
2018-07-13 16:38:24 +02:00
MSG.CPUTYPE .DA MSG.6502
.DA MSG.65C02
.DA MSG.65R02
.DA MSG.65816
2018-08-22 17:23:27 +02:00
MSG.6502 .AZ "6502."
MSG.65C02 .AZ "65C02."
MSG.65R02 .AZ "65R02."
MSG.65816 .AZ "65816."
2018-10-03 17:25:03 +02:00
MSG.CPU.SPEED .AZ "Checking CPU Speed..."
2018-07-13 16:38:24 +02:00
MSG.CPU.SPEEDOK .AZ "%d.%02d Mhz.\r\n"
2018-10-03 17:25:03 +02:00
MSG.Z80 .AZ "Checking Z80 CPU..."
2018-07-13 16:38:24 +02:00
MSG.Z80.OK .AZ "Detected In Slot %d.\r\n"
2018-08-22 17:23:27 +02:00
MSG.Z80.KO .AZ "Not Detected."
*--------------------------------------
2018-12-11 17:41:25 +01:00
DEV.CONSOLE .AZ "/DEV/CONSOLE"
2019-04-30 18:08:47 +02:00
RAMx .AZ "/RAMx"
I.ENV.BOOT .AZ "BOOT"
2018-11-17 18:17:13 +01:00
I.ENV.ROOT .AZ "ROOT"
2019-05-01 21:16:15 +02:00
I.ENV.PATH .AZ "PATH=${BOOT}SBIN/:${BOOT}BIN/"
I.ENV.LIB .AZ "LIB=${BOOT}LIB/"
I.ENV.DRV .AZ "DRV=${BOOT}DRV/"
CTRLR.SHELL .AZ "${BOOT}BIN/SH"
2019-04-11 16:59:57 +01:00
ETCPASSWD .AZ "${ROOT}ETC/PASSWD"
2018-11-22 17:39:41 +01:00
ETCINIT.CMDLINE .AZ "${ROOT}ETC/INIT"
*--------------------------------------
MLIOPEN00 .DA #3
2019-04-29 17:47:17 +02:00
.DA .1
.DA $B000
.BS 1
2019-04-29 17:47:17 +02:00
.1 >PSTR "A2osX.KCONFIG"
*--------------------------------------
MLIREAD00 .DA #4
.BS 1
2018-10-08 07:55:28 +02:00
.DA A2osX.KCONFIG
.DA 16
.BS 2
*--------------------------------------
MLICLOSE00 .DA #1
.BS 1
*--------------------------------------
2018-07-11 17:13:29 +02:00
FD.NULL .DA #S.FD.T.CDEV
.DA #0 HANDLER
.DA #0 BUSID
2018-12-11 17:41:25 +01:00
.DA #0 DEVID
2018-07-12 17:20:39 +02:00
.DA 0 BUSPTR
2018-07-11 17:13:29 +02:00
.DA DRV.NULL
2018-12-13 17:39:24 +01:00
.DA 0 DCBPTR
2018-12-11 17:41:25 +01:00
.DA 0 BUFPTR
FD.NULL.NAME .AZ "NULL" NAME
2018-07-11 17:13:29 +02:00
*--------------------------------------
2018-12-10 17:45:37 +01:00
FD.TTY .DA #S.FD.T.CDEV
.DA #0 HANDLER
.DA #0 BUSID
2018-12-11 17:41:25 +01:00
.DA #1 DEVID
.DA 0 BUSPTR
2018-12-13 17:39:24 +01:00
.DA DRV.TERM
.BS 2 DCBPTR
2018-12-17 15:24:39 +01:00
.BS 2 BUFPTR
2018-12-13 17:39:24 +01:00
*--------------------------------------
FD.CONSOLE.NAME .AZ "CONSOLE"
2018-12-11 17:41:25 +01:00
FD.TTY.NAME .AZ "TTY0"
2018-12-10 17:45:37 +01:00
*--------------------------------------
2018-07-11 17:13:29 +02:00
FD.BDEV .DA #S.FD.T.BDEV
.DA #0 HANDLER
.DA #0 BUSID
.DA #0 DEVID
2018-07-12 17:20:39 +02:00
.BS 2 BUSPTR
2018-07-11 17:13:29 +02:00
.BS 2 DRVPTR
2018-12-13 17:39:24 +01:00
.DA 0 DCBPTR
2018-12-11 17:41:25 +01:00
.DA 0 BUFPTR
FD.BDEV.NAME .AZ "S1D1"
2018-07-11 17:13:29 +02:00
*--------------------------------------
SmartPort.OFS .HS 010305
SmartPort.SIG .HS 200003
2019-02-13 16:20:44 +00:00
AWSmartPort.OFS .HS 12131415161718191A1B
AWSmartPort.SIG .HS A9008DF2C0A9708DF3C0
2018-07-11 17:13:29 +02:00
*--------------------------------------
MAN
2018-11-17 18:17:13 +01:00
SAVE USR/SRC/SYS/KERNEL.S.INIT
LOAD USR/SRC/SYS/KERNEL.S
ASM