From 8372970ad4f2cfd15b8485e37a1178331ad09b19 Mon Sep 17 00:00:00 2001 From: Matthijs Kooijman Date: Thu, 15 Dec 2022 08:53:55 +0100 Subject: [PATCH 1/4] Fix comments in LoRaMacCallback_t It seems the comment for GetDevAddress was copied from GetUniqueId, but not changend sufficiently to be correct. --- Middlewares/Third_Party/LoRaWAN/Mac/LoRaMacInterfaces.h | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Middlewares/Third_Party/LoRaWAN/Mac/LoRaMacInterfaces.h b/Middlewares/Third_Party/LoRaWAN/Mac/LoRaMacInterfaces.h index 109f144a..ee0cf448 100644 --- a/Middlewares/Third_Party/LoRaWAN/Mac/LoRaMacInterfaces.h +++ b/Middlewares/Third_Party/LoRaWAN/Mac/LoRaMacInterfaces.h @@ -3131,15 +3131,15 @@ typedef struct sLoRaMacCallback */ int16_t ( *GetTemperatureLevel )( void ); /*! - * \brief Get the board 64 bits unique ID + * \brief Get the board 64 bits unique ID (for OTAA) * * \param [out] id unique */ void ( *GetUniqueId )(uint8_t *id); /*! - * \brief Get the 64 bits unique Device address + * \brief Get the 32 bits Device address (for ABP) * - * \param [out] id unique + * \param [out] id devaddr */ void ( *GetDevAddress )(uint32_t *devAddr); /*! From 1c17e31589532f453ef3c1f5cbe98b122bb2fc52 Mon Sep 17 00:00:00 2001 From: Matthijs Kooijman Date: Tue, 27 Sep 2022 09:27:27 +0200 Subject: [PATCH 2/4] Fix printf format warnings These warnings are caused because frequencies are stored as `uint32_t`, which is `unsigned long`, while the printf format expects `int`. In practice, this does not actually cause problems, since on STM32 gcc `long` and `int` are both 32-bits and frequencies are never large enough to cause signed vs unsigned ambiguity. Since printf has no format specifiers for e.g. uint32_t (libc does have some macros for this, but those really hurt readability), this is tricky to fix in a portable way (other architectures or compilers might have `uint32_t` equal to `unsigned int` instead of `unsigned long`), this fix just casts the frequency to `unsigned` before passing it to printf (and for good measure, also convert the specifier from `%d` to `%u`). This does mean this printing will break if `int` is not at least 32-bits (e.g. on AVR), but given the scope of this library, that should be acceptable. --- Middlewares/Third_Party/LoRaWAN/Mac/Region/RegionCommon.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Middlewares/Third_Party/LoRaWAN/Mac/Region/RegionCommon.c b/Middlewares/Third_Party/LoRaWAN/Mac/Region/RegionCommon.c index 2723e09f..ab90eac9 100644 --- a/Middlewares/Third_Party/LoRaWAN/Mac/Region/RegionCommon.c +++ b/Middlewares/Third_Party/LoRaWAN/Mac/Region/RegionCommon.c @@ -562,7 +562,7 @@ void RegionCommonRxBeaconSetup( RegionCommonRxBeaconSetupParams_t* rxBeaconSetup 1, 0, 10, rxBeaconSetupParams->SymbolTimeout, true, rxBeaconSetupParams->BeaconSize, false, 0, 0, false, rxContinuous ); Radio.Rx( rxBeaconSetupParams->RxTime ); - MW_LOG(TS_ON, VLEVEL_M, "RX_BC on freq %d Hz at DR %d\r\n", rxBeaconSetupParams->Frequency, rxBeaconSetupParams->BeaconDatarate ); + MW_LOG(TS_ON, VLEVEL_M, "RX_BC on freq %u Hz at DR %d\r\n", (unsigned)rxBeaconSetupParams->Frequency, rxBeaconSetupParams->BeaconDatarate ); } void RegionCommonCountNbOfEnabledChannels( RegionCommonCountNbOfEnabledChannelsParams_t* countNbOfEnabledChannelsParams, @@ -696,15 +696,15 @@ void RegionCommonRxConfigPrint(LoRaMacRxSlot_t rxSlot, uint32_t frequency, int8_ { if ( rxSlot < RX_SLOT_NONE ) { - MW_LOG(TS_ON, VLEVEL_M, "RX_%s on freq %d Hz at DR %d\r\n", EventRXSlotStrings[rxSlot], frequency, dr ); + MW_LOG(TS_ON, VLEVEL_M, "RX_%s on freq %u Hz at DR %d\r\n", EventRXSlotStrings[rxSlot], (unsigned)frequency, dr ); } else { - MW_LOG(TS_ON, VLEVEL_M, "RX on freq %d Hz at DR %d\r\n", frequency, dr ); + MW_LOG(TS_ON, VLEVEL_M, "RX on freq %u Hz at DR %d\r\n", (unsigned)frequency, dr ); } } void RegionCommonTxConfigPrint(uint32_t frequency, int8_t dr) { - MW_LOG(TS_ON, VLEVEL_M, "TX on freq %d Hz at DR %d\r\n", frequency, dr ); + MW_LOG(TS_ON, VLEVEL_M, "TX on freq %u Hz at DR %d\r\n", (unsigned)frequency, dr ); } From 17482cea0d95bfa433525040fe934fea303764ab Mon Sep 17 00:00:00 2001 From: Matthijs Kooijman Date: Tue, 13 Sep 2022 12:12:16 +0200 Subject: [PATCH 3/4] Add additional debug output This adds some more details about RX and TX bytes and TX config. There is also some code for RX config, but to minimize the impact on RX timing, that is commented out. --- Middlewares/Third_Party/LoRaWAN/Mac/LoRaMac.c | 5 ++++ .../SubGHz_Phy/stm32_radio_driver/radio.c | 26 +++++++++++++++++++ 2 files changed, 31 insertions(+) diff --git a/Middlewares/Third_Party/LoRaWAN/Mac/LoRaMac.c b/Middlewares/Third_Party/LoRaWAN/Mac/LoRaMac.c index 1d0631f7..371387e8 100644 --- a/Middlewares/Third_Party/LoRaWAN/Mac/LoRaMac.c +++ b/Middlewares/Third_Party/LoRaWAN/Mac/LoRaMac.c @@ -1127,6 +1127,11 @@ static void ProcessRadioRxDone( void ) #endif /* LORAMAC_VERSION */ Mlme_t joinType = MLME_JOIN; + MW_LOG( TS_ON, VLEVEL_M, "RX: "); + for (size_t i = 0; i < RxDoneParams.Size; ++i) + MW_LOG( TS_ON, VLEVEL_M, "%02x", RxDoneParams.Payload[i]); + MW_LOG( TS_ON, VLEVEL_M, "\r\n"); + #if (defined( LORAMAC_VERSION ) && (( LORAMAC_VERSION == 0x01000400 ) || ( LORAMAC_VERSION == 0x01010100 ))) LoRaMacRadioEvents.Events.RxProcessPending = 0; #endif /* LORAMAC_VERSION */ diff --git a/Middlewares/Third_Party/SubGHz_Phy/stm32_radio_driver/radio.c b/Middlewares/Third_Party/SubGHz_Phy/stm32_radio_driver/radio.c index 8544ebd1..268591cd 100644 --- a/Middlewares/Third_Party/SubGHz_Phy/stm32_radio_driver/radio.c +++ b/Middlewares/Third_Party/SubGHz_Phy/stm32_radio_driver/radio.c @@ -868,6 +868,18 @@ static void RadioSetRxConfig( RadioModems_t modem, uint32_t bandwidth, #if (RADIO_SIGFOX_ENABLE == 1) uint8_t modReg; #endif + //Disabled, too much influence on RX timing + /* + MW_LOG( TS_ON, VLEVEL_M, + "Setting RX Config: modem=%s, bandwidth=%u, datarate=%u, coderate=%u bandwithAfc=%u, preambleLen=%u, symbTimeout=%u, fixLen=%u, payloadLen=%u, crcOn=%u, freqHopOn=%u, hopPeriod=%u, iqInverted=%u, rxContinuous=%u\r\n", + modem == MODEM_FSK ? "MODEM_FSK" : (modem == MODEM_LORA ? "MODEM_LORA" : "?"), + (unsigned)bandwidth, (unsigned)datarate, (unsigned)coderate, + (unsigned)bandwidthAfc, (unsigned)preambleLen, + (unsigned)symbTimeout, (unsigned)fixLen, (unsigned)payloadLen, + (unsigned)crcOn, (unsigned)freqHopOn, (unsigned)hopPeriod, + (unsigned)iqInverted, (unsigned)rxContinuous + ); + */ SubgRf.RxContinuous = rxContinuous; RFW_DeInit(); if( rxContinuous == true ) @@ -1057,6 +1069,15 @@ static void RadioSetTxConfig( RadioModems_t modem, int8_t power, uint32_t fdev, SubgRf.lr_fhss.is_lr_fhss_on = false; #endif /* RADIO_LR_FHSS_IS_ON == 1 */ RFW_DeInit(); + MW_LOG( TS_ON, VLEVEL_M, + "Setting TX Config: modem=%s, power=%u, fdev=%u, bandwidth=%u, datarate=%u, coderate=%u preambleLen=%u, fixLen=%u, crcOn=%u, freqHopOn=%u, hopPeriod=%u, iqInverted=%u, timeout=%u\r\n", + modem == MODEM_FSK ? "MODEM_FSK" : (modem == MODEM_LORA ? "MODEM_LORA" : "?"), + (int)power, (unsigned)fdev, (unsigned)bandwidth, + (unsigned)datarate, (unsigned)coderate, (unsigned)preambleLen, + (unsigned)fixLen, (unsigned)crcOn, (unsigned)freqHopOn, + (unsigned)hopPeriod, (unsigned)iqInverted, (unsigned)timeout + ); + switch( modem ) { case MODEM_FSK: @@ -1315,6 +1336,11 @@ static radio_status_t RadioSend( uint8_t *buffer, uint8_t size ) IRQ_RADIO_NONE, IRQ_RADIO_NONE ); + MW_LOG( TS_ON, VLEVEL_M, "TX:"); + for (size_t i = 0; i < size; ++i) + MW_LOG( TS_ON, VLEVEL_M, " %02x", buffer[i]); + MW_LOG( TS_ON, VLEVEL_M, "\r\n"); + /* Set DBG pin */ DBG_GPIO_RADIO_TX( SET ); From 9735e00c0cd01a026efee98489dc946c2cba21b7 Mon Sep 17 00:00:00 2001 From: Matthijs Kooijman Date: Mon, 19 Dec 2022 13:00:25 +0100 Subject: [PATCH 4/4] Fix signed vs unsigned comparison warning --- .../Third_Party/SubGHz_Phy/stm32_radio_driver/lr_fhss_mac.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Middlewares/Third_Party/SubGHz_Phy/stm32_radio_driver/lr_fhss_mac.c b/Middlewares/Third_Party/SubGHz_Phy/stm32_radio_driver/lr_fhss_mac.c index c3fa28b8..e3d959dc 100644 --- a/Middlewares/Third_Party/SubGHz_Phy/stm32_radio_driver/lr_fhss_mac.c +++ b/Middlewares/Third_Party/SubGHz_Phy/stm32_radio_driver/lr_fhss_mac.c @@ -781,7 +781,7 @@ STATIC uint16_t lr_fhss_payload_interleaving( const uint8_t *data_in, uint16_t d lr_fhss_set_bit_in_byte_vector( data_out, 0 + out_row_index, 0 ); // guard bits lr_fhss_set_bit_in_byte_vector( data_out, 1 + out_row_index, 0 ); // guard bits - for( uint32_t j = 0; j < in_row_width; j++ ) + for( int32_t j = 0; j < in_row_width; j++ ) { lr_fhss_set_bit_in_byte_vector( data_out, j + 2 + out_row_index, lr_fhss_extract_bit_in_byte_vector( data_in, pos ) ); // guard bit