Mercurial > hg > Members > kono > nitros9-code
view level2/modules/kernel/fnproc.asm @ 1948:7010c08050b7
Couldn't give yourself write permission to a file 'cause you didn't have write prmission, fixed.
author | chrish |
---|---|
date | Mon, 12 Dec 2005 03:13:04 +0000 |
parents | 1451bc7ef0b9 |
children | 530759e9f289 |
line wrap: on
line source
************************************************** * System Call: F$NProc * * Function: Start the next process in the active queue * * Input: None * * Output: Control does not return to the caller * FNProc IFGT Level-1 ldx <D.SysPrc get system process descriptor stx <D.Proc save it as current lds <D.SysStk get system stack pointer andcc #^IntMasks re-enable IRQ's (to allow pending one through) ELSE clra clrb std <D.Proc ENDC fcb $8C skip the next 2 bytes L0D91 cwai #^IntMasks re-enable IRQ's and wait for one L0D93 orcc #IntMasks Shut off interrupts again lda #Suspend get suspend suspend state flag ldx #D.AProcQ-P$Queue For start of loop, setup to point to current process * Loop to find next active process that is not Suspended L0D9A leay ,x Point y to previous link (process dsc. ptr) ldx P$Queue,y Get process dsc. ptr for next active process beq L0D91 None, allow any pending IRQ thru & try again bita P$State,x There is one, is it Suspended? bne L0D9A Yes, skip it & try next one * Found a process in line ready to be started ldd P$Queue,x Get next process dsc. ptr in line after found one std P$Queue,y Save the next one in line in previous' next ptr stx <D.Proc Make new process dsc. the current one lbsr L0C58 Go check or make a task # for the found process bcs L0D83 Couldn't get one, go to next process in line lda <D.TSlice Reload # ticks this process can run sta <D.Slice Save as new tick counter for process ldu P$SP,x get the process stack pointer lda P$State,x get it's state lbmi L0E29 If in System State, switch to system task (0) L0DB9 bita #Condem Was it condemned by a deadly signal? bne L0DFD Yes, go exit with Error=the signal code # lbsr TstImg do a F$SetTsk if the ImgChg flag is set L0DBD ldb <P$Signal,x any signals? beq L0DF7 no, go on decb is it a wake up signal? beq L0DEF yes, go wake it up leas -R$Size,s make a register buffer on stack leau ,s point to it lbsr L02CB copy the stack from process to our copy of it lda <P$Signal,x get last signal sta R$B,u save it to process' B ldd <P$SigVec,x any intercept trap? beq L0DFD no, go force the process to F$Exit std R$PC,u save vector to it's PC ldd <P$SigDat,x get pointer to intercept data area std R$U,u save it to it's U ldd P$SP,x get it's stack pointer subd #R$Size take off register stack std P$SP,x save updated SP lbsr L02DA Copy modified stack back overtop process' stack leas R$Size,s purge temporary stack L0DEF clr <P$Signal,x clear the signal * No signals go here L0DF7 equ * IFNE H6309 oim #$01,<D.Quick ELSE ldb <D.Quick orb #$01 stb <D.Quick ENDC BackTo1 equ * L0DF2 ldu <D.UsrSvc Get current User's system call service routine ptr stu <D.XSWI2 Save as SWI2 service routine ptr ldu <D.UsrIRQ Get IRQ entry point for user state stu <D.XIRQ Save as IRQ service routine ptr ldb P$Task,x get task number lslb 2 bytes per entry in D.TskIpt ldy P$SP,x get stack pointer lbsr L0E8D re-map the DAT image, if necessary ldb <D.Quick get quick return flag bra L0E4C Go switch GIME over to new process & run * Process a signal (process had no signal trap) L0DFD equ * IFNE H6309 oim #SysState,P$State,x Put process into system state ELSE ldb P$State,x orb #SysState stb P$State,x ENDC leas >P$Stack,x Point SP to process' stack andcc #^IntMasks Turn interrupts on ldb <P$Signal,x Get signal that process received clr <P$Signal,x Clear out the one in process dsc. os9 F$Exit Exit with signal # being error code S.SvcIRQ jmp [>D.Poll] Call IOMAN for IRQ polling