-
Notifications
You must be signed in to change notification settings - Fork 418
Interrupt Based Timing
Jan Gromeš edited this page Mar 31, 2024
·
2 revisions
Under some conditions, it may be beneficial to use a custom timer to control timing of protocols and ham radio digital modes, such as RTTY or SSTV. By default, timing of tone lengths is controlled by the Arduino micros()
function. However, if the precision of this function is insufficient, a custom timing based on interrupt may be provided.
-
Define the
RADIOLIB_INTERRUPT_TIMING
macro in your build system and set it to 1. For standard RadioLib installations, this is most easily achieved by adding#define RADIOLIB_INTERRUPT_TIMING (1)
to BuildOptUser.h -
Create the interrupt service routine. This is the function that will be called by the interrupt, the only thing it has to do is to call the method
setTimerFlag()
, which will set the timing flag.
// this function MUST be 'void' type
// and MUST NOT have any arguments
void setFlag(void) {
radio.setTimerFlag();
}
- Set up your timing interrupt and attach the interrupt service routine. This step depends on your platform, the following code snippet assumes the code is running on Arduino Uno and is using the TimerOne library:
#include <TimerOne.h>
// interrupt setup function
// this function MUST be 'void' type
// and MUST have exactly one 'uint32_t' argument
void interruptSetup(uint32_t len) {
Timer1.initialize(len);
Timer1.attachInterrupt(setFlag);
}
- Finally, provide this setup function to the library. The
interruptSetup
function will be called by the library to setup the actual pulse length. For example, when using with 45-baud RTTY, RadioLib will call the function asinterruptSetup(22222)
, to configure the interrupt for 22.222 ms (45 baud). Note that this function will get called repeatedly for changing tone lengths!
radio.setInterruptSetup(interruptSetup);
- Done! The timer will now trigger interrupt, which will control the timing of pulse lengths.