Skip to content

Commit

Permalink
[SX127x] Fixed order of ISR functions in examples
Browse files Browse the repository at this point in the history
  • Loading branch information
jgromes committed Nov 19, 2024
1 parent a579eed commit 17bcfcd
Show file tree
Hide file tree
Showing 5 changed files with 99 additions and 99 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,36 @@ SX1278 radio = new Module(10, 2, 9, 3);
Radio radio = new RadioModule();
*/

// flag to indicate that a preamble was not detected
volatile bool timeoutFlag = false;

// flag to indicate that a preamble was detected
volatile bool detectedFlag = false;

// this function is called when no preamble
// is detected within timeout period
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlagTimeout(void) {
// we timed out, set the flag
timeoutFlag = true;
}

// this function is called when LoRa preamble
// is detected within timeout period
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlagDetected(void) {
// we got a preamble, set the flag
detectedFlag = true;
}

void setup() {
// Serial port speed must be high enough for this example
Serial.begin(115200);
Expand Down Expand Up @@ -68,36 +98,6 @@ void setup() {
}
}

// flag to indicate that a preamble was not detected
volatile bool timeoutFlag = false;

// flag to indicate that a preamble was detected
volatile bool detectedFlag = false;

// this function is called when no preamble
// is detected within timeout period
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlagTimeout(void) {
// we timed out, set the flag
timeoutFlag = true;
}

// this function is called when LoRa preamble
// is detected within timeout period
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlagDetected(void) {
// we got a preamble, set the flag
detectedFlag = true;
}

void loop() {
// check if we need to restart channel activity detection
if(detectedFlag || timeoutFlag) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,39 @@ SX1278 radio = new Module(10, 2, 9, 3);
Radio radio = new RadioModule();
*/

// flag to indicate that a preamble was not detected
volatile bool timeoutFlag = false;

// flag to indicate that a preamble was detected
volatile bool detectedFlag = false;

// flag to indicate if we are currently receiving
bool receiving = false;

// this function is called when no preamble
// is detected within timeout period
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlagTimeout(void) {
// we timed out, set the flag
timeoutFlag = true;
}

// this function is called when LoRa preamble
// is detected within timeout period
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlagDetected(void) {
// we got a preamble, set the flag
detectedFlag = true;
}

void setup() {
// Serial port speed must be high enough for this example
Serial.begin(115200);
Expand Down Expand Up @@ -74,39 +107,6 @@ void setup() {
}
}

// flag to indicate that a preamble was not detected
volatile bool timeoutFlag = false;

// flag to indicate that a preamble was detected
volatile bool detectedFlag = false;

// flag to indicate if we are currently receiving
bool receiving = false;

// this function is called when no preamble
// is detected within timeout period
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlagTimeout(void) {
// we timed out, set the flag
timeoutFlag = true;
}

// this function is called when LoRa preamble
// is detected within timeout period
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlagDetected(void) {
// we got a preamble, set the flag
detectedFlag = true;
}

void loop() {
// check if we need to restart channel activity detection
if(detectedFlag || timeoutFlag) {
Expand Down
12 changes: 6 additions & 6 deletions examples/SX127x/SX127x_Receive_Direct/SX127x_Receive_Direct.ino
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,12 @@ const int pin = 5;
Radio radio = new RadioModule();
*/

// this function is called when a new bit is received
void readBit(void) {
// read the data bit
radio.readBit(pin);
}

void setup() {
Serial.begin(9600);

Expand Down Expand Up @@ -59,12 +65,6 @@ void setup() {
radio.receiveDirect();
}

// this function is called when a new bit is received
void readBit(void) {
// read the data bit
radio.readBit(pin);
}

void loop() {
// we expect the packet to contain the string "Hello World!",
// a length byte and 2 CRC bytes, that's 15 bytes in total
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,21 @@ SX1278 radio = new Module(10, 2, 9, 3);
Radio radio = new RadioModule();
*/

// flag to indicate that a packet was received
volatile bool receivedFlag = false;

// this function is called when a complete packet
// is received by the module
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlag(void) {
// we got a packet, set the flag
receivedFlag = true;
}

void setup() {
Serial.begin(9600);

Expand Down Expand Up @@ -78,21 +93,6 @@ void setup() {
// radio.scanChannel();
}

// flag to indicate that a packet was received
volatile bool receivedFlag = false;

// this function is called when a complete packet
// is received by the module
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlag(void) {
// we got a packet, set the flag
receivedFlag = true;
}

void loop() {
// check if the flag is set
if(receivedFlag) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,21 @@ Radio radio = new RadioModule();
// save transmission state between loops
int transmissionState = RADIOLIB_ERR_NONE;

// flag to indicate that a packet was sent
volatile bool transmittedFlag = false;

// this function is called when a complete packet
// is transmitted by the module
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlag(void) {
// we sent a packet, set the flag
transmittedFlag = true;
}

void setup() {
Serial.begin(9600);

Expand Down Expand Up @@ -71,21 +86,6 @@ void setup() {
*/
}

// flag to indicate that a packet was sent
volatile bool transmittedFlag = false;

// this function is called when a complete packet
// is transmitted by the module
// IMPORTANT: this function MUST be 'void' type
// and MUST NOT have any arguments!
#if defined(ESP8266) || defined(ESP32)
ICACHE_RAM_ATTR
#endif
void setFlag(void) {
// we sent a packet, set the flag
transmittedFlag = true;
}

// counter to keep track of transmitted packets
int count = 0;

Expand Down

0 comments on commit 17bcfcd

Please sign in to comment.