bit of refactoring

This commit is contained in:
Felix Rusu 2023-08-12 21:29:01 -04:00
parent 06a4a7ba25
commit 8b564899c7
1 changed files with 254 additions and 307 deletions

143
RFM69.cpp
View File

@ -57,15 +57,13 @@ RFM69::RFM69(uint8_t slaveSelectPin, uint8_t interruptPin, bool isRFM69HW_HCW, S
#endif #endif
} }
bool RFM69::initialize(uint8_t freqBand, uint16_t nodeID, uint8_t networkID) bool RFM69::initialize(uint8_t freqBand, uint16_t nodeID, uint8_t networkID) {
{
_interruptNum = digitalPinToInterrupt(_interruptPin); _interruptNum = digitalPinToInterrupt(_interruptPin);
if (_interruptNum == (uint8_t)NOT_AN_INTERRUPT) return false; if (_interruptNum == (uint8_t)NOT_AN_INTERRUPT) return false;
#ifdef RF69_ATTACHINTERRUPT_TAKES_PIN_NUMBER #ifdef RF69_ATTACHINTERRUPT_TAKES_PIN_NUMBER
_interruptNum = _interruptPin; _interruptNum = _interruptPin;
#endif #endif
const uint8_t CONFIG[][2] = const uint8_t CONFIG[][2] = {
{
/* 0x01 */ { REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_LISTEN_OFF | RF_OPMODE_STANDBY }, /* 0x01 */ { REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_LISTEN_OFF | RF_OPMODE_STANDBY },
/* 0x02 */ { REG_DATAMODUL, RF_DATAMODUL_DATAMODE_PACKET | RF_DATAMODUL_MODULATIONTYPE_FSK | RF_DATAMODUL_MODULATIONSHAPING_00 }, // no shaping /* 0x02 */ { REG_DATAMODUL, RF_DATAMODUL_DATAMODE_PACKET | RF_DATAMODUL_MODULATIONTYPE_FSK | RF_DATAMODUL_MODULATIONSHAPING_00 }, // no shaping
/* 0x03 */ { REG_BITRATEMSB, RF_BITRATEMSB_55555}, // default: 4.8 KBPS /* 0x03 */ { REG_BITRATEMSB, RF_BITRATEMSB_55555}, // default: 4.8 KBPS
@ -151,14 +149,12 @@ bool RFM69::initialize(uint8_t freqBand, uint16_t nodeID, uint8_t networkID)
} }
// return the frequency (in Hz) // return the frequency (in Hz)
uint32_t RFM69::getFrequency() uint32_t RFM69::getFrequency() {
{
return RF69_FSTEP * (((uint32_t) readReg(REG_FRFMSB) << 16) + ((uint16_t) readReg(REG_FRFMID) << 8) + readReg(REG_FRFLSB)); return RF69_FSTEP * (((uint32_t) readReg(REG_FRFMSB) << 16) + ((uint16_t) readReg(REG_FRFMID) << 8) + readReg(REG_FRFLSB));
} }
// set the frequency (in Hz) // set the frequency (in Hz)
void RFM69::setFrequency(uint32_t freqHz) void RFM69::setFrequency(uint32_t freqHz) {
{
uint8_t oldMode = _mode; uint8_t oldMode = _mode;
if (oldMode == RF69_MODE_TX) { if (oldMode == RF69_MODE_TX) {
setMode(RF69_MODE_RX); setMode(RF69_MODE_RX);
@ -173,8 +169,7 @@ void RFM69::setFrequency(uint32_t freqHz)
setMode(oldMode); setMode(oldMode);
} }
void RFM69::setMode(uint8_t newMode) void RFM69::setMode(uint8_t newMode) {
{
if (newMode == _mode) if (newMode == _mode)
return; return;
@ -213,21 +208,18 @@ void RFM69::sleep() {
} }
//set this node's address //set this node's address
void RFM69::setAddress(uint16_t addr) void RFM69::setAddress(uint16_t addr) {
{
_address = addr; _address = addr;
writeReg(REG_NODEADRS, _address); //unused in packet mode writeReg(REG_NODEADRS, _address); //unused in packet mode
} }
//set this node's network id //set this node's network id
void RFM69::setNetwork(uint8_t networkID) void RFM69::setNetwork(uint8_t networkID) {
{
writeReg(REG_SYNCVALUE2, networkID); writeReg(REG_SYNCVALUE2, networkID);
} }
//set user's ISR callback //set user's ISR callback
void RFM69::setIsrCallback(void (*callback)()) void RFM69::setIsrCallback(void (*callback)()) {
{
_isrCallback = callback; _isrCallback = callback;
} }
@ -272,9 +264,7 @@ void RFM69::setPowerLevel(uint8_t powerLevel) {
} }
// return stored _powerLevel // return stored _powerLevel
uint8_t RFM69::getPowerLevel() { uint8_t RFM69::getPowerLevel() { return _powerLevel; }
return _powerLevel;
}
//Set TX Output power in dBm: //Set TX Output power in dBm:
// [-18..+13]dBm in RFM69 W/CW // [-18..+13]dBm in RFM69 W/CW
@ -297,18 +287,15 @@ int8_t RFM69::setPowerDBm(int8_t dBm) {
return dBm; return dBm;
} }
bool RFM69::canSend() bool RFM69::canSend() {
{ if (_mode == RF69_MODE_RX && PAYLOADLEN == 0 && readRSSI() < CSMA_LIMIT) { // if signal stronger than -100dBm is detected assume channel activity
if (_mode == RF69_MODE_RX && PAYLOADLEN == 0 && readRSSI() < CSMA_LIMIT) // if signal stronger than -100dBm is detected assume channel activity
{
setMode(RF69_MODE_STANDBY); setMode(RF69_MODE_STANDBY);
return true; return true;
} }
return false; return false;
} }
void RFM69::send(uint16_t toAddress, const void* buffer, uint8_t bufferSize, bool requestACK) void RFM69::send(uint16_t toAddress, const void* buffer, uint8_t bufferSize, bool requestACK) {
{
writeReg(REG_PACKETCONFIG2, (readReg(REG_PACKETCONFIG2) & 0xFB) | RF_PACKET2_RXRESTART); // avoid RX deadlocks writeReg(REG_PACKETCONFIG2, (readReg(REG_PACKETCONFIG2) & 0xFB) | RF_PACKET2_RXRESTART); // avoid RX deadlocks
uint32_t now = millis(); uint32_t now = millis();
while (!canSend() && millis() - now < RF69_CSMA_LIMIT_MS){ while (!canSend() && millis() - now < RF69_CSMA_LIMIT_MS){
@ -328,12 +315,10 @@ void RFM69::send(uint16_t toAddress, const void* buffer, uint8_t bufferSize, boo
// replies usually take only 5..8ms at 50kbps@915MHz // replies usually take only 5..8ms at 50kbps@915MHz
bool RFM69::sendWithRetry(uint16_t toAddress, const void* buffer, uint8_t bufferSize, uint8_t retries, uint8_t retryWaitTime) { bool RFM69::sendWithRetry(uint16_t toAddress, const void* buffer, uint8_t bufferSize, uint8_t retries, uint8_t retryWaitTime) {
uint32_t sentTime; uint32_t sentTime;
for (uint8_t i = 0; i <= retries; i++) for (uint8_t i = 0; i <= retries; i++) {
{
send(toAddress, buffer, bufferSize, true); send(toAddress, buffer, bufferSize, true);
sentTime = millis(); sentTime = millis();
while (millis() - sentTime < retryWaitTime) while (millis() - sentTime < retryWaitTime) {
{
if (ACKReceived(toAddress)) return true; if (ACKReceived(toAddress)) return true;
} }
} }
@ -371,8 +356,7 @@ void RFM69::sendACK(const void* buffer, uint8_t bufferSize) {
} }
// internal function // internal function
void RFM69::sendFrame(uint16_t toAddress, const void* buffer, uint8_t bufferSize, bool requestACK, bool sendACK) void RFM69::sendFrame(uint16_t toAddress, const void* buffer, uint8_t bufferSize, bool requestACK, bool sendACK) {
{
//NOTE: overridden in RFM69_ATC! //NOTE: overridden in RFM69_ATC!
setMode(RF69_MODE_STANDBY); // turn off receiver to prevent reception while filling fifo setMode(RF69_MODE_STANDBY); // turn off receiver to prevent reception while filling fifo
while ((readReg(REG_IRQFLAGS1) & RF_IRQFLAGS1_MODEREADY) == 0x00); // wait for ModeReady while ((readReg(REG_IRQFLAGS1) & RF_IRQFLAGS1_MODEREADY) == 0x00); // wait for ModeReady
@ -411,8 +395,7 @@ void RFM69::sendFrame(uint16_t toAddress, const void* buffer, uint8_t bufferSize
// internal function - interrupt gets called when a packet is received // internal function - interrupt gets called when a packet is received
void RFM69::interruptHandler() { void RFM69::interruptHandler() {
if (_mode == RF69_MODE_RX && (readReg(REG_IRQFLAGS2) & RF_IRQFLAGS2_PAYLOADREADY)) if (_mode == RF69_MODE_RX && (readReg(REG_IRQFLAGS2) & RF_IRQFLAGS2_PAYLOADREADY)) {
{
setMode(RF69_MODE_STANDBY); setMode(RF69_MODE_STANDBY);
select(); select();
_spi->transfer(REG_FIFO & 0x7F); _spi->transfer(REG_FIFO & 0x7F);
@ -480,13 +463,10 @@ bool RFM69::receiveDone() {
_haveData = false; _haveData = false;
interruptHandler(); interruptHandler();
} }
if (_mode == RF69_MODE_RX && PAYLOADLEN > 0) if (_mode == RF69_MODE_RX && PAYLOADLEN > 0) {
{
setMode(RF69_MODE_STANDBY); // enables interrupts setMode(RF69_MODE_STANDBY); // enables interrupts
return true; return true;
} } else if (_mode == RF69_MODE_RX) { // already in RX no payload yet
else if (_mode == RF69_MODE_RX) // already in RX no payload yet
{
return false; return false;
} }
receiveBegin(); receiveBegin();
@ -502,8 +482,7 @@ void RFM69::encrypt(const char* key) {
#endif #endif
setMode(RF69_MODE_STANDBY); setMode(RF69_MODE_STANDBY);
uint8_t validKey = key != 0 && strlen(key)!=0; uint8_t validKey = key != 0 && strlen(key)!=0;
if (validKey) if (validKey) {
{
#if defined(RF69_LISTENMODE_ENABLE) #if defined(RF69_LISTENMODE_ENABLE)
memcpy(_encryptKey, key, 16); memcpy(_encryptKey, key, 16);
#endif #endif
@ -519,8 +498,7 @@ void RFM69::encrypt(const char* key) {
// get the received signal strength indicator (RSSI) // get the received signal strength indicator (RSSI)
int16_t RFM69::readRSSI(bool forceTrigger) { int16_t RFM69::readRSSI(bool forceTrigger) {
int16_t rssi = 0; int16_t rssi = 0;
if (forceTrigger) if (forceTrigger) {
{
// RSSI trigger not needed if DAGC is in continuous mode // RSSI trigger not needed if DAGC is in continuous mode
writeReg(REG_RSSICONFIG, RF_RSSI_START); writeReg(REG_RSSICONFIG, RF_RSSI_START);
while ((readReg(REG_RSSICONFIG) & RF_RSSI_DONE) == 0x00); // wait for RSSI_Ready while ((readReg(REG_RSSICONFIG) & RF_RSSI_DONE) == 0x00); // wait for RSSI_Ready
@ -530,8 +508,7 @@ int16_t RFM69::readRSSI(bool forceTrigger) {
return rssi; return rssi;
} }
uint8_t RFM69::readReg(uint8_t addr) uint8_t RFM69::readReg(uint8_t addr) {
{
select(); select();
_spi->transfer(addr & 0x7F); _spi->transfer(addr & 0x7F);
uint8_t regval = _spi->transfer(0); uint8_t regval = _spi->transfer(0);
@ -539,8 +516,7 @@ uint8_t RFM69::readReg(uint8_t addr)
return regval; return regval;
} }
void RFM69::writeReg(uint8_t addr, uint8_t value) void RFM69::writeReg(uint8_t addr, uint8_t value) {
{
select(); select();
_spi->transfer(addr | 0x80); _spi->transfer(addr | 0x80);
_spi->transfer(value); _spi->transfer(value);
@ -625,10 +601,8 @@ bool RFM69::setIrq(uint8_t newIRQPin) {
// disconnect from existing IRQ pin // disconnect from existing IRQ pin
detachInterrupt( _interruptNum ); detachInterrupt( _interruptNum );
_interruptNum = _newInterruptNum; _interruptNum = _newInterruptNum;
attachInterrupt(_interruptNum, RFM69::isr0, RISING); attachInterrupt(_interruptNum, RFM69::isr0, RISING);
return true; return true;
} }
@ -647,8 +621,7 @@ void SerialPrint_P(PGM_P str, void (*f)(uint8_t) = SerialWrite ) {
} }
#endif #endif
void RFM69::readAllRegs() void RFM69::readAllRegs() {
{
uint8_t regVal; uint8_t regVal;
#if REGISTER_DETAIL #if REGISTER_DETAIL
@ -662,8 +635,7 @@ void RFM69::readAllRegs()
#endif #endif
Serial.println("Address - HEX - BIN"); Serial.println("Address - HEX - BIN");
for (uint8_t regAddr = 1; regAddr <= 0x4F; regAddr++) for (uint8_t regAddr = 1; regAddr <= 0x4F; regAddr++) {
{
select(); select();
_spi->transfer(regAddr & 0x7F); // send address + r/w bit _spi->transfer(regAddr & 0x7F); // send address + r/w bit
regVal = _spi->transfer(0); regVal = _spi->transfer(0);
@ -676,8 +648,7 @@ void RFM69::readAllRegs()
Serial.println(regVal,BIN); Serial.println(regVal,BIN);
#if REGISTER_DETAIL #if REGISTER_DETAIL
switch ( regAddr ) switch ( regAddr ){
{
case 0x1 : { case 0x1 : {
SerialPrint("Controls the automatic Sequencer ( see section 4.2 )\nSequencerOff : "); SerialPrint("Controls the automatic Sequencer ( see section 4.2 )\nSequencerOff : ");
if (0x80 & regVal) { if (0x80 & regVal) {
@ -719,7 +690,6 @@ void RFM69::readAllRegs()
} }
case 0x2 : { case 0x2 : {
SerialPrint("Data Processing mode:\nDataMode : "); SerialPrint("Data Processing mode:\nDataMode : ");
capVal = (regVal >> 5) & 0x3; capVal = (regVal >> 5) & 0x3;
if (capVal == 0b00) { if (capVal == 0b00) {
@ -901,7 +871,6 @@ void RFM69::readAllRegs()
SerialPrint("11 -> Reserved\n"); SerialPrint("11 -> Reserved\n");
} }
SerialPrint("\n"); SerialPrint("\n");
break; break;
} }
@ -940,16 +909,14 @@ void RFM69::readAllRegsCompact() {
} }
} }
uint8_t RFM69::readTemperature(uint8_t calFactor) // returns centigrade uint8_t RFM69::readTemperature(uint8_t calFactor) { // returns centigrade
{
setMode(RF69_MODE_STANDBY); setMode(RF69_MODE_STANDBY);
writeReg(REG_TEMP1, RF_TEMP1_MEAS_START); writeReg(REG_TEMP1, RF_TEMP1_MEAS_START);
while ((readReg(REG_TEMP1) & RF_TEMP1_MEAS_RUNNING)); while ((readReg(REG_TEMP1) & RF_TEMP1_MEAS_RUNNING));
return ~readReg(REG_TEMP2) + COURSE_TEMP_COEF + calFactor; // 'complement' corrects the slope, rising temp = rising val return ~readReg(REG_TEMP2) + COURSE_TEMP_COEF + calFactor; // 'complement' corrects the slope, rising temp = rising val
} // COURSE_TEMP_COEF puts reading in the ballpark, user can add additional correction } // COURSE_TEMP_COEF puts reading in the ballpark, user can add additional correction
void RFM69::rcCalibration() void RFM69::rcCalibration() {
{
writeReg(REG_OSC1, RF_OSC1_RCCAL_START); writeReg(REG_OSC1, RF_OSC1_RCCAL_START);
while ((readReg(REG_OSC1) & RF_OSC1_RCCAL_DONE) == 0x00); while ((readReg(REG_OSC1) & RF_OSC1_RCCAL_DONE) == 0x00);
} }
@ -991,8 +958,7 @@ uint8_t RFM69::setLNA(uint8_t newReg) {
} }
// ListenMode sleep/timer - see ListenModeSleep example for proper usage! // ListenMode sleep/timer - see ListenModeSleep example for proper usage!
void RFM69::listenModeSleep(uint16_t millisInterval) void RFM69::listenModeSleep(uint16_t millisInterval) {
{
setMode( RF69_MODE_STANDBY ); setMode( RF69_MODE_STANDBY );
while ((readReg(REG_IRQFLAGS1) & RF_IRQFLAGS1_MODEREADY) == 0x00); // wait for ModeReady while ((readReg(REG_IRQFLAGS1) & RF_IRQFLAGS1_MODEREADY) == 0x00); // wait for ModeReady
@ -1012,12 +978,10 @@ void RFM69::listenModeSleep(uint16_t millisInterval)
if( microInterval > 255 * 4100L ) { if( microInterval > 255 * 4100L ) {
idleResol = RF_LISTEN1_RESOL_IDLE_262000; idleResol = RF_LISTEN1_RESOL_IDLE_262000;
divisor = 262000; divisor = 262000;
} } else if( microInterval > 255 * 64L ) {
else if( microInterval > 255 * 64L ) {
idleResol = RF_LISTEN1_RESOL_IDLE_4100; idleResol = RF_LISTEN1_RESOL_IDLE_4100;
divisor = 4100; divisor = 4100;
} } else {
else {
idleResol = RF_LISTEN1_RESOL_IDLE_64; idleResol = RF_LISTEN1_RESOL_IDLE_64;
divisor = 64; divisor = 64;
} }
@ -1029,17 +993,14 @@ void RFM69::listenModeSleep(uint16_t millisInterval)
writeReg( REG_RXTIMEOUT2, 1 ); writeReg( REG_RXTIMEOUT2, 1 );
writeReg( REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_STANDBY ); writeReg( REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_STANDBY );
writeReg( REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_STANDBY | RF_OPMODE_LISTEN_ON ); writeReg( REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_STANDBY | RF_OPMODE_LISTEN_ON );
attachInterrupt( _interruptNum, delayIrq, RISING); attachInterrupt( _interruptNum, delayIrq, RISING);
//must call sleep + interrupt handler 3 times here, then endListenModeSleep() - see ListenModeSleep example! //must call sleep + interrupt handler 3 times here, then endListenModeSleep() - see ListenModeSleep example!
} }
//============================================================================= //=============================================================================
// endListenModeSleep() - called by listenModeSleep() // endListenModeSleep() - called by listenModeSleep()
//============================================================================= //=============================================================================
void RFM69::endListenModeSleep() void RFM69::endListenModeSleep() {
{
detachInterrupt( _interruptNum ); detachInterrupt( _interruptNum );
writeReg( REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_LISTENABORT | RF_OPMODE_STANDBY ); writeReg( REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_LISTENABORT | RF_OPMODE_STANDBY );
writeReg( REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_STANDBY ); writeReg( REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_STANDBY );
@ -1063,8 +1024,7 @@ volatile uint16_t RFM69::RF69_LISTEN_BURST_REMAINING_MS = 0;
//============================================================================= //=============================================================================
// reinitRadio() - use base class initialization with saved values // reinitRadio() - use base class initialization with saved values
//============================================================================= //=============================================================================
bool RFM69::reinitRadio() bool RFM69::reinitRadio() {
{
bool haveEncryptKey = _haveEncryptKey; bool haveEncryptKey = _haveEncryptKey;
if (!initialize(_freqBand, _address, _networkID)) return false; if (!initialize(_freqBand, _address, _networkID)) return false;
if (haveEncryptKey) encrypt(_encryptKey); // Restore the encryption key if necessary if (haveEncryptKey) encrypt(_encryptKey); // Restore the encryption key if necessary
@ -1072,8 +1032,7 @@ bool RFM69::reinitRadio()
return true; return true;
} }
static uint32_t getUsForResolution(uint8_t resolution) static uint32_t getUsForResolution(uint8_t resolution) {
{
switch (resolution) { switch (resolution) {
case RF_LISTEN1_RESOL_RX_64: case RF_LISTEN1_RESOL_RX_64:
case RF_LISTEN1_RESOL_IDLE_64: case RF_LISTEN1_RESOL_IDLE_64:
@ -1090,8 +1049,7 @@ static uint32_t getUsForResolution(uint8_t resolution)
} }
} }
static uint32_t getCoefForResolution(uint8_t resolution, uint32_t duration) static uint32_t getCoefForResolution(uint8_t resolution, uint32_t duration) {
{
uint32_t resolDuration = getUsForResolution(resolution); uint32_t resolDuration = getUsForResolution(resolution);
uint32_t result = duration / resolDuration; uint32_t result = duration / resolDuration;
@ -1102,8 +1060,7 @@ static uint32_t getCoefForResolution(uint8_t resolution, uint32_t duration)
return result; return result;
} }
static bool chooseResolutionAndCoef(uint8_t *resolutions, uint32_t duration, uint8_t& resolOut, uint8_t& coefOut) static bool chooseResolutionAndCoef(uint8_t *resolutions, uint32_t duration, uint8_t& resolOut, uint8_t& coefOut) {
{
for (int i = 0; resolutions[i]; i++) { for (int i = 0; resolutions[i]; i++) {
uint32_t coef = getCoefForResolution(resolutions[i], duration); uint32_t coef = getCoefForResolution(resolutions[i], duration);
if (coef <= 255) { if (coef <= 255) {
@ -1117,8 +1074,7 @@ static bool chooseResolutionAndCoef(uint8_t *resolutions, uint32_t duration, uin
return false; return false;
} }
bool RFM69::listenModeSetDurations(uint32_t& rxDuration, uint32_t& idleDuration) bool RFM69::listenModeSetDurations(uint32_t& rxDuration, uint32_t& idleDuration) {
{
uint8_t rxResolutions[] = { RF_LISTEN1_RESOL_RX_64, RF_LISTEN1_RESOL_RX_4100, RF_LISTEN1_RESOL_RX_262000, 0 }; uint8_t rxResolutions[] = { RF_LISTEN1_RESOL_RX_64, RF_LISTEN1_RESOL_RX_4100, RF_LISTEN1_RESOL_RX_262000, 0 };
uint8_t idleResolutions[] = { RF_LISTEN1_RESOL_IDLE_64, RF_LISTEN1_RESOL_IDLE_4100, RF_LISTEN1_RESOL_IDLE_262000, 0 }; uint8_t idleResolutions[] = { RF_LISTEN1_RESOL_IDLE_64, RF_LISTEN1_RESOL_IDLE_4100, RF_LISTEN1_RESOL_IDLE_262000, 0 };
@ -1135,14 +1091,12 @@ bool RFM69::listenModeSetDurations(uint32_t& rxDuration, uint32_t& idleDuration)
return true; return true;
} }
void RFM69::listenModeGetDurations(uint32_t &rxDuration, uint32_t &idleDuration) void RFM69::listenModeGetDurations(uint32_t &rxDuration, uint32_t &idleDuration) {
{
rxDuration = getUsForResolution(_rxListenResolution) * _rxListenCoef; rxDuration = getUsForResolution(_rxListenResolution) * _rxListenCoef;
idleDuration = getUsForResolution(_idleListenResolution) * _idleListenCoef; idleDuration = getUsForResolution(_idleListenResolution) * _idleListenCoef;
} }
void RFM69::listenModeReset(void) void RFM69::listenModeReset(void) {
{
DATALEN = 0; DATALEN = 0;
SENDERID = 0; SENDERID = 0;
TARGETID = 0; TARGETID = 0;
@ -1160,16 +1114,14 @@ ISR_PREFIX void RFM69::listenModeIrq() { selfPointer->listenModeInterruptHandler
//============================================================================= //=============================================================================
// listenModeInterruptHandler() - only called by listen irq handler // listenModeInterruptHandler() - only called by listen irq handler
//============================================================================= //=============================================================================
void RFM69::listenModeInterruptHandler(void) void RFM69::listenModeInterruptHandler(void) {
{
if (DATALEN != 0) return; if (DATALEN != 0) return;
listenModeReset(); listenModeReset();
noInterrupts(); noInterrupts();
select(); select();
union // union to simplify addressing of long and short parts of time offset union { // union to simplify addressing of long and short parts of time offset
{
uint32_t l; uint32_t l;
uint8_t b[4]; uint8_t b[4];
} burstRemaining; } burstRemaining;
@ -1208,8 +1160,7 @@ out:
//============================================================================= //=============================================================================
// listenModeStart() - switch radio to Listen Mode in prep for sleep until burst // listenModeStart() - switch radio to Listen Mode in prep for sleep until burst
//============================================================================= //=============================================================================
void RFM69::listenModeStart(void) void RFM69::listenModeStart(void) {
{
//pRadio = this; //pRadio = this;
while (readReg(REG_IRQFLAGS2) & RF_IRQFLAGS2_PACKETSENT == 0x00); // wait for ModeReady while (readReg(REG_IRQFLAGS2) & RF_IRQFLAGS2_PACKETSENT == 0x00); // wait for ModeReady
listenModeReset(); listenModeReset();
@ -1239,8 +1190,7 @@ void RFM69::listenModeStart(void)
//============================================================================= //=============================================================================
// listenModeEnd() - exit listen mode and reinit the radio // listenModeEnd() - exit listen mode and reinit the radio
//============================================================================= //=============================================================================
void RFM69::listenModeEnd(void) void RFM69::listenModeEnd(void) {
{
detachInterrupt(_interruptNum); detachInterrupt(_interruptNum);
writeReg(REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_LISTENABORT | RF_OPMODE_STANDBY); writeReg(REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_LISTENABORT | RF_OPMODE_STANDBY);
writeReg(REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_STANDBY); writeReg(REG_OPMODE, RF_OPMODE_SEQUENCER_ON | RF_OPMODE_STANDBY);
@ -1251,8 +1201,7 @@ void RFM69::listenModeEnd(void)
reinitRadio(); reinitRadio();
} }
void RFM69::listenModeApplyHighSpeedSettings() void RFM69::listenModeApplyHighSpeedSettings() {
{
if (!_isHighSpeed) return; if (!_isHighSpeed) return;
writeReg(REG_BITRATEMSB, RF_BITRATEMSB_200000); writeReg(REG_BITRATEMSB, RF_BITRATEMSB_200000);
writeReg(REG_BITRATELSB, RF_BITRATELSB_200000); writeReg(REG_BITRATELSB, RF_BITRATELSB_200000);
@ -1267,8 +1216,7 @@ void RFM69::listenModeApplyHighSpeedSettings()
//============================================================================= //=============================================================================
// sendBurst() - send a burst of packets to a sleeping listening node (or all) // sendBurst() - send a burst of packets to a sleeping listening node (or all)
//============================================================================= //=============================================================================
void RFM69::listenModeSendBurst( uint8_t targetNode, const void* buffer, uint8_t size ) void RFM69::listenModeSendBurst(uint8_t targetNode, const void* buffer, uint8_t size) {
{
detachInterrupt(_interruptNum); detachInterrupt(_interruptNum);
setMode(RF69_MODE_STANDBY); setMode(RF69_MODE_STANDBY);
writeReg(REG_PACKETCONFIG1, RF_PACKET1_FORMAT_VARIABLE | RF_PACKET1_DCFREE_WHITENING | RF_PACKET1_CRC_ON | RF_PACKET1_CRCAUTOCLEAR_ON ); writeReg(REG_PACKETCONFIG1, RF_PACKET1_FORMAT_VARIABLE | RF_PACKET1_DCFREE_WHITENING | RF_PACKET1_CRC_ON | RF_PACKET1_CRCAUTOCLEAR_ON );
@ -1279,8 +1227,7 @@ void RFM69::listenModeSendBurst( uint8_t targetNode, const void* buffer, uint8_t
writeReg(REG_FRFMSB, readReg(REG_FRFMSB) + 1); writeReg(REG_FRFMSB, readReg(REG_FRFMSB) + 1);
writeReg(REG_FRFLSB, readReg(REG_FRFLSB)); // MUST write to LSB to affect change! writeReg(REG_FRFLSB, readReg(REG_FRFLSB)); // MUST write to LSB to affect change!
union // union to simplify addressing of long and short parts of time offset union { // union to simplify addressing of long and short parts of time offset
{
int32_t l; int32_t l;
uint8_t b[4]; uint8_t b[4];
} timeRemaining; } timeRemaining;