view level2/modules/kernel/fchain.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 53c50c807d55
children 039ddb7c8ad7
line wrap: on
line source

**************************************************
* System Call: F$Chain
*
* Function: Starts a new child process and terminates the calling process.
*
* Input:  X = Address of module or filename
*         Y = Parameter area size (256 byte pages)
*         U = Address of parameter area
*         A = Language/Type code
*         B = Optional data area size (256 byte pages)
*
* Output: None
*
* Error:  CC = C bit set; B = error code
*
FChain   pshs  u            preserve register stack pointer
         lbsr  AllPrc       allocate a new process descriptor
         bcc   L03B7        do the chain if no error
         puls  u,pc         return to caller with error

* Copy Process Descriptor Data
L03B7    ldx   <D.Proc      get pointer to current process
         pshs  x,u          save old & new descriptor pointers
         leax  P$SP,x       point to source
         leau  P$SP,u       point to destination
         IFNE  H6309
         ldw   #$00fc       get size (P$SP+$FC)
         tfm   x+,u+        move it
         ELSE
         ldy   #$00FC
L03C3    ldd   ,x++		copy bytes
         std   ,u++
         leay  -2,y
         bne   L03C3
         ENDC
L03CB    ldu   2,s          get new descriptor pointer
         leau  <P$DATImg,u
         ldx   ,s           get old descriptor pointer
         lda   P$Task,x     get task #
         lsla               2 bytes per entry
         ldx   <D.TskIpt    get task image table pointer
         stu   a,x          save updated DAT image pointer for later
* Question: are the previous 7 lines necessary? The F$AllTsk call, below
* should take care of everything!
         ldx   <D.Proc      get process descriptor
         IFNE  H6309
         clrd               Faster than 2 memory clears
         ELSE
         clra
         clrb
         ENDC
         stb   P$Task,x     old process has no task number
         std   <P$SWI,x     clear out all sorts of signals and vectors
         std   <P$SWI2,x
         std   <P$SWI3,x
         sta   <P$Signal,x
         std   <P$SigVec,x
         ldu   <P$PModul,x
         os9   F$UnLink     unlink from the primary module
         ldb   P$PagCnt,x   grab the page count
         addb  #$1F         round up to the nearest block
         lsrb  
         lsrb  
         lsrb  
         lsrb  
         lsrb               get number of blocks used
         lda   #$08         
         IFNE  H6309
         subr  b,a          A=number of blocks unused
         ELSE
         pshs  b
         suba  ,s+
         ENDC
         leay  <P$DATImg,x  set up the initial DAT image
         lslb  
         leay  b,y          go to the offset
         ldu   #DAT.Free    mark the blocks as free
L040C    stu   ,y++         do all of them
         deca  
         bne   L040C
         ldu   2,s          get new process descriptor pointer
         stu   <D.Proc      make it the new process
         ldu   4,s
         lbsr  L04B1        link to new module & setup register stack
         IFNE  H6309
         bcs   L04A1
         ELSE
         lbcs  L04A1
         ENDC
         pshs  d            somehow D = memory size? Or parameter size?
         os9   F$AllTsk     allocate a new task number
* ignore errors here
* Hmmm.. the code above FORCES the new process to have the same DAT image ptr
* as the old process, not that it matters...

         IFNE  H6309
         fcb   $24,$00		TODO: Identify this!
         ENDC
         ldu   <D.Proc      get nre process
         lda   P$Task,u     new task number
         ldb   P$Task,x     old task number
         leau  >(P$Stack-R$Size),x  set up the stack for the new process
         leax  ,y           
         ldu   R$X,u        where to copy from
         IFNE  H6309
         cmpr  x,u          check From/To addresses
         ELSE
         pshs  x		src ptr
         cmpu  ,s++		dest ptr
         ENDC
         puls  y		size
         bhi   L0471        To < From: do F$Move
         beq   L0474        To == From, skip F$Move

* To > From: do special copy
         leay  ,y           any bytes to move?
         beq   L0474        no, skip ahead
         IFNE  H6309
         pshs  x            save address
         addr  y,x          add size to FROM address
         cmpr  x,u          is it
         puls  x
         ELSE
         pshs  d,x
         tfr   y,d
         leax  d,x
         pshs  x
         cmpu  ,s++
         puls  d,x
         ENDC
         bls   L0471        end of FROM <= start of TO: do F$Move

* The areas to copy overlap: do special move routine
         pshs  d,x,y,u      save regs
         IFNE  H6309
         addr  y,x         go to the END of the area to copy FROM
         addr  y,u         end of area to copy TO
         ELSE
         tfr   y,d
         leax  d,x
         leau  d,u
         ENDC

