[LR11x0] Use array as LR-FHSS sync word

pull/1302/head
jgromes 2024-10-28 18:52:07 +00:00
rodzic 15a751a543
commit 8f3a5c7430
3 zmienionych plików z 32 dodań i 25 usunięć

Wyświetl plik

@ -62,7 +62,8 @@ void setup() {
3, // header count 3, // header count
0x13A); // hopping sequence seed 0x13A); // hopping sequence seed
state = radio.setOutputPower(10.0); state = radio.setOutputPower(10.0);
state = radio.setSyncWord(0x12345678); uint8_t syncWord[] = {0x01, 0x23, 0x45, 0x67};
state = radio.setSyncWord(syncWord, 4);
if (state != RADIOLIB_ERR_NONE) { if (state != RADIOLIB_ERR_NONE) {
Serial.print(F("Unable to set configuration, code ")); Serial.print(F("Unable to set configuration, code "));
Serial.println(state); Serial.println(state);

Wyświetl plik

@ -110,7 +110,8 @@ int16_t LR11x0::beginLRFHSS(uint8_t bw, uint8_t cr, bool narrowGrid, float tcxoV
state = setLrFhssConfig(bw, cr); state = setLrFhssConfig(bw, cr);
RADIOLIB_ASSERT(state); RADIOLIB_ASSERT(state);
state = setSyncWord(0x12AD101B); uint8_t syncWord[] = { 0x12, 0xAD, 0x10, 0x1B };
state = setSyncWord(syncWord, 4);
RADIOLIB_ASSERT(state); RADIOLIB_ASSERT(state);
state = setRegulatorLDO(); state = setRegulatorLDO();
@ -758,20 +759,16 @@ int16_t LR11x0::setCodingRate(uint8_t cr, bool longInterleave) {
return(setModulationParamsLoRa(this->spreadingFactor, this->bandwidth, this->codingRate, this->ldrOptimize)); return(setModulationParamsLoRa(this->spreadingFactor, this->bandwidth, this->codingRate, this->ldrOptimize));
} }
int16_t LR11x0::setSyncWord(uint32_t syncWord) { int16_t LR11x0::setSyncWord(uint8_t syncWord) {
// check active modem // check active modem
uint8_t type = RADIOLIB_LR11X0_PACKET_TYPE_NONE; uint8_t type = RADIOLIB_LR11X0_PACKET_TYPE_NONE;
int16_t state = getPacketType(&type); int16_t state = getPacketType(&type);
RADIOLIB_ASSERT(state); RADIOLIB_ASSERT(state);
if(type == RADIOLIB_LR11X0_PACKET_TYPE_LORA) { if(type != RADIOLIB_LR11X0_PACKET_TYPE_LORA) {
return(setLoRaSyncWord(syncWord & 0xFF)); return(RADIOLIB_ERR_WRONG_MODEM);
} else if(type == RADIOLIB_LR11X0_PACKET_TYPE_LR_FHSS) {
return(lrFhssSetSyncWord(syncWord));
} }
return(RADIOLIB_ERR_WRONG_MODEM); return(setLoRaSyncWord(syncWord));
} }
int16_t LR11x0::setBitRate(float br) { int16_t LR11x0::setBitRate(float br) {
@ -885,27 +882,36 @@ int16_t LR11x0::setSyncWord(uint8_t* syncWord, size_t len) {
uint8_t type = RADIOLIB_LR11X0_PACKET_TYPE_NONE; uint8_t type = RADIOLIB_LR11X0_PACKET_TYPE_NONE;
int16_t state = getPacketType(&type); int16_t state = getPacketType(&type);
RADIOLIB_ASSERT(state); RADIOLIB_ASSERT(state);
if(type == RADIOLIB_LR11X0_PACKET_TYPE_LORA) { if(type == RADIOLIB_LR11X0_PACKET_TYPE_GFSK) {
// update sync word length
this->syncWordLength = len*8;
state = setPacketParamsGFSK(this->preambleLengthGFSK, this->preambleDetLength, this->syncWordLength, this->addrComp, this->packetType, RADIOLIB_LR11X0_MAX_PACKET_LENGTH, this->crcTypeGFSK, this->whitening);
RADIOLIB_ASSERT(state);
// sync word is passed most-significant byte first
uint8_t fullSyncWord[RADIOLIB_LR11X0_GFSK_SYNC_WORD_LEN] = { 0 };
memcpy(fullSyncWord, syncWord, len);
return(setGfskSyncWord(fullSyncWord));
} else if(type == RADIOLIB_LR11X0_PACKET_TYPE_LORA) {
// with length set to 1 and LoRa modem active, assume it is the LoRa sync word // with length set to 1 and LoRa modem active, assume it is the LoRa sync word
if(len > 1) { if(len > 1) {
return(RADIOLIB_ERR_INVALID_SYNC_WORD); return(RADIOLIB_ERR_INVALID_SYNC_WORD);
} }
return(setSyncWord(syncWord[0])); return(setSyncWord(syncWord[0]));
} else if(type != RADIOLIB_LR11X0_PACKET_TYPE_GFSK) { } else if(type == RADIOLIB_LR11X0_PACKET_TYPE_LR_FHSS) {
return(RADIOLIB_ERR_WRONG_MODEM); // with length set to 4 and LR-FHSS modem active, assume it is the LR-FHSS sync word
if(len != sizeof(uint32_t)) {
return(RADIOLIB_ERR_INVALID_SYNC_WORD);
}
uint32_t sync = 0;
memcpy(&sync, syncWord, sizeof(uint32_t));
return(lrFhssSetSyncWord(sync));
} }
// update sync word length return(RADIOLIB_ERR_WRONG_MODEM);
this->syncWordLength = len*8;
state = setPacketParamsGFSK(this->preambleLengthGFSK, this->preambleDetLength, this->syncWordLength, this->addrComp, this->packetType, RADIOLIB_LR11X0_MAX_PACKET_LENGTH, this->crcTypeGFSK, this->whitening);
RADIOLIB_ASSERT(state);
// sync word is passed most-significant byte first
uint8_t fullSyncWord[RADIOLIB_LR11X0_GFSK_SYNC_WORD_LEN] = { 0 };
memcpy(fullSyncWord, syncWord, len);
return(setGfskSyncWord(fullSyncWord));
} }
int16_t LR11x0::setSyncBits(uint8_t *syncWord, uint8_t bitsLen) { int16_t LR11x0::setSyncBits(uint8_t *syncWord, uint8_t bitsLen) {

Wyświetl plik

@ -1176,11 +1176,11 @@ class LR11x0: public PhysicalLayer {
int16_t setCodingRate(uint8_t cr, bool longInterleave = false); int16_t setCodingRate(uint8_t cr, bool longInterleave = false);
/*! /*!
\brief Sets LoRa or LR-FHSS sync word. \brief Sets LoRa sync word.
\param syncWord LoRa or LR-FHSS sync word to be set. For LoRa, only 8 least significant bits will be used \param syncWord LoRa sync word to be set.
\returns \ref status_codes \returns \ref status_codes
*/ */
int16_t setSyncWord(uint32_t syncWord); int16_t setSyncWord(uint8_t syncWord);
/*! /*!
\brief Sets GFSK bit rate. Allowed values range from 0.6 to 300.0 kbps. \brief Sets GFSK bit rate. Allowed values range from 0.6 to 300.0 kbps.