2017-08-29 17:19:09 +02:00
|
|
|
|
PR#3
|
|
|
|
|
PREFIX /A2OSX.BUILD
|
|
|
|
|
LOMEM $A00
|
|
|
|
|
INC 1
|
|
|
|
|
AUTO 6
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
SYS.BASL0 .EQ $800
|
|
|
|
|
*--------------------------------------
|
2017-09-19 17:34:01 +02:00
|
|
|
|
CORE.Run lda CORE.PSCount
|
|
|
|
|
sta CORE.Counter
|
2017-09-20 17:09:55 +02:00
|
|
|
|
bne .1 SHOULD NEVER HAPPEN!!!
|
|
|
|
|
jmp CORE.Events
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
.1 ldx CORE.Counter
|
|
|
|
|
lda PS.Table.PID-1,x
|
2017-09-20 17:09:55 +02:00
|
|
|
|
beq .8
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
lda PS.Table.hMem-1,x
|
|
|
|
|
jsr K.GetMemPtr.A
|
|
|
|
|
>STYA pPS
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
lda (pPs) get S.PS.F
|
2017-08-29 17:19:09 +02:00
|
|
|
|
bit #S.PS.F.HOLD Waiting for Another Task to Terminate?
|
|
|
|
|
beq .2
|
|
|
|
|
|
|
|
|
|
ldy #S.PS.CPID
|
|
|
|
|
lda (pPs),y
|
2017-09-08 16:49:23 +02:00
|
|
|
|
jsr CORE.GetPSByID.A
|
2017-09-20 17:09:55 +02:00
|
|
|
|
bcc .8 yes, still running....
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
lda (pPs) get S.PS.F again
|
2017-08-29 17:19:09 +02:00
|
|
|
|
and #$FF^S.PS.F.HOLD unmark as HOLD
|
|
|
|
|
sta (pPs)
|
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.2 jsr CORE.PSEnter Restore at least ZP & Ptrs
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
lda (pPs) get S.PS.F again
|
2017-08-29 17:19:09 +02:00
|
|
|
|
bit #S.PS.F.SLEEP Is this PS sleeping?
|
2017-09-20 17:09:55 +02:00
|
|
|
|
beq .3 no, call INIT/RUN
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
and #$FF^S.PS.F.SLEEP unmark as SLEEP
|
|
|
|
|
sta (pPS)
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
jsr CORE.PSResume Restore PC....and JMP to
|
|
|
|
|
bcc .7
|
|
|
|
|
bcs .5
|
|
|
|
|
|
|
|
|
|
.3 bit #S.PS.F.INIT
|
|
|
|
|
beq .4
|
|
|
|
|
|
|
|
|
|
and #$FF^S.PS.F.INIT unmark as INIT
|
2017-08-29 17:19:09 +02:00
|
|
|
|
sta (pPS)
|
|
|
|
|
|
|
|
|
|
ldx #TSKMGR.INIT
|
|
|
|
|
.HS 2C BIT abs
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.4 ldx #TSKMGR.RUN
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
jsr pCodeJmp Call INIT/RUN function
|
|
|
|
|
bcc .7 INIT/RUN/RESUME said CS=QUIT?
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.5 tax save RC
|
2017-08-29 17:19:09 +02:00
|
|
|
|
ldy #S.PS.PPID Notify Parent Process for exit code...
|
|
|
|
|
lda (pPs),y
|
2017-09-20 17:09:55 +02:00
|
|
|
|
jsr CORE.GetPSByID.A X unmodified
|
|
|
|
|
bcs .6 parent is dead.....skipping...
|
2017-09-19 17:34:01 +02:00
|
|
|
|
>STYA ZPPtr1
|
2017-09-20 17:09:55 +02:00
|
|
|
|
|
2017-08-29 17:19:09 +02:00
|
|
|
|
lda (ZPPtr1) Parent PS is HOLD?
|
|
|
|
|
bit #S.PS.F.HOLD
|
2017-09-20 17:09:55 +02:00
|
|
|
|
beq .6 no...
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
|
|
|
|
eor #S.PS.F.HOLD yes, release hold...
|
|
|
|
|
sta (ZPPtr1)
|
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
txa ...probably waiting for this PS to terminate....
|
2017-08-29 17:19:09 +02:00
|
|
|
|
ldy #S.PS.RC give it RC
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.6 ldx #TSKMGR.QUIT Quit this process
|
2017-08-29 17:19:09 +02:00
|
|
|
|
jsr pCodeJmp Call QUIT function
|
|
|
|
|
|
|
|
|
|
ldy #S.PS.PID
|
|
|
|
|
lda (pPs),y
|
2017-09-08 16:49:23 +02:00
|
|
|
|
jsr CORE.PSFree.A
|
2017-09-20 17:09:55 +02:00
|
|
|
|
bra .8
|
|
|
|
|
|
|
|
|
|
.7 jsr CORE.PSLeave Save ZP & Ptrs
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.8 dec CORE.Counter
|
2017-09-19 17:34:01 +02:00
|
|
|
|
bne .1
|
2017-09-06 17:00:10 +02:00
|
|
|
|
*--------------------------------------
|
2017-09-20 17:09:55 +02:00
|
|
|
|
CORE.Events jsr CORE.GetEvents
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
bcs .4 CS=no event
|
|
|
|
|
|
|
|
|
|
jsr CORE.DispatchEvents
|
|
|
|
|
bcc .4 CC=All Events Dispatched
|
|
|
|
|
|
|
|
|
|
jsr CORE.PSSelect0
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
lda #EvtMgr.Table
|
|
|
|
|
sta pEvent
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
.1 lda (pEvent)
|
|
|
|
|
beq .3
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
bmi .2 Ignore & Discard any timer event
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
jsr CORE.DumpEvent
|
2017-09-06 17:00:10 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
.2 jsr CORE.DestroyEvent
|
2017-09-06 17:00:10 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
.3 lda pEvent
|
|
|
|
|
clc
|
|
|
|
|
adc #S.EVT
|
|
|
|
|
sta pEvent
|
|
|
|
|
lda EVTMGR.COUNT
|
|
|
|
|
bne .1
|
2017-09-20 17:09:55 +02:00
|
|
|
|
*--------------------------------------
|
2017-09-19 17:34:01 +02:00
|
|
|
|
.4 lda A2osX.ASCREEN
|
|
|
|
|
cmp #2 is SYS active?
|
|
|
|
|
bne .6
|
2017-09-12 17:24:36 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
ldx CORE.CPULoadI
|
|
|
|
|
lda CORE.CPULoadC,x
|
|
|
|
|
sta SYS.BASL0+38
|
|
|
|
|
dex
|
|
|
|
|
bpl .5
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
ldx #3
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
.5 stx CORE.CPULoadI
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
.6 bit OPENAPPLE
|
|
|
|
|
bpl .8
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
lda KBD
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
bpl .8
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
cmp #"1"
|
|
|
|
|
bcc .8
|
|
|
|
|
cmp #"5"
|
|
|
|
|
bcs .8
|
2017-09-08 16:49:23 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
sta KBDSTROBE
|
2017-09-19 17:34:01 +02:00
|
|
|
|
jsr CORE.ScreenSelect
|
|
|
|
|
.8 jmp CORE.Run
|
2017-09-08 16:49:23 +02:00
|
|
|
|
*--------------------------------------
|
2017-08-31 17:35:15 +02:00
|
|
|
|
* CORE.GetEvents :
|
|
|
|
|
* IN :
|
|
|
|
|
* OUT :
|
|
|
|
|
* CS = no event, A = ERROR
|
|
|
|
|
* CC * event in YA
|
|
|
|
|
* (pEvent)
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
CORE.GetEvents lda #EvtMgr.Table
|
|
|
|
|
sta pEvent point to start of event list
|
|
|
|
|
|
|
|
|
|
stz EvtMgr.Count reset Size
|
|
|
|
|
|
|
|
|
|
lda K.IrkMgr.VBL do we have IRQ enabled for VBL ?
|
|
|
|
|
bpl .10 no, regular poll
|
|
|
|
|
|
|
|
|
|
lda K.IrkMgr.VBLINT
|
|
|
|
|
beq .3 no
|
|
|
|
|
|
|
|
|
|
dec K.IrkMgr.VBLINT
|
|
|
|
|
bra .11
|
|
|
|
|
|
|
|
|
|
.10 lda VBL get VLINE status
|
|
|
|
|
tax
|
|
|
|
|
eor EvtMgr.VBLState
|
2017-09-20 17:09:55 +02:00
|
|
|
|
bpl .3 no change,no tick
|
2017-08-31 17:35:15 +02:00
|
|
|
|
txa
|
|
|
|
|
sta EvtMgr.VBLState save new
|
|
|
|
|
bpl .3 Up2down transition,no tick
|
|
|
|
|
|
|
|
|
|
.11 inc A2osX.TIMER16
|
|
|
|
|
bne .1
|
|
|
|
|
inc A2osX.TIMER16+1
|
|
|
|
|
|
|
|
|
|
.1 dec EvtMgr.HZ.CNT
|
|
|
|
|
bne .3 not yet 100ms
|
|
|
|
|
|
|
|
|
|
ldx A2osX.HZ
|
|
|
|
|
stx EvtMgr.HZ.CNT
|
|
|
|
|
|
|
|
|
|
lda #S.EVT.F.T10TH
|
|
|
|
|
|
|
|
|
|
dec EvtMgr.10TH.CNT
|
|
|
|
|
bne .2
|
|
|
|
|
|
|
|
|
|
ldx #10
|
|
|
|
|
stx EvtMgr.10TH.CNT
|
|
|
|
|
|
|
|
|
|
ora #S.EVT.F.T1SEC
|
|
|
|
|
|
|
|
|
|
.2 sta (pEvent)
|
|
|
|
|
inc EvtMgr.Count Add one event to Queue
|
|
|
|
|
|
|
|
|
|
lda pEvent
|
|
|
|
|
clc
|
|
|
|
|
adc #S.EVT
|
|
|
|
|
sta pEvent if CS, EVT queue full!!! ($100)
|
|
|
|
|
|
|
|
|
|
.3 sec
|
|
|
|
|
lda EvtMgr.Count if 0, exit with CS (from cmp), and A=0 "no event"
|
|
|
|
|
beq .9
|
|
|
|
|
|
|
|
|
|
.8 clc
|
|
|
|
|
.9 rts
|
|
|
|
|
*--------------------------------------
|
2017-08-29 17:19:09 +02:00
|
|
|
|
* CORE.DispatchEvents
|
|
|
|
|
* IN:
|
|
|
|
|
* OUT:
|
|
|
|
|
* CS: Not Dispatched
|
|
|
|
|
* CC: Event Cleared
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
CORE.DispatchEvents
|
2017-09-19 17:34:01 +02:00
|
|
|
|
lda CORE.PSCount
|
|
|
|
|
sta CORE.Counter
|
2017-08-29 17:19:09 +02:00
|
|
|
|
beq .9
|
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
.1 ldx CORE.Counter
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
lda PS.Table.PID-1,x
|
2017-09-20 17:09:55 +02:00
|
|
|
|
beq .5
|
2017-09-19 17:34:01 +02:00
|
|
|
|
|
|
|
|
|
lda PS.Table.hMem-1,x
|
|
|
|
|
jsr K.GetMemPtr.A
|
|
|
|
|
>STYA pPS
|
|
|
|
|
|
|
|
|
|
lda (pPs) get S.PS.F
|
2017-08-29 17:19:09 +02:00
|
|
|
|
bit #S.PS.F.INIT+S.PS.F.HOLD Init or Waiting for Another Task to Terminate?
|
2017-09-20 17:09:55 +02:00
|
|
|
|
bne .5
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
|
|
|
|
bit #S.PS.F.EVENT Accept Events ?
|
2017-09-20 17:09:55 +02:00
|
|
|
|
beq .5
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
jsr CORE.PSEnter
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
|
|
|
|
lda #EvtMgr.Table
|
|
|
|
|
sta pEvent Select first event in list
|
|
|
|
|
|
|
|
|
|
lda EVTMGR.COUNT
|
|
|
|
|
sta TSKMGR.EVENTCNT
|
|
|
|
|
|
|
|
|
|
.2 lda (pEvent) Empty event, select next
|
|
|
|
|
beq .3
|
|
|
|
|
|
|
|
|
|
ldx #TSKMGR.DOEVENT
|
|
|
|
|
jsr pCodeJmp Call DOEVENT function
|
|
|
|
|
bcs .3 not for this PS, try next event in list
|
|
|
|
|
|
|
|
|
|
jsr CORE.DestroyEvent this PS handled the EVT, destroy it...
|
|
|
|
|
lda EVTMGR.COUNT
|
|
|
|
|
beq .8 no more event, exit
|
|
|
|
|
|
|
|
|
|
.3 dec TSKMGR.EVENTCNT
|
|
|
|
|
beq .4 all EVT submitted to this PS, try other PS
|
|
|
|
|
|
|
|
|
|
lda pEvent try next EVT to this PS
|
|
|
|
|
clc
|
|
|
|
|
adc #S.EVT
|
|
|
|
|
sta pEvent
|
|
|
|
|
bra .2
|
2017-09-20 17:09:55 +02:00
|
|
|
|
|
|
|
|
|
.4 jsr CORE.PSLeave
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.5 dec CORE.Counter
|
2017-09-19 17:34:01 +02:00
|
|
|
|
bne .1
|
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.9 sec
|
2017-09-19 17:34:01 +02:00
|
|
|
|
rts
|
2017-08-29 17:19:09 +02:00
|
|
|
|
|
|
|
|
|
.8 clc
|
|
|
|
|
rts
|
2017-09-19 17:34:01 +02:00
|
|
|
|
*--------------------------------------
|
2017-09-20 17:09:55 +02:00
|
|
|
|
CORE.Quit clc
|
2017-08-29 17:19:09 +02:00
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
2017-09-19 17:34:01 +02:00
|
|
|
|
* PS.Free.A
|
|
|
|
|
* In : A = PID to free
|
|
|
|
|
*--------------------------------------
|
2017-09-20 17:09:55 +02:00
|
|
|
|
CORE.PSFree.A sta .1+1 Save PS ID
|
|
|
|
|
jsr CORE.GetPSByID.A PS in ZPPtr1
|
|
|
|
|
bcs .9
|
2017-09-19 17:34:01 +02:00
|
|
|
|
>STYA ZPPtr1
|
2017-09-20 17:09:55 +02:00
|
|
|
|
|
2017-09-19 17:34:01 +02:00
|
|
|
|
ldy #S.PS.hSS
|
|
|
|
|
jsr .8
|
|
|
|
|
|
|
|
|
|
ldy #S.PS.hDS
|
|
|
|
|
jsr .8
|
|
|
|
|
|
|
|
|
|
ldy #S.PS.hCS
|
|
|
|
|
jsr .8
|
|
|
|
|
|
|
|
|
|
ldy #S.PS.hARGS
|
|
|
|
|
jsr .8
|
|
|
|
|
|
|
|
|
|
lda (ZPPtr1) get S.PS.F
|
|
|
|
|
and #S.PS.F.ENV do we have to discard duplicated env & prefix ?
|
|
|
|
|
beq .1
|
|
|
|
|
|
|
|
|
|
ldy #S.PS.hENV
|
|
|
|
|
jsr .8
|
|
|
|
|
|
|
|
|
|
ldy #S.PS.hPREFIX
|
|
|
|
|
jsr .8
|
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.1 lda #$ff Self Modified
|
|
|
|
|
|
|
|
|
|
ldx CORE.PSCount
|
|
|
|
|
|
|
|
|
|
.2 cmp PS.Table.PID-1,x
|
|
|
|
|
beq .3
|
|
|
|
|
dex
|
|
|
|
|
bne .2
|
|
|
|
|
bra *
|
|
|
|
|
|
|
|
|
|
.3 stz PS.Table.PID-1,x
|
2017-09-19 17:34:01 +02:00
|
|
|
|
lda PS.TABLE.hMem-1,x
|
2017-09-22 17:25:21 +02:00
|
|
|
|
.4 jmp K.FreeMem.A
|
2017-09-19 17:34:01 +02:00
|
|
|
|
|
|
|
|
|
.8 lda (ZPPtr1),y
|
2017-09-22 17:25:21 +02:00
|
|
|
|
bne .4
|
2017-09-19 17:34:01 +02:00
|
|
|
|
.9 rts
|
|
|
|
|
*--------------------------------------
|
2017-09-20 17:09:55 +02:00
|
|
|
|
* X unmodofied
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
CORE.GetPSByID.A
|
|
|
|
|
ldy CORE.PSCount
|
|
|
|
|
beq .9
|
|
|
|
|
|
|
|
|
|
.1 cmp PS.Table.PID-1,y
|
|
|
|
|
beq .2
|
|
|
|
|
dey
|
|
|
|
|
bne .1
|
|
|
|
|
|
|
|
|
|
.9 lda #TSKMGR.ERRNSP
|
|
|
|
|
sec
|
2017-08-29 17:19:09 +02:00
|
|
|
|
rts
|
2017-09-20 17:09:55 +02:00
|
|
|
|
|
|
|
|
|
.2 lda PS.TABLE.hMem-1,y
|
|
|
|
|
jmp K.GetMemPtr.A
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
CORE.DumpEvent ldy #S.EVT-1
|
|
|
|
|
|
|
|
|
|
.1 >PUSHB (pEvent),y
|
|
|
|
|
dey
|
|
|
|
|
bpl .1
|
|
|
|
|
|
|
|
|
|
>LDYAI .2
|
|
|
|
|
jmp K.PrintF.YA
|
|
|
|
|
|
|
|
|
|
.2 >CSTR "!Evt:F=%b,Dev=$%h,LO=$%h,HI=$%h,W1=$%H,W2=$%H\n"
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
CORE.ScreenSelect
|
|
|
|
|
and #$0F
|
|
|
|
|
cmp A2osX.ASCREEN Same as active screen...nothing to do
|
|
|
|
|
beq .8
|
|
|
|
|
|
|
|
|
|
tax
|
|
|
|
|
|
|
|
|
|
lda A2osX.SCRNDEVS-1,x
|
|
|
|
|
beq .8 No device claimed this screen
|
|
|
|
|
|
|
|
|
|
jsr K.GetDevByID.A x unmodified.....
|
|
|
|
|
bcs .8 ???
|
|
|
|
|
|
|
|
|
|
stx A2osX.ASCREEN
|
|
|
|
|
|
|
|
|
|
>STYA pDev
|
|
|
|
|
|
|
|
|
|
ldx #DEVMGR.CONTROL
|
|
|
|
|
jmp pDevJmp
|
|
|
|
|
|
|
|
|
|
.8 rts
|
2017-08-29 17:19:09 +02:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
CORE.DestroyEvent
|
|
|
|
|
lda (pEvent)
|
|
|
|
|
beq .9
|
|
|
|
|
|
|
|
|
|
bit #S.EVT.F.hMEM1
|
|
|
|
|
beq .1
|
|
|
|
|
|
|
|
|
|
pha
|
|
|
|
|
ldy #S.EVT.DATALO
|
|
|
|
|
lda (pEvent),y
|
|
|
|
|
jsr K.FreeMem.A
|
|
|
|
|
pla
|
|
|
|
|
|
|
|
|
|
.1 bit #S.EVT.F.hMEM2
|
|
|
|
|
beq .2
|
|
|
|
|
|
|
|
|
|
ldy #S.EVT.DATAHI
|
|
|
|
|
lda (pEvent),y
|
|
|
|
|
jsr K.FreeMem.A
|
|
|
|
|
|
|
|
|
|
.2 lda #0
|
|
|
|
|
sta (pEvent)
|
|
|
|
|
dec EvtMgr.Count
|
|
|
|
|
.9 rts
|
2017-09-19 17:34:01 +02:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
CORE.PSSelect0 >LDYAI CORE.S.PS0 Select PS0
|
|
|
|
|
>STYA pPs
|
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
>LDYA CORE.S.PS0+S.PS.Context+4
|
|
|
|
|
>STYA pStack
|
2017-09-19 17:34:01 +02:00
|
|
|
|
rts
|
2017-09-15 08:37:15 +02:00
|
|
|
|
*/--------------------------------------
|
|
|
|
|
* # Sleep
|
|
|
|
|
* Make current process suspend until next RUN
|
|
|
|
|
* ## In :
|
|
|
|
|
* (none)
|
|
|
|
|
* ## Out :
|
|
|
|
|
* (none)
|
|
|
|
|
*\--------------------------------------
|
|
|
|
|
K.Sleep pla get PC LO
|
|
|
|
|
sec
|
|
|
|
|
sbc pCode
|
|
|
|
|
ldy #S.PS.PC
|
|
|
|
|
sta (pPs),y
|
|
|
|
|
|
|
|
|
|
pla get PC HI
|
|
|
|
|
sbc pCode+1
|
|
|
|
|
iny
|
|
|
|
|
sta (pPs),y
|
2017-09-19 17:34:01 +02:00
|
|
|
|
|
2017-09-15 08:37:15 +02:00
|
|
|
|
lda (pPs)
|
|
|
|
|
ora #S.PS.F.SLEEP
|
|
|
|
|
sta (pPs)
|
2017-09-20 17:09:55 +02:00
|
|
|
|
*--------------------------------------
|
2017-09-19 17:34:01 +02:00
|
|
|
|
CORE.PSLeave ldy #S.PS.Context+23
|
|
|
|
|
ldx #23
|
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.1 lda pCode,x
|
2017-09-19 17:34:01 +02:00
|
|
|
|
sta (pPs),y
|
|
|
|
|
dey
|
|
|
|
|
dex
|
|
|
|
|
bpl .1
|
2017-09-18 17:43:00 +02:00
|
|
|
|
|
2017-09-15 08:37:15 +02:00
|
|
|
|
clc No error,
|
|
|
|
|
rts back to Kernel
|
2017-08-29 17:19:09 +02:00
|
|
|
|
*--------------------------------------
|
2017-09-20 17:09:55 +02:00
|
|
|
|
CORE.PSEnter ldy #S.PS.Context+23
|
|
|
|
|
ldx #23
|
2017-09-18 17:43:00 +02:00
|
|
|
|
|
2017-09-20 17:09:55 +02:00
|
|
|
|
.1 lda (pPs),y
|
|
|
|
|
sta pCode,x
|
|
|
|
|
dey
|
|
|
|
|
dex
|
|
|
|
|
bpl .1
|
|
|
|
|
rts
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
CORE.PSResume ldy #S.PS.PC
|
2017-09-18 17:43:00 +02:00
|
|
|
|
lda (pPs),y
|
|
|
|
|
sec Advance PC by one as it was saved by a JSR
|
|
|
|
|
adc pCode setup by PS.Select
|
2017-09-19 17:34:01 +02:00
|
|
|
|
sta .8+1
|
2017-09-18 17:43:00 +02:00
|
|
|
|
iny
|
|
|
|
|
lda (pPs),y
|
|
|
|
|
adc pCode+1
|
2017-09-19 17:34:01 +02:00
|
|
|
|
sta .8+2
|
|
|
|
|
|
|
|
|
|
.8 jmp $FFFF
|
2017-09-18 17:43:00 +02:00
|
|
|
|
*--------------------------------------
|
2017-09-11 17:29:08 +02:00
|
|
|
|
TSKMGR.EVENTCNT .BS 1
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
DevMgr.Stat .DA DevMgr.NUL.Code
|
|
|
|
|
DevMgr.Free .DA DevMgr.FreeMem
|
|
|
|
|
.DA DevMgr.HiMem
|
|
|
|
|
DevMgr.Count .DA #2 NUL,SYS
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
EvtMgr.VBLState .BS 1
|
|
|
|
|
EvtMgr.10TH.CNT .BS 1
|
|
|
|
|
EvtMgr.HZ.CNT .BS 1
|
|
|
|
|
EvtMgr.Count .BS 1
|
|
|
|
|
*--------------------------------------
|
2017-09-19 17:34:01 +02:00
|
|
|
|
CORE.CPULoadI .BS 1
|
|
|
|
|
CORE.CPULoadC .AS -"/-\|"
|
|
|
|
|
CORE.Counter .BS 1
|
|
|
|
|
CORE.PSCount .DA #0
|
|
|
|
|
CORE.LastPSID .DA #0
|
|
|
|
|
CORE.S.PS0 .BS S.PS
|
2017-09-11 17:29:08 +02:00
|
|
|
|
*--------------------------------------
|
2017-08-29 17:19:09 +02:00
|
|
|
|
MAN
|
|
|
|
|
SAVE /A2OSX.SRC/SYS/KERNEL.S.CORE
|
|
|
|
|
LOAD /A2OSX.SRC/SYS/KERNEL.S
|
|
|
|
|
ASM
|