* This all appears to be doing a copy where destination <= source,
* in the same address space.
L0457    ldb   ,s           grab ??
         leax  -1,x         back up one
         os9   F$LDABX  
         exg   x,u
         ldb   1,s
         leax  -1,x         back up another one
         os9   F$STABX  
         exg   x,u
         leay  -1,y
         bne   L0457

         puls  d,x,y,u      restore regs
         bra   L0474        skip over F$Move

L0471    os9   F$Move       move data over?
L0474    lda   <D.SysTsk    get system task number
         ldx   ,s           old process dsc ptr
         ldu   P$SP,x
         leax  >(P$Stack-R$Size),x
         ldy   #R$Size
         os9   F$Move       move the stack over
         puls  u,x          restore new, old process dsc's
         lda   P$ID,u
         lbsr  L0386        check alarms
         os9   F$DelTsk     delete the old task
         orcc  #IntMasks
         ldd   <D.SysPrc
         std   <D.Proc
         IFNE   H6309
         aim   #^SysState,P$State,x
         ELSE
         lda   P$State,x
         anda  #^SysState
         sta   P$State,x
         ENDC
         os9   F$AProc      activate the process
         os9   F$NProc      go to it

* comes here on error with link to new module
L04A1    puls  u,x
         stx   <D.Proc
         pshs  b
         lda   ,u
         lbsr  L0386        kill signals
         puls  b
         os9   F$Exit       exit from the process with error condition

* Setup new process DAT image with module
L04B1    pshs   d,x,y,u     preserve everything
         ldd    <D.Proc     get pointer to current process
         pshs   d           save it
         stx    <D.Proc     save pointer to new process
         lda    R$A,u       get module type
         ldx    R$X,u       get pointer to module name
         ldy    ,s          get pointer to current process
         leay   P$DATImg,y  point to DAT image
         os9    F$SLink     map it into new process DAT image
         bcc    L04D7       no error, keep going
         ldd    ,s          restore to current process
         std    <D.Proc
         ldu    4,s         get pointer to new process
         os9    F$Load      try & load it
         bcc    L04D7       no error, keep going
         leas   4,s         purge stack
         puls   x,y,u,pc    restore & return
* 
L04D7    stu    2,s         save pointer to module
         pshs   a,y         save module type & entry point
         ldu    $0B,s       restore register stack pointer
         stx    R$X,u       save updated name pointer
         ldx    $07,s       restore process pointer
         stx    <D.Proc     make it current
         ldd    5,s         get pointer to new module
         std    P$PModul,x  save it into process descriptor
         puls   a           restore module type
         cmpa   #Prgrm+Objct regular module?
         beq    L04FB       yes, go
         cmpa   #Systm+Objct system module?
         beq    L04FB
         IFNE   H6309
*--- these lines added to allow 6309 native mode modules to be executed
         cmpa   #Prgrm+Obj6309 regular module?
         beq    L04FB       yes, go
         cmpa   #Systm+Obj6309 system module?
         beq    L04FB
*---
         ENDC
         ldb    #E$NEMod    return unknown module
L04F4    leas   2,s         purge stack
         stb    3,s         save error
         comb               set carry
         bra    L053E       return
* Setup up data memory
L04FB    ldd    #M$Mem      get offset to module memory size
         leay   P$DATImg,x  get pointer to DAT image
         ldx    P$PModul,x  get pointer to module header
         os9    F$LDDDXY    get module memory size
         cmpa   R$B,u       bigger or smaller than callers request?
         bcc    L050E       bigger, use it instead
         lda    R$B,u       get callers memory size instead
         clrb               clear LSB of mem size
L050E    os9    F$Mem       try & get the data memory
         bcs    L04F4       can't do it, exit with error
         ldx    6,s         restore process pointer
         leay   (P$Stack-R$Size),x point to new register stack
         pshs   d           preserve memory size
         subd   R$Y,u       take off size of paramater area
         std    R$X,y       save pointer to parameter area
         subd   #R$Size     take off size of register stack
         std    P$SP,x      save new SP
         ldd    R$Y,u       get parameter count
         std    R$A,y       save it to new process
         std    6,s         save it for myself to
         puls   d,x         restore top of mem & program entry point
         std    R$Y,y       set top of mem pointer
         ldd    R$U,u       get pointer to parameters
         std    6,s
         lda    #Entire
         sta    R$CC,y      save condition code
         clra  
         sta    R$DP,y      save direct page
         clrb  
         std    R$U,y       save data area start
         stx    R$PC,y      save program entry point
L053E    puls   d           restore process pointer
         std    <D.Proc     save it as current
         puls   d,x,y,u,pc