FreeCalypso > hg > freecalypso-tools
view target-utils/buzplayer/timer.c @ 965:2969032bdfac
fcup-smsend[mult]: fix buglet in K&R C NULL pointer passing
The only 100% safe way to pass a NULL pointer as a function argument
in K&R C is to cast 0 to a pointer type; failing to do so may cause
mysterious bugs (invalid stack frames or garbage in argument registers)
on 64-bit machines. This issue has already been fixed in most of
FC host tools, but I just found some missed spots: passing of NULL UDH
to PDU encoding functions in fcup-smsend[mult] in the case of single
(not concatenated) SMS.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 01 Sep 2023 07:33:51 +0000 |
parents | e3d40f49d8c4 |
children |
line wrap: on
line source
/* * FreeCalypso buzzer "melodies" have times measured in TDMA frames, * as that is the time unit in the main firmware which will ultimately * play them. In this standalone buzzer player we simulate TDMA frame * timing by programming Calypso TIMER1 with the period of 1875, and * we detect timer overflow (one virtual TDMA frame time having passed) * by polling the read register to avoid the need for interrupt handling * infrastructure. */ #include "types.h" #include "timer.h" void timer_init() { TIMER1_REGS.cntl = CNTL_CLOCK_ENABLE; TIMER1_REGS.load = 1875; TIMER1_REGS.cntl = CNTL_CLOCK_ENABLE | CNTL_AUTO_RELOAD | CNTL_START; } void wait_for_tdma_frame() { u16 read1, read2; read1 = TIMER1_REGS.read; for (;;) { read2 = TIMER1_REGS.read; if (read2 > read1) return; read1 = read2; } }