prog8/examples/bench8/crc16.p8

32 lines
683 B
Plaintext
Raw Normal View History

2022-08-12 22:02:44 +02:00
%import textio
2023-09-05 22:59:36 +02:00
%import floats
2022-08-12 22:02:44 +02:00
main {
sub crc16(uword data, uword length) -> uword {
uword crc = 0
repeat length {
2023-09-05 22:59:36 +02:00
crc ^= mkword(@(data), 0)
2022-08-12 22:02:44 +02:00
repeat 8 {
if crc & $8000
crc = (crc<<1)^$1021
else
crc<<=1
}
data++
}
return crc
}
sub start() {
txt.print("calculating (expecting $ffd0)...")
cbm.SETTIM(0,0,0)
2022-08-12 22:02:44 +02:00
uword crc = crc16($e000, $2000)
txt.print_uwhex(crc, true)
2022-08-12 22:02:44 +02:00
txt.nl()
2023-09-05 22:59:36 +02:00
floats.print_f(cbm.RDTIM16() / 60.0)
txt.print(" seconds")
sys.wait(9999)
2022-08-12 22:02:44 +02:00
}
}