mirror of
https://github.com/irmen/prog8.git
synced 2025-01-03 21:31:35 +00:00
43 lines
1.1 KiB
Plaintext
43 lines
1.1 KiB
Plaintext
|
%import textio
|
||
|
|
||
|
main {
|
||
|
sub crc32(uword data, uword length) {
|
||
|
; because prog8 doesn't have 32 bits integers, we have to split up the calucation over 2 words.
|
||
|
; result in cx16.r0 (high word) and cx1.r1 (low word).
|
||
|
cx16.r0 = 0
|
||
|
cx16.r1 = 0
|
||
|
repeat length {
|
||
|
cx16.r0 ^= @(data) << $0008
|
||
|
repeat 8 {
|
||
|
if cx16.r0 & $8000 {
|
||
|
sys.clear_carry()
|
||
|
rol(cx16.r1)
|
||
|
rol(cx16.r0)
|
||
|
cx16.r0 ^= $04c1
|
||
|
cx16.r1 ^= $1db7
|
||
|
}
|
||
|
else {
|
||
|
sys.clear_carry()
|
||
|
rol(cx16.r1)
|
||
|
rol(cx16.r0)
|
||
|
}
|
||
|
}
|
||
|
data++
|
||
|
}
|
||
|
cx16.r0 ^= $ffff
|
||
|
cx16.r1 ^= $ffff
|
||
|
}
|
||
|
|
||
|
sub start() {
|
||
|
txt.print("calculating...")
|
||
|
c64.SETTIM(0,0,0)
|
||
|
crc32($e000, $2000)
|
||
|
txt.print_uwhex(cx16.r0, true)
|
||
|
txt.print_uwhex(cx16.r1, false)
|
||
|
txt.nl()
|
||
|
txt.print_uw(c64.RDTIM16())
|
||
|
txt.print(" jiffies")
|
||
|
sys.wait(100)
|
||
|
}
|
||
|
}
|