sys.wait() no longer resets the jiffyclock to zero

This commit is contained in:
Irmen de Jong 2021-01-03 02:45:25 +01:00
parent cb65480c6c
commit e6a1442296
4 changed files with 16 additions and 12 deletions

View File

@ -485,13 +485,17 @@ sys {
} }
sub wait(uword jiffies) { sub wait(uword jiffies) {
c64.SETTIM(0,0,0) ; TODO do the wait without resetting the jiffy clock ; --- wait approximately the given number of jiffies (1/60th seconds)
while c64.RDTIM16() < jiffies { repeat jiffies {
; wait till the time catches up ubyte jiff = lsb(c64.RDTIM16())
while jiff==lsb(c64.RDTIM16()) {
; wait until 1 jiffy has passed
} }
} }
} }
}
cx16 { cx16 {
; the sixteen virtual 16-bit registers that the CX16 has defined in the zeropage ; the sixteen virtual 16-bit registers that the CX16 has defined in the zeropage

View File

@ -474,9 +474,12 @@ sys {
} }
sub wait(uword jiffies) { sub wait(uword jiffies) {
c64.SETTIM(0,0,0) ; TODO do the wait without resetting the jiffy clock ; --- wait approximately the given number of jiffies (1/60th seconds)
while c64.RDTIM16() < jiffies { repeat jiffies {
; wait till the time catches up ubyte jiff = lsb(c64.RDTIM16())
while jiff==lsb(c64.RDTIM16()) {
; wait until 1 jiffy has passed
}
} }
} }

View File

@ -3,7 +3,6 @@ TODO
==== ====
- move all str* builtin functions to a str library module - move all str* builtin functions to a str library module
- make the syslib.wait() functions not reset the jiffy clock to 0
- detect variables that are written but never read - mark those as unused too and remove them, such as uword unused = memory("unused222", 20) - also remove the memory slab allocation - detect variables that are written but never read - mark those as unused too and remove them, such as uword unused = memory("unused222", 20) - also remove the memory slab allocation
- hoist all variable declarations up to the subroutine scope *before* even the constant folding takes place (to avoid undefined symbol errors when referring to a variable from another nested scope in the subroutine) - hoist all variable declarations up to the subroutine scope *before* even the constant folding takes place (to avoid undefined symbol errors when referring to a variable from another nested scope in the subroutine)
- make it possible to use cpu opcodes such as 'nop' as variable names by prefixing all asm vars with something such as '_' - make it possible to use cpu opcodes such as 'nop' as variable names by prefixing all asm vars with something such as '_'

View File

@ -1,6 +1,6 @@
%import test_stack %import test_stack
%import textio %import textio
%zeropage full %zeropage basicsafe
%option no_sysinit %option no_sysinit
main { main {
@ -8,13 +8,11 @@ main {
sub start () { sub start () {
uword current_time uword current_time
repeat 5 { repeat 6 {
current_time = c64.RDTIM16() current_time = c64.RDTIM16()
txt.print_uw(current_time) txt.print_uw(current_time)
txt.chrout('\n') txt.chrout('\n')
repeat 60000 { sys.wait(30)
current_time++
}
} }