Modtronix inAir9 driver based on SX1276 standard driver
Dependents: SX1276PingPong_inAir Sensors LoRaTerminal
Fork of SX1276Lib by
sx1276/sx1276-inAir.cpp
- Committer:
- rba90
- Date:
- 2016-05-28
- Revision:
- 26:bc0732f29f43
File content as of revision 26:bc0732f29f43:
#include "sx1276-inAir.h" const RadioRegisters_t SX1276inAir::RadioRegsInit[] = RADIO_INIT_REGISTERS_VALUE; SX1276inAir::SX1276inAir( RadioEvents_t *events, PinName mosi, PinName miso, PinName sclk, PinName nss, PinName reset, PinName dio0, PinName dio1, PinName dio2, PinName dio3, PinName antSwitch ) : SX1276( events, mosi, miso, sclk, nss, reset, dio0, dio1, dio2, dio3, NC, NC), antSwitch( NC ), fake( NC ) { this->RadioEvents = events; Reset(); RxChainCalibration( ); IoInit( ); SetOpMode( RF_OPMODE_SLEEP ); IoIrqInit( dioIrq ); RadioRegistersInit( ); SetModem( MODEM_FSK ); this->settings.State = RF_IDLE ; } SX1276inAir::SX1276inAir( RadioEvents_t *events ) : SX1276( events, D11/*MOSI*/, D12/*MISO*/, D13/*SCLK*/, D7/*CS*/, A5/*RST*/, D2/*DIO0*/, D8, D4, A4, NC, NC ), // For NUCLEO L152RE dio4 is on port A3 antSwitch( A4 ), fake( D8 ) { this->RadioEvents = events; Reset(); boardConnected = BOARD_UNKNOWN; DetectBoardType(); RxChainCalibration( ); IoInit( ); SetOpMode( RF_OPMODE_SLEEP ); IoIrqInit( dioIrq ); RadioRegistersInit( ); SetModem( MODEM_FSK ); this->settings.State = RF_IDLE ; } //------------------------------------------------------------------------- // Board relative functions //------------------------------------------------------------------------- uint8_t SX1276inAir::DetectBoardType( void ) { //Detect board type NOT possible with inAir4, inAir9 and inAir9B boards. User has to call //the SetBoardType() function to set the board type! return ( boardConnected ); } void SX1276inAir::IoInit( void ) { AntSwInit( ); SpiInit( ); } void SX1276inAir::RadioRegistersInit( ){ uint8_t i = 0; for( i = 0; i < sizeof( RadioRegsInit ) / sizeof( RadioRegisters_t ); i++ ) { SetModem( RadioRegsInit[i].Modem ); Write( RadioRegsInit[i].Addr, RadioRegsInit[i].Value ); } } void SX1276inAir::SpiInit( void ) { nss = 1; spi.format( 8,0 ); uint32_t frequencyToSet = 8000000; #if( defined (TARGET_NUCLEO_F446RE) || defined ( TARGET_NUCLEO_L152RE ) || defined (TARGET_NUCLEO_F401RE) || defined ( TARGET_LPC11U6X ) || defined (TARGET_K64F) || defined ( TARGET_NZ32ST1L ) || defined(TARGET_NZ32SC151) ) spi.frequency( frequencyToSet ); #elif( defined ( TARGET_KL25Z ) ) //busclock frequency is halved -> double the spi frequency to compensate spi.frequency( frequencyToSet * 2 ); #else #warning "Check the board's SPI frequency" #endif wait(0.1); } void SX1276inAir::IoIrqInit( DioIrqHandler *irqHandlers ) { //TARGET_KL25Z board does not have pulldown resistors, seems like TARGET_K64F does have them #if( defined (TARGET_NUCLEO_F446RE) || defined ( TARGET_NUCLEO_L152RE ) || defined (TARGET_NUCLEO_F401RE) || defined ( TARGET_LPC11U6X ) || defined (TARGET_K64F) || defined ( TARGET_NZ32ST1L ) || defined(TARGET_NZ32SC151)) dio0.mode(PullDown); dio1.mode(PullDown); dio2.mode(PullDown); dio3.mode(PullDown); //dio4.mode(PullDown); #endif dio0.rise( this, static_cast< TriggerInAir > ( irqHandlers[0] ) ); dio1.rise( this, static_cast< TriggerInAir > ( irqHandlers[1] ) ); dio2.rise( this, static_cast< TriggerInAir > ( irqHandlers[2] ) ); //For SHD3I with BOARD_INAIR4 in imod3, on FRDM-KL25Z board. It uses A4 on FRDM-KL25Z board, which does not have interrupt #if( defined ( TARGET_KL25Z ) && defined(SHIELD_SHD3I_INAIR9) ) //Nothing to be done #else dio3.rise( this, static_cast< TriggerInAir > ( irqHandlers[3] ) ); #endif //dio4.rise( this, static_cast< TriggerInAir > ( irqHandlers[4] ) ); } void SX1276inAir::IoDeInit( void ) { //nothing } uint8_t SX1276inAir::GetPaSelect( uint32_t channel ) { if(boardConnected == BOARD_INAIR9B) { return RF_PACONFIG_PASELECT_PABOOST; } else { return RF_PACONFIG_PASELECT_RFO; } } void SX1276inAir::SetAntSwLowPower( bool status ) { if( isRadioActive != status ) { isRadioActive = status; if( status == false ) { AntSwInit( ); } else { AntSwDeInit( ); } } } void SX1276inAir::AntSwInit( void ) { //antSwitch = 0; } void SX1276inAir::AntSwDeInit( void ) { //antSwitch = 0; } void SX1276inAir::SetAntSw( uint8_t rxTx ) { if( this->rxTx == rxTx ) { //no need to go further return; } this->rxTx = rxTx; // if( rxTx != 0 ) // { // antSwitch = 1; // } // else // { // antSwitch = 0; // } } bool SX1276inAir::CheckRfFrequency( uint32_t frequency ) { //TODO: Implement check, currently all frequencies are supported return true; } void SX1276inAir::Reset( void ) { reset.output(); reset = 0; wait_ms( 1 ); reset.input(); wait_ms( 6 ); } void SX1276inAir::Write( uint8_t addr, uint8_t data ) { Write( addr, &data, 1 ); } uint8_t SX1276inAir::Read( uint8_t addr ) { uint8_t data; Read( addr, &data, 1 ); return data; } void SX1276inAir::Write( uint8_t addr, uint8_t *buffer, uint8_t size ) { uint8_t i; nss = 0; spi.write( addr | 0x80 ); for( i = 0; i < size; i++ ) { spi.write( buffer[i] ); } nss = 1; } void SX1276inAir::Read( uint8_t addr, uint8_t *buffer, uint8_t size ) { uint8_t i; nss = 0; spi.write( addr & 0x7F ); for( i = 0; i < size; i++ ) { buffer[i] = spi.write( 0 ); } nss = 1; } void SX1276inAir::WriteFifo( uint8_t *buffer, uint8_t size ) { Write( 0, buffer, size ); } void SX1276inAir::ReadFifo( uint8_t *buffer, uint8_t size ) { Read( 0, buffer, size ); }