mirror of
https://github.com/DoctorWkt/pdp7-unix.git
synced 2026-01-25 19:57:20 +00:00
sys comments
This commit is contained in:
@@ -65,7 +65,7 @@ sysexit: " common system call exit code
|
||||
1:
|
||||
dzm .insys " clear "in system call" flag
|
||||
jms chkint " pending user interrupt?
|
||||
skp " no
|
||||
skp " no, return to user
|
||||
jmp .save " yes: dump core
|
||||
jms copy; u.rq+2; 10; 6 " restore auto-index locations 10-15
|
||||
lac u.rq+1 " restore auto-index location 9
|
||||
@@ -77,7 +77,7 @@ sysexit: " common system call exit code
|
||||
lac u.ac " restore AC register
|
||||
jmp u.rq+8 i " return to user
|
||||
|
||||
" scheduler / idle loop
|
||||
" scheduler / swapper / idle loop
|
||||
swap: 0
|
||||
ion
|
||||
1:
|
||||
@@ -176,8 +176,8 @@ locn:
|
||||
" call:
|
||||
" .insys/ 0
|
||||
" jms chkint
|
||||
" no: no interrupt, or intflg set (discards interrupt)
|
||||
" yes: PI off, .insys set
|
||||
" <already ".insys", no interrupt, or intflg set (ignore interrupt)>
|
||||
" <found user interrupt: PI off, .insys set>
|
||||
chkint: 0
|
||||
lac .insys
|
||||
sza " in system?
|
||||
|
||||
@@ -216,7 +216,7 @@
|
||||
sza " zero (read)
|
||||
lac d1 " no: get write mode bit
|
||||
sna " non-zero (write)?
|
||||
lac d2 " no: get read mode bot
|
||||
lac d2 " no: get read mode bit
|
||||
dac mode " save for access call
|
||||
lac u.cdir " get current working directory
|
||||
jms namei; 0:0 " search for file
|
||||
|
||||
@@ -330,9 +330,9 @@ rppti:
|
||||
jmp .+3
|
||||
alss 9
|
||||
jmp passone
|
||||
lac sfiles+3
|
||||
sma
|
||||
rsa
|
||||
lac sfiles+3 " get sleep word
|
||||
sma " high bit set?
|
||||
rsa " no: reader select alphanumeric mode
|
||||
1:
|
||||
jms sleep; sfiles+3
|
||||
jms swap
|
||||
|
||||
@@ -248,13 +248,13 @@ dspinit: 0
|
||||
jmp dspinit i
|
||||
|
||||
" "move display" (change display buffer pointer)
|
||||
" called with new buffer pointer in AC??
|
||||
" called with new buffer pointer in AC
|
||||
movdsp: 0
|
||||
iof
|
||||
cdf
|
||||
dac dspbufp
|
||||
cdf " clear display flags (stop)
|
||||
dac dspbufp " save display buf pointer
|
||||
-1
|
||||
dac .dspb
|
||||
dac .dspb " .dspb = -1
|
||||
ion
|
||||
jmp movdsp i
|
||||
|
||||
|
||||
383
src/sys/s7.s
383
src/sys/s7.s
@@ -1,28 +1,28 @@
|
||||
"** 01-s1.pdf page 41
|
||||
" s7
|
||||
|
||||
pibreak: " priority interrupt break processing "chain"
|
||||
dac .ac " save interrupt AC
|
||||
pibreak: " priority interrupt break processing "chain"
|
||||
dac .ac " save interrupt AC
|
||||
"** CROSSED OUT....
|
||||
dpsf
|
||||
jmp 1f " disable the Graphics-2 I/O
|
||||
dpsf " skip on data phone flag set
|
||||
jmp 1f " not set: check next device
|
||||
|
||||
dpcf
|
||||
dprs
|
||||
dac dpstat
|
||||
sma ral
|
||||
jmp 2f
|
||||
dprc
|
||||
dac dpchar
|
||||
dpcf " clear dataphone flag
|
||||
dprs " read dataphone status
|
||||
dac dpstat " save for user
|
||||
sma ral " REC FLG set? rotate flags left
|
||||
jmp 2f " no
|
||||
dprc " read char (bit zero set if parity correct)
|
||||
dac dpchar " save for user
|
||||
-1
|
||||
dac dpread
|
||||
lac dpstat
|
||||
ral
|
||||
dac dpread " dpread = -1
|
||||
lac dpstat " get status back
|
||||
ral " rotate up
|
||||
2:
|
||||
sma
|
||||
jmp piret
|
||||
sma " XMIT FLG set?
|
||||
jmp piret " no: return from interrupt
|
||||
-1
|
||||
dac dpwrite
|
||||
dac dpwrite " dpwrite = -1
|
||||
jmp piret "** END OF CROSSOUT
|
||||
|
||||
1: clsf " clock overflow (line frequency ticks)?
|
||||
@@ -40,7 +40,7 @@ pibreak: " priority interrupt break processing "chain"
|
||||
cnop: " fetched as constant in iread
|
||||
nop
|
||||
-1
|
||||
dac 7 " set location 7 to -1 (nothing ever clears it)
|
||||
dac 7 " set location 7 to -1 (nothing ever checks/clears it?)
|
||||
clon " enable clock interrupts, reset flag
|
||||
lac ttydelay " tty delay positive?
|
||||
spa " yes: skip to skp
|
||||
@@ -49,141 +49,142 @@ cnop: " fetched as constant in iread
|
||||
jms ttyrestart " yes: start output
|
||||
"** START CROSSED OUT: written: lac tty
|
||||
lac .dspb
|
||||
sna
|
||||
jmp piret
|
||||
isz .dsptm
|
||||
skp
|
||||
jmp dsprestart
|
||||
sad d3
|
||||
jmp piret
|
||||
isz .dspb
|
||||
jmp piret
|
||||
jmp dsprestart "** END CROSSED OUT
|
||||
sna " .dspb != 0?
|
||||
jmp piret " no: return
|
||||
isz .dsptm " increment .dsptm; is zero?
|
||||
skp " no
|
||||
jmp dsprestart " yes: restart display
|
||||
sad d3 " .dspb == 3?
|
||||
jmp piret " yes: return
|
||||
isz .dspb " increment .dspb; is zero?
|
||||
jmp piret " no: return from interrupt
|
||||
jmp dsprestart " yes: restart display
|
||||
"** END CROSSED OUT
|
||||
|
||||
1: dssf " disk flag set?
|
||||
jmp 1f " no
|
||||
1: dssf " disk flag set?
|
||||
jmp 1f " no
|
||||
|
||||
-1 " set .dskb = -1
|
||||
-1 " set .dskb = -1
|
||||
dac .dskb
|
||||
|
||||
"** 01-s1.pdf page 42
|
||||
|
||||
dsrs " get disk status in .dske
|
||||
dsrs " get disk status in .dske
|
||||
dac .dske
|
||||
dscs " clear status register
|
||||
dscs " clear status register
|
||||
jmp piret
|
||||
|
||||
"** BEGIN CROSSED OUT
|
||||
1: lds " load display status (see 03-scope.pdf pg 25)
|
||||
sma ral " display trap set? (and rotate left)
|
||||
jmp 1f " not set
|
||||
cdf " display done executing; clear display flags
|
||||
1: lds " load display status (see 03-scope.pdf pg 25)
|
||||
sma ral " display trap set? (and rotate left)
|
||||
jmp 1f " not set
|
||||
cdf " display done executing; clear display flags
|
||||
lac .dspb
|
||||
sna
|
||||
jmp piret " return now if .dspb == 0
|
||||
jmp piret " return now if .dspb == 0
|
||||
tad dm3
|
||||
sna
|
||||
jmp dsprestart " start display if .dspb == 3
|
||||
dac .dspb " otherwise, .dspb -= 3 and return
|
||||
jmp dsprestart " start display if .dspb == 3
|
||||
dac .dspb " otherwise, .dspb -= 3 and return
|
||||
jmp piret
|
||||
dsprestart:
|
||||
lac d1
|
||||
dac .dspb " set .dspb = 1
|
||||
lac dspbufp " load display buf pointer
|
||||
beg " start display processor
|
||||
dac .dspb " set .dspb = 1
|
||||
lac dspbufp " load display buf pointer
|
||||
beg " start display processor
|
||||
-10
|
||||
dac .dsptm " set .dsptm = -10 (10 ticks)
|
||||
dac .dsptm " set .dsptm = -10 (10 ticks)
|
||||
jmp piret
|
||||
|
||||
1: sma ral " edges flag set?? (and rotate)
|
||||
jmp .+3 " no
|
||||
raef " "resume after edges flag"
|
||||
jmp piret " return
|
||||
sma " light pen flag?
|
||||
jmp 1f " no
|
||||
lda " G-2: load display address
|
||||
dac .lpba " save
|
||||
rlpd " G-2: resume after light pen stop
|
||||
1: sma ral " edges flag set?? (and rotate)
|
||||
jmp .+3 " no
|
||||
raef " "resume after edges flag"
|
||||
jmp piret " return
|
||||
sma " light pen flag?
|
||||
jmp 1f " no
|
||||
lda " G-2: load display address
|
||||
dac .lpba " save
|
||||
rlpd " G-2: resume after light pen stop
|
||||
jmp piret
|
||||
|
||||
1: ksf " (TTY) keyboard flag set?
|
||||
jmp 1f " no
|
||||
1: ksf " (TTY) keyboard flag set?
|
||||
jmp 1f " no
|
||||
|
||||
lac ttydelay " get TTY delay
|
||||
sma " minus (waiting for output)?
|
||||
isz ttydelay " no: increment??? (make more positive)
|
||||
krb " read keyboard buffer
|
||||
dac char " save in char
|
||||
sad o375 " interrupt char (TTY ALT MODE?)
|
||||
jmp intrp1 " yes
|
||||
lac ttydelay " get TTY delay
|
||||
sma " minus (waiting for output)?
|
||||
isz ttydelay " no: increment??? (make more positive)
|
||||
krb " read keyboard buffer
|
||||
dac char " save in char
|
||||
sad o375 " interrupt char (TTY ALT MODE?)
|
||||
jmp intrp1 " yes
|
||||
lac d1
|
||||
jms putchar
|
||||
dzm char
|
||||
lac sfiles+0 " get sleep word for ttyin
|
||||
jms wakeup " wake processes
|
||||
dac sfiles+0 " clear sleep word
|
||||
lac char " get character
|
||||
sad o212 " new line (with parity)??
|
||||
skp " yes
|
||||
jmp piret " no: done
|
||||
lac sfiles+1 " get ttyout sleep word
|
||||
sma " highest bit set?
|
||||
xor o400000 " no, make it so (why???)
|
||||
dac sfiles+1 " save back
|
||||
lac sfiles+0 " get sleep word for ttyin
|
||||
jms wakeup " wake processes
|
||||
dac sfiles+0 " clear sleep word
|
||||
lac char " get character
|
||||
sad o212 " new line (with parity)??
|
||||
skp " yes
|
||||
jmp piret " no: done
|
||||
lac sfiles+1 " get ttyout sleep word
|
||||
sma " highest bit set?
|
||||
xor o400000 " no, make it so (why???)
|
||||
dac sfiles+1 " save back
|
||||
|
||||
"** 01-s1.pdf page 43
|
||||
|
||||
jms putcr " output CR next
|
||||
jms ttyrestart " start output
|
||||
jms putcr " output CR next
|
||||
jms ttyrestart " start output
|
||||
jmp piret
|
||||
|
||||
1: tsf " TTY output flag set?
|
||||
jmp 1f " no
|
||||
1: tsf " TTY output flag set?
|
||||
jmp 1f " no
|
||||
|
||||
tcf " yes: clear flag
|
||||
jms ttyrestart " transmit next character
|
||||
tcf " yes: clear flag
|
||||
jms ttyrestart " transmit next character
|
||||
jmp piret
|
||||
|
||||
ttyrestart: 0
|
||||
lac ttydelay " get tty delay
|
||||
spa " positive?
|
||||
jmp ttyrestart i " no: keep waiting
|
||||
lac nttychar " get pending CR, if any
|
||||
dzm nttychar " clear it
|
||||
sza " need to send CR?
|
||||
jmp 3f " yes
|
||||
isz ttydelay " increment ttydelay (make more positive)
|
||||
lac ttydelay " get tty delay
|
||||
spa " positive?
|
||||
jmp ttyrestart i " no: keep waiting
|
||||
lac nttychar " get pending CR, if any
|
||||
dzm nttychar " clear it
|
||||
sza " need to send CR?
|
||||
jmp 3f " yes
|
||||
isz ttydelay " increment ttydelay (make more positive)
|
||||
lac d2
|
||||
jms getchar " get a character
|
||||
jmp 2f " none found??
|
||||
jms getchar " get a character
|
||||
jmp 2f " none found??
|
||||
3:
|
||||
tls " start output
|
||||
sad o12 " newline?
|
||||
jms putcr " yes: put CR next
|
||||
sad o15 " CR?
|
||||
skp " yes
|
||||
jmp ttyrestart i " no: return
|
||||
lac ttydelay " get current tty delay
|
||||
tad o20 " bump by 16
|
||||
rcr " divide by two
|
||||
cma " complement
|
||||
dac ttydelay " save
|
||||
tls " start output
|
||||
sad o12 " newline?
|
||||
jms putcr " yes: put CR next
|
||||
sad o15 " CR?
|
||||
skp " yes
|
||||
jmp ttyrestart i " no: return
|
||||
lac ttydelay " get current tty delay
|
||||
tad o20 " bump by 16
|
||||
rcr " divide by two
|
||||
cma " complement
|
||||
dac ttydelay " save
|
||||
jmp ttyrestart i
|
||||
2:
|
||||
lac sfiles+1 " run out of characters to send: wake user(s)
|
||||
lac sfiles+1 " run out of characters to send: wake user(s)
|
||||
jms wakeup
|
||||
dac sfiles+1
|
||||
jmp ttyrestart i "** written arrow up 2 copies
|
||||
|
||||
"** BEGIN CROSSED OUT
|
||||
1: sck " Graphic-2 keyboard flag set?
|
||||
jmp 1f " no.
|
||||
1: sck " Graphic-2 keyboard flag set?
|
||||
jmp 1f " no.
|
||||
|
||||
cck " yes: clear flag
|
||||
lck " read character
|
||||
cck " yes: clear flag
|
||||
lck " read character
|
||||
dac char
|
||||
sad o33 " code 33 (ESCAPE?)
|
||||
jmp intrp2 " yes: mark interrupt
|
||||
sad o33 " code 33 (ESCAPE?)
|
||||
jmp intrp2 " yes: mark interrupt
|
||||
lac d3
|
||||
jms putchar
|
||||
nop
|
||||
@@ -192,21 +193,21 @@ ttyrestart: 0
|
||||
dac sfiles+2
|
||||
jmp piret
|
||||
|
||||
1: rsf " paper tape ready?
|
||||
jmp 1f " no
|
||||
1: rsf " paper tape reader ready?
|
||||
jmp 1f " no
|
||||
|
||||
|
||||
"** 01-s1.pdf page 44
|
||||
|
||||
lac npptchar
|
||||
sna
|
||||
jmp .+5
|
||||
dac char
|
||||
rrb
|
||||
dac npptchar
|
||||
sna " have saved char?
|
||||
jmp .+5 " no: jump to second rrb
|
||||
dac char " yes: save as current char
|
||||
rrb " clear flag, read reader buffer
|
||||
dac npptchar " save as saved char
|
||||
jmp .+3
|
||||
rrb
|
||||
dac char
|
||||
rrb " here without saved char: read new
|
||||
dac char " save as current
|
||||
3:
|
||||
lac char
|
||||
sna
|
||||
@@ -218,16 +219,16 @@ ttyrestart: 0
|
||||
sad d4
|
||||
jmp 4f
|
||||
2:
|
||||
lac npptchar
|
||||
sna
|
||||
jmp .+4
|
||||
dac char
|
||||
dzm npptchar
|
||||
lac npptchar " get saved char (if any)
|
||||
sna " had saved char?
|
||||
jmp .+4 " no: wake up writer
|
||||
dac char " yes: save as char to send
|
||||
dzm npptchar " clear saved char
|
||||
jmp 3b
|
||||
rsa
|
||||
rsa " reader select alphanumeric mode
|
||||
lac sfiles+3
|
||||
jms wakeup
|
||||
xor o400000
|
||||
jms wakeup " wake sleepers; returns zero
|
||||
xor o400000 " set high bit (rsa before sleep)
|
||||
dac sfiles+3
|
||||
jmp piret
|
||||
3:
|
||||
@@ -239,43 +240,43 @@ ttyrestart: 0
|
||||
dac sfiles+3
|
||||
jmp piret
|
||||
|
||||
1: psf " paper tape ready?
|
||||
jmp 1f " no
|
||||
1: psf " paper tape punch ready?
|
||||
jmp 1f " no
|
||||
|
||||
pcf " clear ptp flag
|
||||
pcf " clear ptp flag
|
||||
lac d5
|
||||
jms getchar " get next char
|
||||
jmp .+3
|
||||
psa
|
||||
jmp piret
|
||||
lac sfiles+4
|
||||
jms wakeup
|
||||
dac sfiles+4
|
||||
jmp piret
|
||||
jms getchar " get next char
|
||||
jmp .+3 " none: wake sleepers
|
||||
psa " punch set alphanumeric mode
|
||||
jmp piret " return from interrupt
|
||||
lac sfiles+4 " get sleeper bit vector
|
||||
jms wakeup " wake them
|
||||
dac sfiles+4 " store zero
|
||||
jmp piret " return from PI
|
||||
|
||||
"** BEGIN CROSSED OUT
|
||||
1: spb " any graphic-2 push button?
|
||||
jmp 1f " no
|
||||
1: spb " any graphic-2 push button?
|
||||
jmp 1f " no
|
||||
|
||||
cpb " clear push button flag
|
||||
lpb " load push button value
|
||||
cpb " clear push button flag
|
||||
lpb " load push button value
|
||||
dac pbsflgs+1
|
||||
|
||||
"** 01-s1.pdf page 45
|
||||
|
||||
and o2000 " get push button 7
|
||||
sna " set?
|
||||
jmp piret " no: done
|
||||
jms dspinit " yes: reset display buffer
|
||||
lac sfiles+6 " wake up anyone sleeping on display
|
||||
and o2000 " get push button 7
|
||||
sna " set?
|
||||
jmp piret " no: done
|
||||
jms dspinit " yes: reset display buffer
|
||||
lac sfiles+6 " wake up anyone sleeping on display
|
||||
jms wakeup
|
||||
dac sfiles+6
|
||||
cla " clear button lights
|
||||
cla " clear button lights
|
||||
wbl
|
||||
jmp piret "** END CROSSED OUT
|
||||
|
||||
1: crsf " card reader flag set?
|
||||
jmp 1f " no
|
||||
1: crsf " card reader flag set?
|
||||
jmp 1f " no
|
||||
|
||||
crrb
|
||||
dac crchar
|
||||
@@ -283,14 +284,14 @@ ttyrestart: 0
|
||||
dac crread
|
||||
jmp piret
|
||||
|
||||
1: crrb " read card reader buffer??
|
||||
1: crrb " read card reader buffer??
|
||||
|
||||
piret: " return from priority interrupt
|
||||
lac 0 " get LINK/PC
|
||||
ral " restore LINK
|
||||
lac .ac " restore AC
|
||||
ion " reenable interrupts
|
||||
jmp 0 i " return from interrupt
|
||||
piret: " return from priority interrupt
|
||||
lac 0 " get LINK (in bit 0)
|
||||
ral " restore LINK
|
||||
lac .ac " restore AC
|
||||
ion " reenable interrupts
|
||||
jmp 0 i " return from interrupt
|
||||
|
||||
" wake sleeping processes
|
||||
" NOTE!! Called from interrupt service, so avoids indirect!!!
|
||||
@@ -299,35 +300,35 @@ piret: " return from priority interrupt
|
||||
" jms wakeup
|
||||
" AC/ 0 (to store in sfiles word)
|
||||
wakeup: 0
|
||||
dac 9f+t " save vector in t0
|
||||
dac 9f+t " save vector in t0
|
||||
-mnproc
|
||||
dac 9f+t+1 " loop count in t1
|
||||
lac tadu " get "tad ulist"
|
||||
dac 9f+t+1 " loop count in t1
|
||||
lac tadu " get "tad ulist"
|
||||
dac 2f
|
||||
lac dacu " get "dac ulist"
|
||||
lac dacu " get "dac ulist"
|
||||
dac 2f+1
|
||||
1:
|
||||
lac 9f+t
|
||||
ral " rotate vector up one
|
||||
ral " rotate vector up one
|
||||
dac 9f+t
|
||||
sma " high bit set?
|
||||
jmp 2f+2 " no: skip the fun
|
||||
lac o700000 " yes: decrement process status (wake)
|
||||
2: tad .. " (avoiding indirect)
|
||||
sma " high bit set?
|
||||
jmp 2f+2 " no: skip the fun
|
||||
lac o700000 " yes: decrement process status (wake)
|
||||
2: tad .. " (avoiding indirect)
|
||||
dac ..
|
||||
lac 2b " advance tad operand by 4 words
|
||||
lac 2b " advance tad operand by 4 words
|
||||
tad d4
|
||||
dac 2b
|
||||
lac 2b+1 " advance tad operand by 4 words
|
||||
lac 2b+1 " advance tad operand by 4 words
|
||||
tad d4
|
||||
dac 2b+1
|
||||
isz 9f+t+1 " done?
|
||||
jmp 1b " no, keep going
|
||||
cla " return zero in AC
|
||||
isz 9f+t+1 " done?
|
||||
jmp 1b " no, keep going
|
||||
cla " return zero in AC
|
||||
jmp wakeup i
|
||||
t = t+2
|
||||
|
||||
" call to output CR after LF (NL)
|
||||
" call to output CR after LF (NL) on TTY
|
||||
putcr: 0
|
||||
lac o15
|
||||
dac nttychar
|
||||
@@ -337,43 +338,43 @@ putcr: 0
|
||||
cla
|
||||
jmp putcr i
|
||||
|
||||
intrp1: " here with TTY interrupt character
|
||||
lac d6 " get keyboard special device number
|
||||
dac .int1 " save as interrupt source
|
||||
lac d1 " drain tty input buffer?
|
||||
intrp1: " here with TTY interrupt character
|
||||
lac d6 " get keyboard special device number
|
||||
dac .int1 " save as interrupt source
|
||||
lac d1 " drain tty input buffer?
|
||||
jms getchar
|
||||
skp
|
||||
jmp .-3
|
||||
lac d2 " drain tty output buffer?
|
||||
lac d2 " drain tty output buffer?
|
||||
jms getchar
|
||||
skp
|
||||
jmp .-3
|
||||
lac sfiles+0 " wake ttyin sleepers
|
||||
lac sfiles+0 " wake ttyin sleepers
|
||||
jms wakeup
|
||||
dac sfiles+0
|
||||
lac sfiles+1 " wake ttyout sleepers
|
||||
lac sfiles+1 " wake ttyout sleepers
|
||||
jms wakeup
|
||||
dac sfiles+1
|
||||
jms chkint " check if user interrupted
|
||||
jmp piret " no, return from PI
|
||||
jmp 1f " yes: return thru system call code (dump core)
|
||||
intrp2: " here with display interrupt character
|
||||
lac d7 " get keyboard special device number
|
||||
dac .int2 " save as interrupt source
|
||||
lac d3 " drain keyboard buffer?
|
||||
jms chkint " check if user interrupted
|
||||
jmp piret " no, return from PI
|
||||
jmp 1f " yes: return thru system call code (dump core)
|
||||
intrp2: " here with display interrupt character
|
||||
lac d7 " get keyboard special device number
|
||||
dac .int2 " save as interrupt source
|
||||
lac d3 " drain keyboard buffer?
|
||||
jms getchar
|
||||
skp
|
||||
jmp .-3
|
||||
lac sfiles+2 " wake up any "keyboard" sleepers
|
||||
lac sfiles+2 " wake up any "keyboard" sleepers
|
||||
jms wakeup
|
||||
dac sfiles+2
|
||||
lac sfiles+6 " wake up any "display" sleepers
|
||||
lac sfiles+6 " wake up any "display" sleepers
|
||||
jms wakeup
|
||||
dac sfiles+6
|
||||
jms chkint " check if user interrupted
|
||||
jmp piret " no, return from PI
|
||||
jms chkint " check if user interrupted
|
||||
jmp piret " no, return from PI
|
||||
1:
|
||||
lac 0 " get interrupt PC
|
||||
dac 020 " save as system call return PC
|
||||
lac .ac " restore AC from interrupt
|
||||
jmp 021 " join system call processing (dump core?)
|
||||
lac 0 " get interrupt PC
|
||||
dac 020 " save as system call return PC
|
||||
lac .ac " restore AC from interrupt
|
||||
jmp 021 " join system call processing (dump core?)
|
||||
|
||||
13
src/sys/s8.s
13
src/sys/s8.s
@@ -117,6 +117,7 @@ dspbuf:
|
||||
" X-Y: invisible, no delay, Y=01740 (992)
|
||||
" X-Y: invisible, settling delay, X=0
|
||||
.=.+30
|
||||
" Kernel startup (reused for display buffer)
|
||||
coldentry:
|
||||
dzm 0100 " not re-entrant
|
||||
caf " clear all flags
|
||||
@@ -145,14 +146,14 @@ edskbsp: .
|
||||
uquant: .=.+1 " number of ticks user has been running
|
||||
dspbufp: .=.+1 " pointer to display buffer
|
||||
pbsflgs: .=.+2 " buttons on last tick, last button interrupt
|
||||
mode: .=.+1
|
||||
mode: .=.+1 " user access mode: 1 for write, 2 for read
|
||||
nttychar: .=.+1 " CR to send next, or zero
|
||||
npptchar: .=.+1
|
||||
npptchar: .=.+1 " saved PTR char
|
||||
ttydelay: .=.+1 " delay count for TTY output
|
||||
name: .=.+4
|
||||
lnkaddr: .=.+1
|
||||
char: .=.+1
|
||||
dskaddr: .=.+1
|
||||
name: .=.+4 " file name for current sys call
|
||||
lnkaddr: .=.+1 " temp for character queue routines
|
||||
char: .=.+1 " current char: temp for PI
|
||||
dskaddr: .=.+1 " number of block in dskbuf
|
||||
uniqpid: 1 " pid generator
|
||||
lu: .=.+4 " user (process) table entry copy
|
||||
sfiles: .=.+10 " wait addresses for special files
|
||||
|
||||
Reference in New Issue
Block a user