123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684 |
- #include <string.h>
- #include "platform.h"
- #if defined( USE_SX1276_RADIO )
- #include "radio.h"
- #include "sx1276-Hal.h"
- #include "sx1276.h"
- #include "sx1276-LoRaMisc.h"
- #include "sx1276-LoRa.h"
- #include "delay.h"
- #define RSSI_OFFSET_LF -164.0
- #define RSSI_OFFSET_HF -157.0
- const int32_t HoppingFrequencies[] =
- {
- 916500000,
- 923500000,
- 906500000,
- 917500000,
- 917500000,
- 909000000,
- 903000000,
- 916000000,
- 912500000,
- 926000000,
- 925000000,
- 909500000,
- 913000000,
- 918500000,
- 918500000,
- 902500000,
- 911500000,
- 926500000,
- 902500000,
- 922000000,
- 924000000,
- 903500000,
- 913000000,
- 922000000,
- 926000000,
- 910000000,
- 920000000,
- 922500000,
- 911000000,
- 922000000,
- 909500000,
- 926000000,
- 922000000,
- 918000000,
- 925500000,
- 908000000,
- 917500000,
- 926500000,
- 908500000,
- 916000000,
- 905500000,
- 916000000,
- 903000000,
- 905000000,
- 915000000,
- 913000000,
- 907000000,
- 910000000,
- 926500000,
- 925500000,
- 911000000,
- };
- tLoRaSettings LoRaSettings =
- {
- 470000000,
- 20,
- 9,
-
- 12,
- 2,
- true,
- false,
- 0,
- 0,
- 4,
- 1000,
- 1000,
- 4,
- };
- tSX1276LR* SX1276LR;
- static uint8_t RFBuffer[RF_BUFFER_SIZE];
- static uint8_t RFLRState = RFLR_STATE_IDLE;
- static uint16_t RxPacketSize = 0;
- static int8_t RxPacketSnrEstimate;
- static double RxPacketRssiValue;
- static uint8_t RxGain = 1;
- static uint32_t RxTimeoutTimer = 0;
- static uint32_t PacketTimeout;
- static uint16_t TxPacketSize = 0;
- void SX1276LoRaInit( void )
- {
- RFLRState = RFLR_STATE_IDLE;
- SX1276LoRaSetDefaults( );
-
- SX1276ReadBuffer( REG_LR_OPMODE, SX1276Regs + 1, 0x70 - 1 );
-
- SX1276LR->RegLna = RFLR_LNA_GAIN_G1;
- SX1276WriteBuffer( REG_LR_OPMODE, SX1276Regs + 1, 0x70 - 1 );
-
- SX1276LoRaSetRFFrequency( LoRaSettings.RFFrequency );
- SX1276LoRaSetSpreadingFactor( LoRaSettings.SpreadingFactor );
- SX1276LoRaSetErrorCoding( LoRaSettings.ErrorCoding );
- SX1276LoRaSetPacketCrcOn( LoRaSettings.CrcOn );
- SX1276LoRaSetSignalBandwidth( LoRaSettings.SignalBw );
- SX1276LoRaSetImplicitHeaderOn( LoRaSettings.ImplicitHeaderOn );
- SX1276LoRaSetSymbTimeout( 0x3FF );
- SX1276LoRaSetPayloadLength( LoRaSettings.PayloadLength );
- SX1276LoRaSetLowDatarateOptimize( true );
- #if( ( MODULE_SX1276RF1IAS == 1 ) || ( MODULE_SX1276RF1KAS == 1 ) )
- if( LoRaSettings.RFFrequency > 860000000 )
- {
- SX1276LoRaSetPAOutput( RFLR_PACONFIG_PASELECT_RFO );
- SX1276LoRaSetPa20dBm( false );
- LoRaSettings.Power = 14;
- SX1276LoRaSetRFPower( LoRaSettings.Power );
- }
- else
- {
- SX1276LoRaSetPAOutput( RFLR_PACONFIG_PASELECT_PABOOST );
- SX1276LoRaSetPa20dBm( true );
- LoRaSettings.Power = 20;
- SX1276LoRaSetRFPower( LoRaSettings.Power );
- }
- #elif( MODULE_SX1276RF1JAS == 1 )
- if( LoRaSettings.RFFrequency > 860000000 )
- {
- SX1276LoRaSetPAOutput( RFLR_PACONFIG_PASELECT_PABOOST );
- SX1276LoRaSetPa20dBm( true );
- LoRaSettings.Power = 20;
- SX1276LoRaSetRFPower( LoRaSettings.Power );
- }
- else
- {
- SX1276LoRaSetPAOutput( RFLR_PACONFIG_PASELECT_RFO );
- SX1276LoRaSetPa20dBm( false );
- LoRaSettings.Power = 14;
- SX1276LoRaSetRFPower( LoRaSettings.Power );
- }
- #endif
- SX1276LoRaSetOpMode( RFLR_OPMODE_STANDBY );
- }
- void SX1276LoRaInit1( tLoRaSettings *LoRaSettings )
- {
-
- }
- void SX1276LoRaSetDefaults( void )
- {
-
- SX1276Read( REG_LR_VERSION, &SX1276LR->RegVersion );
- }
- void SX1276LoRaReset( void )
- {
- SX1276SetReset( RADIO_RESET_ON );
-
-
-
- delay_ms(1);
- SX1276SetReset( RADIO_RESET_OFF );
-
-
- delay_ms(6);
- }
- void SX1276LoRaSetOpMode( uint8_t opMode )
- {
- static uint8_t opModePrev = RFLR_OPMODE_STANDBY;
- static bool antennaSwitchTxOnPrev = true;
- bool antennaSwitchTxOn = false;
- opModePrev = SX1276LR->RegOpMode & ~RFLR_OPMODE_MASK;
- if( opMode != opModePrev )
- {
- if( opMode == RFLR_OPMODE_TRANSMITTER )
- {
- antennaSwitchTxOn = true;
- }
- else
- {
- antennaSwitchTxOn = false;
- }
- if( antennaSwitchTxOn != antennaSwitchTxOnPrev )
- {
- antennaSwitchTxOnPrev = antennaSwitchTxOn;
- RXTX( antennaSwitchTxOn );
- }
- SX1276LR->RegOpMode = ( SX1276LR->RegOpMode & RFLR_OPMODE_MASK ) | opMode;
- SX1276Write( REG_LR_OPMODE, SX1276LR->RegOpMode );
- }
- }
- uint8_t SX1276LoRaGetOpMode( void )
- {
- SX1276Read( REG_LR_OPMODE, &SX1276LR->RegOpMode );
-
- return SX1276LR->RegOpMode & ~RFLR_OPMODE_MASK;
- }
- uint8_t SX1276LoRaReadRxGain( void )
- {
- SX1276Read( REG_LR_LNA, &SX1276LR->RegLna );
- return( SX1276LR->RegLna >> 5 ) & 0x07;
- }
- double SX1276LoRaReadRssi( void )
- {
-
- SX1276Read( REG_LR_RSSIVALUE, &SX1276LR->RegRssiValue );
- if( LoRaSettings.RFFrequency < 860000000 )
- {
- return RSSI_OFFSET_LF + ( double )SX1276LR->RegRssiValue;
- }
- else
- {
- return RSSI_OFFSET_HF + ( double )SX1276LR->RegRssiValue;
- }
- }
- uint8_t SX1276LoRaGetPacketRxGain( void )
- {
- return RxGain;
- }
- int8_t SX1276LoRaGetPacketSnr( void )
- {
- return RxPacketSnrEstimate;
- }
- double SX1276LoRaGetPacketRssi( void )
- {
- return RxPacketRssiValue;
- }
- void SX1276LoRaStartRx( void )
- {
- SX1276LoRaSetRFState( RFLR_STATE_RX_INIT );
- }
- void SX1276LoRaGetRxPacket( void *buffer, uint16_t *size )
- {
- *size = RxPacketSize;
- RxPacketSize = 0;
- memcpy( ( void * )buffer, ( void * )RFBuffer, ( size_t )*size );
- }
- void SX1276LoRaSetTxPacket( const void *buffer, uint16_t size )
- {
- TxPacketSize = size;
- memcpy( ( void * )RFBuffer, buffer, ( size_t )TxPacketSize );
- RFLRState = RFLR_STATE_TX_INIT;
- }
- uint8_t SX1276LoRaGetRFState( void )
- {
- return RFLRState;
- }
- void SX1276LoRaSetRFState( uint8_t state )
- {
- RFLRState = state;
- }
- uint32_t SX1276LoRaProcess( void )
- {
- uint32_t result = RF_BUSY;
-
- switch( RFLRState )
- {
- case RFLR_STATE_IDLE:
- break;
- case RFLR_STATE_RX_INIT:
-
- SX1276LoRaSetOpMode( RFLR_OPMODE_STANDBY );
- SX1276LR->RegIrqFlagsMask = RFLR_IRQFLAGS_RXTIMEOUT |
-
-
- RFLR_IRQFLAGS_VALIDHEADER |
- RFLR_IRQFLAGS_TXDONE |
- RFLR_IRQFLAGS_CADDONE |
-
- RFLR_IRQFLAGS_CADDETECTED;
- SX1276Write( REG_LR_IRQFLAGSMASK, SX1276LR->RegIrqFlagsMask );
- if( LoRaSettings.FreqHopOn == true )
- {
- SX1276LR->RegHopPeriod = LoRaSettings.HopPeriod;
- SX1276Read( REG_LR_HOPCHANNEL, &SX1276LR->RegHopChannel );
- SX1276LoRaSetRFFrequency( HoppingFrequencies[SX1276LR->RegHopChannel & RFLR_HOPCHANNEL_CHANNEL_MASK] );
- }
- else
- {
- SX1276LR->RegHopPeriod = 255;
- }
-
- SX1276Write( REG_LR_HOPPERIOD, SX1276LR->RegHopPeriod );
-
-
- SX1276LR->RegDioMapping1 = RFLR_DIOMAPPING1_DIO0_00 | RFLR_DIOMAPPING1_DIO1_00 | RFLR_DIOMAPPING1_DIO2_00 | RFLR_DIOMAPPING1_DIO3_00;
-
- SX1276LR->RegDioMapping2 = RFLR_DIOMAPPING2_DIO4_00 | RFLR_DIOMAPPING2_DIO5_00;
- SX1276WriteBuffer( REG_LR_DIOMAPPING1, &SX1276LR->RegDioMapping1, 2 );
-
- if( LoRaSettings.RxSingleOn == true )
- {
- SX1276LoRaSetOpMode( RFLR_OPMODE_RECEIVER_SINGLE );
- }
- else
- {
- SX1276LR->RegFifoAddrPtr = SX1276LR->RegFifoRxBaseAddr;
- SX1276Write( REG_LR_FIFOADDRPTR, SX1276LR->RegFifoAddrPtr );
-
- SX1276LoRaSetOpMode( RFLR_OPMODE_RECEIVER );
- }
-
- memset( RFBuffer, 0, ( size_t )RF_BUFFER_SIZE );
- PacketTimeout = LoRaSettings.RxPacketTimeout;
- RxTimeoutTimer = GET_TICK_COUNT();
- RFLRState = RFLR_STATE_RX_RUNNING;
- break;
- case RFLR_STATE_RX_RUNNING:
-
- if( DIO0 == 1 )
- {
- RxTimeoutTimer = GET_TICK_COUNT( );
- if( LoRaSettings.FreqHopOn == true )
- {
- SX1276Read( REG_LR_HOPCHANNEL, &SX1276LR->RegHopChannel );
- SX1276LoRaSetRFFrequency( HoppingFrequencies[SX1276LR->RegHopChannel & RFLR_HOPCHANNEL_CHANNEL_MASK] );
- }
-
- SX1276Write( REG_LR_IRQFLAGS, RFLR_IRQFLAGS_RXDONE );
- RFLRState = RFLR_STATE_RX_DONE;
- }
- if( LoRaSettings.RxSingleOn == true )
- {
- if( ( GET_TICK_COUNT( ) - RxTimeoutTimer ) > PacketTimeout )
- {
- RFLRState = RFLR_STATE_RX_TIMEOUT;
- }
- }
- break;
- case RFLR_STATE_RX_DONE:
- SX1276Read( REG_LR_IRQFLAGS, &SX1276LR->RegIrqFlags );
- if( ( SX1276LR->RegIrqFlags & RFLR_IRQFLAGS_PAYLOADCRCERROR ) == RFLR_IRQFLAGS_PAYLOADCRCERROR )
- {
-
- SX1276Write( REG_LR_IRQFLAGS, RFLR_IRQFLAGS_PAYLOADCRCERROR );
-
- if( LoRaSettings.RxSingleOn == true )
- {
- RFLRState = RFLR_STATE_RX_INIT;
- }
- else
- {
- RFLRState = RFLR_STATE_RX_RUNNING;
- }
- break;
- }
-
- {
- uint8_t rxSnrEstimate;
- SX1276Read( REG_LR_PKTSNRVALUE, &rxSnrEstimate );
- if( rxSnrEstimate & 0x80 )
- {
-
- RxPacketSnrEstimate = ( ( ~rxSnrEstimate + 1 ) & 0xFF ) >> 2;
- RxPacketSnrEstimate = -RxPacketSnrEstimate;
- }
- else
- {
-
- RxPacketSnrEstimate = ( rxSnrEstimate & 0xFF ) >> 2;
- }
- }
-
- SX1276Read( REG_LR_PKTRSSIVALUE, &SX1276LR->RegPktRssiValue );
-
- if( LoRaSettings.RFFrequency < 860000000 )
- {
- if( RxPacketSnrEstimate < 0 )
- {
- RxPacketRssiValue = RSSI_OFFSET_LF + ( ( double )SX1276LR->RegPktRssiValue ) + RxPacketSnrEstimate;
- }
- else
- {
- RxPacketRssiValue = RSSI_OFFSET_LF + ( 1.0666 * ( ( double )SX1276LR->RegPktRssiValue ) );
- }
- }
- else
- {
- if( RxPacketSnrEstimate < 0 )
- {
- RxPacketRssiValue = RSSI_OFFSET_HF + ( ( double )SX1276LR->RegPktRssiValue ) + RxPacketSnrEstimate;
- }
- else
- {
- RxPacketRssiValue = RSSI_OFFSET_HF + ( 1.0666 * ( ( double )SX1276LR->RegPktRssiValue ) );
- }
- }
- if( LoRaSettings.RxSingleOn == true )
- {
- SX1276LR->RegFifoAddrPtr = SX1276LR->RegFifoRxBaseAddr;
- SX1276Write( REG_LR_FIFOADDRPTR, SX1276LR->RegFifoAddrPtr );
- if( LoRaSettings.ImplicitHeaderOn == true )
- {
- RxPacketSize = SX1276LR->RegPayloadLength;
- SX1276ReadFifo( RFBuffer, SX1276LR->RegPayloadLength );
- }
- else
- {
- SX1276Read( REG_LR_NBRXBYTES, &SX1276LR->RegNbRxBytes );
- RxPacketSize = SX1276LR->RegNbRxBytes;
- SX1276ReadFifo( RFBuffer, SX1276LR->RegNbRxBytes );
- }
- }
- else
- {
- SX1276Read( REG_LR_FIFORXCURRENTADDR, &SX1276LR->RegFifoRxCurrentAddr );
- if( LoRaSettings.ImplicitHeaderOn == true )
- {
- RxPacketSize = SX1276LR->RegPayloadLength;
- SX1276LR->RegFifoAddrPtr = SX1276LR->RegFifoRxCurrentAddr;
- SX1276Write( REG_LR_FIFOADDRPTR, SX1276LR->RegFifoAddrPtr );
- SX1276ReadFifo( RFBuffer, SX1276LR->RegPayloadLength );
- }
- else
- {
- SX1276Read( REG_LR_NBRXBYTES, &SX1276LR->RegNbRxBytes );
- RxPacketSize = SX1276LR->RegNbRxBytes;
- SX1276LR->RegFifoAddrPtr = SX1276LR->RegFifoRxCurrentAddr;
- SX1276Write( REG_LR_FIFOADDRPTR, SX1276LR->RegFifoAddrPtr );
- SX1276ReadFifo( RFBuffer, SX1276LR->RegNbRxBytes );
- }
- }
-
- if( LoRaSettings.RxSingleOn == true )
- {
- RFLRState = RFLR_STATE_RX_INIT;
- }
- else
- {
- RFLRState = RFLR_STATE_RX_RUNNING;
- }
- result = RF_RX_DONE;
- break;
- case RFLR_STATE_RX_TIMEOUT:
- RFLRState = RFLR_STATE_RX_INIT;
- result = RF_RX_TIMEOUT;
- break;
- case RFLR_STATE_TX_INIT:
- SX1276LoRaSetOpMode( RFLR_OPMODE_STANDBY );
- if( LoRaSettings.FreqHopOn == true )
- {
- SX1276LR->RegIrqFlagsMask = RFLR_IRQFLAGS_RXTIMEOUT |
- RFLR_IRQFLAGS_RXDONE |
- RFLR_IRQFLAGS_PAYLOADCRCERROR |
- RFLR_IRQFLAGS_VALIDHEADER |
-
- RFLR_IRQFLAGS_CADDONE |
-
- RFLR_IRQFLAGS_CADDETECTED;
- SX1276LR->RegHopPeriod = LoRaSettings.HopPeriod;
- SX1276Read( REG_LR_HOPCHANNEL, &SX1276LR->RegHopChannel );
- SX1276LoRaSetRFFrequency( HoppingFrequencies[SX1276LR->RegHopChannel & RFLR_HOPCHANNEL_CHANNEL_MASK] );
- }
- else
- {
- SX1276LR->RegIrqFlagsMask = RFLR_IRQFLAGS_RXTIMEOUT |
- RFLR_IRQFLAGS_RXDONE |
- RFLR_IRQFLAGS_PAYLOADCRCERROR |
- RFLR_IRQFLAGS_VALIDHEADER |
-
- RFLR_IRQFLAGS_CADDONE |
- RFLR_IRQFLAGS_FHSSCHANGEDCHANNEL |
- RFLR_IRQFLAGS_CADDETECTED;
- SX1276LR->RegHopPeriod = 0;
- }
- SX1276Write( REG_LR_HOPPERIOD, SX1276LR->RegHopPeriod );
- SX1276Write( REG_LR_IRQFLAGSMASK, SX1276LR->RegIrqFlagsMask );
-
- SX1276LR->RegPayloadLength = TxPacketSize;
- SX1276Write( REG_LR_PAYLOADLENGTH, SX1276LR->RegPayloadLength );
-
- SX1276LR->RegFifoTxBaseAddr = 0x00;
- SX1276Write( REG_LR_FIFOTXBASEADDR, SX1276LR->RegFifoTxBaseAddr );
- SX1276LR->RegFifoAddrPtr = SX1276LR->RegFifoTxBaseAddr;
- SX1276Write( REG_LR_FIFOADDRPTR, SX1276LR->RegFifoAddrPtr );
-
-
- SX1276WriteFifo( RFBuffer, SX1276LR->RegPayloadLength );
-
- SX1276LR->RegDioMapping1 = RFLR_DIOMAPPING1_DIO0_01 | RFLR_DIOMAPPING1_DIO1_00 | RFLR_DIOMAPPING1_DIO2_00 | RFLR_DIOMAPPING1_DIO3_01;
-
- SX1276LR->RegDioMapping2 = RFLR_DIOMAPPING2_DIO4_01 | RFLR_DIOMAPPING2_DIO5_00;
- SX1276WriteBuffer( REG_LR_DIOMAPPING1, &SX1276LR->RegDioMapping1, 2 );
- SX1276LoRaSetOpMode( RFLR_OPMODE_TRANSMITTER );
- RFLRState = RFLR_STATE_TX_RUNNING;
- break;
- case RFLR_STATE_TX_RUNNING:
- if( DIO0 == 1 )
- {
-
- SX1276Write( REG_LR_IRQFLAGS, RFLR_IRQFLAGS_TXDONE );
- RFLRState = RFLR_STATE_TX_DONE;
- }
- break;
- case RFLR_STATE_TX_DONE:
-
- SX1276LoRaSetOpMode( RFLR_OPMODE_STANDBY );
- RFLRState = RFLR_STATE_IDLE;
- result = RF_TX_DONE;
- break;
- case RFLR_STATE_CAD_INIT:
- SX1276LoRaSetOpMode( RFLR_OPMODE_STANDBY );
-
- SX1276LR->RegIrqFlagsMask = RFLR_IRQFLAGS_RXTIMEOUT |
- RFLR_IRQFLAGS_RXDONE |
- RFLR_IRQFLAGS_PAYLOADCRCERROR |
- RFLR_IRQFLAGS_VALIDHEADER |
- RFLR_IRQFLAGS_TXDONE |
-
- RFLR_IRQFLAGS_FHSSCHANGEDCHANNEL;
-
- SX1276Write( REG_LR_IRQFLAGSMASK, SX1276LR->RegIrqFlagsMask );
-
-
- SX1276LR->RegDioMapping1 = RFLR_DIOMAPPING1_DIO0_00 | RFLR_DIOMAPPING1_DIO1_00 | RFLR_DIOMAPPING1_DIO2_00 | RFLR_DIOMAPPING1_DIO3_00;
-
- SX1276LR->RegDioMapping2 = RFLR_DIOMAPPING2_DIO4_00 | RFLR_DIOMAPPING2_DIO5_00;
- SX1276WriteBuffer( REG_LR_DIOMAPPING1, &SX1276LR->RegDioMapping1, 2 );
-
- SX1276LoRaSetOpMode( RFLR_OPMODE_CAD );
- RFLRState = RFLR_STATE_CAD_RUNNING;
- break;
- case RFLR_STATE_CAD_RUNNING:
- if( DIO3 == 1 )
- {
-
- SX1276Write( REG_LR_IRQFLAGS, RFLR_IRQFLAGS_CADDONE );
- if( DIO4 == 1 )
- {
-
- SX1276Write( REG_LR_IRQFLAGS, RFLR_IRQFLAGS_CADDETECTED );
-
- RFLRState = RFLR_STATE_RX_INIT;
- result = RF_CHANNEL_ACTIVITY_DETECTED;
- }
- else
- {
-
- RFLRState = RFLR_STATE_IDLE;
- result = RF_CHANNEL_EMPTY;
- }
- }
- break;
-
- default:
- break;
- }
- return result;
- }
- #endif
|