Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: SX1280PingPong RangignMaster RangingSlave MSNV2-Terminal_V1-6 ... more
SX1280Hal Class Reference
Actual implementation of a SX1280 radio. More...
#include <sx1280-hal.h>
Inherits SX1280.
| Public Member Functions | |
| SX1280Hal (PinName mosi, PinName miso, PinName sclk, PinName nss, PinName busy, PinName dio1, PinName dio2, PinName dio3, PinName rst, RadioCallbacks_t *callbacks) | |
| Constructor for SX1280Hal with SPI support. | |
| SX1280Hal (PinName tx, PinName rx, PinName ctsn, PinName busy, PinName dio1, PinName dio2, PinName dio3, PinName rst, RadioCallbacks_t *callbacks) | |
| Constructor for SX1280Hal with UART support. | |
| virtual | ~SX1280Hal (void) | 
| Destructor for SX1280Hal with UART support. | |
| virtual void | Reset (void) | 
| Soft resets the radio. | |
| virtual void | Wakeup (void) | 
| Wakes up the radio. | |
| void | SetSpiSpeed (uint32_t spiSpeed) | 
| Set the SPI Speed. | |
| virtual void | WriteCommand (RadioCommands_t opcode, uint8_t *buffer, uint16_t size) | 
| Send a command that write data to the radio. | |
| virtual void | ReadCommand (RadioCommands_t opcode, uint8_t *buffer, uint16_t size) | 
| Send a command that read data from the radio. | |
| virtual void | WriteRegister (uint16_t address, uint8_t *buffer, uint16_t size) | 
| Write data to the radio memory. | |
| virtual void | WriteRegister (uint16_t address, uint8_t value) | 
| Write a single byte of data to the radio memory. | |
| virtual void | ReadRegister (uint16_t address, uint8_t *buffer, uint16_t size) | 
| Read data from the radio memory. | |
| virtual uint8_t | ReadRegister (uint16_t address) | 
| Read a single byte of data from the radio memory. | |
| virtual void | WriteBuffer (uint8_t offset, uint8_t *buffer, uint8_t size) | 
| Write data to the buffer holding the payload in the radio. | |
| virtual void | ReadBuffer (uint8_t offset, uint8_t *buffer, uint8_t size) | 
| Read data from the buffer holding the payload in the radio. | |
| virtual uint8_t | GetDioStatus (void) | 
| Returns the status of DIOs pins. | |
| void | Init (void) | 
| Initializes the radio driver. | |
| void | SetPollingMode (void) | 
| Set the driver in polling mode. | |
| void | SetInterruptMode (void) | 
| Set the driver in interrupt mode. | |
| void | SetRegistersDefault (void) | 
| Initializes the radio registers to the recommended default values. | |
| virtual uint16_t | GetFirmwareVersion (void) | 
| Returns the current device firmware version. | |
| virtual RadioOperatingModes_t | GetOpMode (void) | 
| Gets the current Operation Mode of the Radio. | |
| virtual RadioStatus_t | GetStatus (void) | 
| Gets the current radio status. | |
| void | SetSleep (SleepParams_t sleepConfig) | 
| Sets the radio in sleep mode. | |
| void | SetStandby (RadioStandbyModes_t mode) | 
| Sets the radio in configuration mode. | |
| void | SetFs (void) | 
| Sets the radio in FS mode. | |
| void | SetTx (TickTime_t timeout) | 
| Sets the radio in transmission mode. | |
| void | SetRx (TickTime_t timeout) | 
| Sets the radio in reception mode. | |
| void | SetRxDutyCycle (RadioTickSizes_t periodBase, uint16_t periodBaseCountRx, uint16_t periodBaseCountSleep) | 
| Sets the Rx duty cycle management parameters. | |
| void | SetCad (void) | 
| Sets the radio in CAD mode. | |
| void | SetTxContinuousWave (void) | 
| Sets the radio in continuous wave transmission mode. | |
| void | SetTxContinuousPreamble (void) | 
| Sets the radio in continuous preamble transmission mode. | |
| void | SetPacketType (RadioPacketTypes_t packetType) | 
| Sets the radio for the given protocol. | |
| RadioPacketTypes_t | GetPacketType (bool returnLocalCopy=false) | 
| Gets the current radio protocol. | |
| void | SetRfFrequency (uint32_t rfFrequency) | 
| Sets the RF frequency. | |
| void | SetTxParams (int8_t power, RadioRampTimes_t rampTime) | 
| Sets the transmission parameters. | |
| void | SetCadParams (RadioLoRaCadSymbols_t cadSymbolNum) | 
| Sets the number of symbols to be used for Channel Activity Detection operation. | |
| void | SetBufferBaseAddresses (uint8_t txBaseAddress, uint8_t rxBaseAddress) | 
| Sets the data buffer base address for transmission and reception. | |
| void | SetModulationParams (ModulationParams_t *modParams) | 
| Set the modulation parameters. | |
| void | SetPacketParams (PacketParams_t *packetParams) | 
| Sets the packet parameters. | |
| void | GetRxBufferStatus (uint8_t *rxPayloadLength, uint8_t *rxStartBufferPointer) | 
| Gets the last received packet buffer status. | |
| void | GetPacketStatus (PacketStatus_t *packetStatus) | 
| Gets the last received packet status. | |
| int8_t | GetRssiInst (void) | 
| Returns the instantaneous RSSI value for the last packet received. | |
| void | SetDioIrqParams (uint16_t irqMask, uint16_t dio1Mask, uint16_t dio2Mask, uint16_t dio3Mask) | 
| Sets the IRQ mask and DIO masks. | |
| uint16_t | GetIrqStatus (void) | 
| Returns the current IRQ status. | |
| void | ClearIrqStatus (uint16_t irqMask) | 
| Clears the IRQs. | |
| void | Calibrate (CalibrationParams_t calibParam) | 
| Calibrates the given radio block. | |
| void | SetRegulatorMode (RadioRegulatorModes_t mode) | 
| Sets the power regulators operating mode. | |
| void | SetSaveContext (void) | 
| Saves the current selected modem configuration into data RAM. | |
| void | SetAutoTx (uint16_t time) | 
| Sets the chip to automatically send a packet after the end of a packet reception. | |
| void | StopAutoTx (void) | 
| Stop the chip to automatically send a packet after the end of a packet reception if previously activated with SX1280::SetAutoTx command. | |
| void | SetAutoFs (bool enableAutoFs) | 
| Sets the chip to stay in FS mode after sending a packet. | |
| void | SetLongPreamble (bool enable) | 
| Enables or disables long preamble detection mode. | |
| void | SetPayload (uint8_t *payload, uint8_t size, uint8_t offset=0x00) | 
| Saves the payload to be send in the radio buffer. | |
| uint8_t | GetPayload (uint8_t *payload, uint8_t *size, uint8_t maxSize) | 
| Reads the payload received. If the received payload is longer than maxSize, then the method returns 1 and do not set size and payload. | |
| void | SendPayload (uint8_t *payload, uint8_t size, TickTime_t timeout, uint8_t offset=0x00) | 
| Sends a payload. | |
| uint8_t | SetSyncWord (uint8_t syncWordIdx, uint8_t *syncWord) | 
| Sets the Sync Word given by index used in GFSK, FLRC and BLE protocols. | |
| void | SetSyncWordErrorTolerance (uint8_t errorBits) | 
| Defines how many error bits are tolerated in sync word detection. | |
| uint8_t | SetCrcSeed (uint8_t *seed) | 
| Sets the Initial value for the LFSR used for the CRC calculation. | |
| void | SetBleAccessAddress (uint32_t accessAddress) | 
| Set the Access Address field of BLE packet. | |
| void | SetBleAdvertizerAccessAddress (void) | 
| Set the Access Address for Advertizer BLE packets. | |
| void | SetCrcPolynomial (uint16_t polynomial) | 
| Sets the seed used for the CRC calculation. | |
| void | SetWhiteningSeed (uint8_t seed) | 
| Sets the Initial value of the LFSR used for the whitening in GFSK, FLRC and BLE protocols. | |
| void | EnableManualGain (void) | 
| Enable manual gain control and disable AGC. | |
| void | DisableManualGain (void) | 
| Disable the manual gain control and enable AGC. | |
| void | SetManualGainValue (uint8_t gain) | 
| Set the gain for the AGC. | |
| void | SetLNAGainSetting (const RadioLnaSettings_t lnaSetting) | 
| Configure the LNA regime of operation. | |
| void | SetRangingIdLength (RadioRangingIdCheckLengths_t length) | 
| Sets the number of bits used to check that ranging request match ranging ID. | |
| void | SetDeviceRangingAddress (uint32_t address) | 
| Sets ranging device id. | |
| void | SetRangingRequestAddress (uint32_t address) | 
| Sets the device id to ping in a ranging request. | |
| double | GetRangingResult (RadioRangingResultTypes_t resultType) | 
| Return the ranging result value. | |
| uint8_t | GetRangingPowerDeltaThresholdIndicator (void) | 
| Return the last ranging result power indicator. | |
| void | SetRangingCalibration (uint16_t cal) | 
| Sets the standard processing delay between Master and Slave. | |
| void | RangingClearFilterResult (void) | 
| Clears the ranging filter. | |
| void | RangingSetFilterNumSamples (uint8_t numSample) | 
| Set the number of samples considered in the built-in filter. | |
| double | GetFrequencyError () | 
| Return the Estimated Frequency Error in LORA and RANGING operations. | |
| void | ProcessIrqs (void) | 
| Process the analysis of radio IRQs and calls callback functions depending on radio state. | |
| void | ForcePreambleLength (RadioPreambleLengths_t preambleLength) | 
| Force the preamble length in GFSK and BLE mode. | |
| Protected Member Functions | |
| virtual void | SpiInit (void) | 
| Initializes SPI object used to communicate with the radio. | |
| virtual void | UartInit (void) | 
| Initializes UART object used to communicate with the radio. | |
| virtual void | IoIrqInit (DioIrqHandler irqHandler) | 
| Sets the callback functions to be run on DIO1..3 interrupt. | |
| void | OnDioIrq (void) | 
| DIOs interrupt callback. | |
| void | SetRangingRole (RadioRangingRoles_t role) | 
| Set the role of the radio during ranging operations. | |
| Protected Attributes | |
| SPI * | RadioSpi | 
| The SPI object used to communicate with the radio. | |
| Serial * | RadioUart | 
| The UART object used to communicate with the radio. | |
| DigitalOut | RadioNss | 
| The pin connected to Radio chip select (active low) | |
| DigitalInOut | RadioReset | 
| The reset pin connected to the radio. | |
| DigitalOut | RadioCtsn | 
| The Clear To Send radio pin (active low) | |
| DigitalIn | BUSY | 
| The pin connected to BUSY. | |
| InterruptIn * | DIO1 | 
| The pin connected to DIO1. | |
| InterruptIn * | DIO2 | 
| The pin connected to DIO2. | |
| InterruptIn * | DIO3 | 
| The pin connected to DIO3. | |
| void(* | txDone )(void) | 
| Callback on Tx done interrupt. | |
| void(* | rxDone )(void) | 
| Callback on Rx done interrupt. | |
| void(* | rxSyncWordDone )(void) | 
| Callback on Rx SyncWord interrupt. | |
| void(* | rxHeaderDone )(void) | 
| Callback on Rx header received interrupt. | |
| void(* | txTimeout )(void) | 
| Callback on Tx timeout interrupt. | |
| void(* | rxTimeout )(void) | 
| Callback on Rx timeout interrupt. | |
| void(* | rxError )(IrqErrorCode_t errCode) | 
| Callback on Rx error interrupt. | |
| void(* | rangingDone )(IrqRangingCode_t val) | 
| Callback on ranging done interrupt. | |
| void(* | cadDone )(bool cadFlag) | 
| Callback on Channel Activity Detection done interrupt. | |
Detailed Description
Actual implementation of a SX1280 radio.
Definition at line 24 of file sx1280-hal.h.
Constructor & Destructor Documentation
| SX1280Hal | ( | PinName | mosi, | 
| PinName | miso, | ||
| PinName | sclk, | ||
| PinName | nss, | ||
| PinName | busy, | ||
| PinName | dio1, | ||
| PinName | dio2, | ||
| PinName | dio3, | ||
| PinName | rst, | ||
| RadioCallbacks_t * | callbacks | ||
| ) | 
Constructor for SX1280Hal with SPI support.
Represents the physical connectivity with the radio and set callback functions on radio interrupts
Definition at line 72 of file sx1280-hal.cpp.
| SX1280Hal | ( | PinName | tx, | 
| PinName | rx, | ||
| PinName | ctsn, | ||
| PinName | busy, | ||
| PinName | dio1, | ||
| PinName | dio2, | ||
| PinName | dio3, | ||
| PinName | rst, | ||
| RadioCallbacks_t * | callbacks | ||
| ) | 
Constructor for SX1280Hal with UART support.
Represents the physical connectivity with the radio and set callback functions on radio interrupts
Definition at line 91 of file sx1280-hal.cpp.
| ~SX1280Hal | ( | void | ) |  [virtual] | 
Destructor for SX1280Hal with UART support.
Take care of the correct destruction of the communication objects
Definition at line 109 of file sx1280-hal.cpp.
Member Function Documentation
| void Calibrate | ( | CalibrationParams_t | calibParam ) |  [inherited] | 
Calibrates the given radio block.
- Parameters:
- 
  [in] calibParam The description of blocks to be calibrated 
Definition at line 490 of file sx1280.cpp.
| void ClearIrqStatus | ( | uint16_t | irqMask ) |  [inherited] | 
Clears the IRQs.
- Parameters:
- 
  [in] irqMask IRQ(s) to be cleared 
Definition at line 481 of file sx1280.cpp.
| void DisableManualGain | ( | void | ) |  [inherited] | 
Disable the manual gain control and enable AGC.
- See also:
- SX1280::EnableManualGain
Definition at line 703 of file sx1280.cpp.
| void EnableManualGain | ( | void | ) |  [inherited] | 
Enable manual gain control and disable AGC.
Definition at line 697 of file sx1280.cpp.
| void ForcePreambleLength | ( | RadioPreambleLengths_t | preambleLength ) |  [inherited] | 
Force the preamble length in GFSK and BLE mode.
- Parameters:
- 
  [in] preambleLength The desired preamble length 
Definition at line 343 of file sx1280.cpp.
| uint8_t GetDioStatus | ( | void | ) |  [virtual] | 
Returns the status of DIOs pins.
- Return values:
- 
  dioStatus A byte where each bit represents a DIO state: [ DIO3 | DIO2 | DIO1 | BUSY ] 
Implements SX1280.
Definition at line 468 of file sx1280-hal.cpp.
| uint16_t GetFirmwareVersion | ( | void | ) |  [virtual, inherited] | 
Returns the current device firmware version.
- Return values:
- 
  version Firmware version 
Implements Radio.
Definition at line 56 of file sx1280.cpp.
| double GetFrequencyError | ( | ) |  [inherited] | 
Return the Estimated Frequency Error in LORA and RANGING operations.
- Return values:
- 
  efe The estimated frequency error [Hz] 
Definition at line 856 of file sx1280.cpp.
| uint16_t GetIrqStatus | ( | void | ) |  [inherited] | 
Returns the current IRQ status.
- Return values:
- 
  irqStatus IRQ status 
Definition at line 474 of file sx1280.cpp.
| RadioOperatingModes_t GetOpMode | ( | void | ) |  [virtual, inherited] | 
Gets the current Operation Mode of the Radio.
- Return values:
- 
  opMode Last operating mode 
Definition at line 71 of file sx1280.cpp.
| void GetPacketStatus | ( | PacketStatus_t * | packetStatus ) |  [inherited] | 
Gets the last received packet status.
The packet status structure returned depends on the modem type selected
- See also:
- PacketStatus_t for the description of availabled informations
- Parameters:
- 
  [out] packetStatus A structure of packet status 
Definition at line 374 of file sx1280.cpp.
| RadioPacketTypes_t GetPacketType | ( | bool | returnLocalCopy = false) |  [inherited] | 
Gets the current radio protocol.
Default behavior return the packet type returned by the radio. To reduce the SPI activity and return the packet type stored by the driver, a second optional argument must be provided evaluating as true boolean
- Parameters:
- 
  [in] returnLocalCopy If true, the packet type returned is the last saved in the driver If false, the packet type is obtained from the chip Default: false 
- Return values:
- 
  packetType [PACKET_TYPE_GENERIC, PACKET_TYPE_LORA, PACKET_TYPE_RANGING, PACKET_TYPE_FLRC, PACKET_TYPE_BLE, PACKET_TYPE_NONE] 
Definition at line 181 of file sx1280.cpp.
| uint8_t GetPayload | ( | uint8_t * | payload, | 
| uint8_t * | size, | ||
| uint8_t | maxSize | ||
| ) |  [inherited] | 
Reads the payload received. If the received payload is longer than maxSize, then the method returns 1 and do not set size and payload.
- Parameters:
- 
  [out] payload A pointer to a buffer into which the payload will be copied [out] size A pointer to the size of the payload received [in] maxSize The maximal size allowed to copy into the buffer 
Definition at line 542 of file sx1280.cpp.
| uint8_t GetRangingPowerDeltaThresholdIndicator | ( | void | ) |  [inherited] | 
Return the last ranging result power indicator.
The value returned is not an absolute power measurement. It is a relative power measurement.
- Return values:
- 
  deltaThreshold A relative power indicator 
Definition at line 812 of file sx1280.cpp.
| double GetRangingResult | ( | RadioRangingResultTypes_t | resultType ) |  [inherited] | 
Return the ranging result value.
- Parameters:
- 
  [in] resultType Specifies the type of result. [0: RAW, 1: Averaged, 2: De-biased, 3:Filtered] 
- Return values:
- 
  ranging The ranging measure filtered according to resultType [m] 
Definition at line 771 of file sx1280.cpp.
| int8_t GetRssiInst | ( | void | ) |  [inherited] | 
Returns the instantaneous RSSI value for the last packet received.
- Return values:
- 
  rssiInst Instantaneous RSSI 
Definition at line 450 of file sx1280.cpp.
| void GetRxBufferStatus | ( | uint8_t * | rxPayloadLength, | 
| uint8_t * | rxStartBufferPointer | ||
| ) |  [inherited] | 
Gets the last received packet buffer status.
- Parameters:
- 
  [out] rxPayloadLength Last received packet payload length [out] rxStartBufferPointer Last received packet buffer address pointer 
Definition at line 348 of file sx1280.cpp.
| RadioStatus_t GetStatus | ( | void | ) |  [virtual, inherited] | 
Gets the current radio status.
- Return values:
- 
  status Radio status 
Implements Radio.
Definition at line 61 of file sx1280.cpp.
| void Init | ( | void | ) |  [inherited] | 
Initializes the radio driver.
Definition at line 40 of file sx1280.cpp.
| void IoIrqInit | ( | DioIrqHandler | irqHandler ) |  [protected, virtual] | 
Sets the callback functions to be run on DIO1..3 interrupt.
- Parameters:
- 
  [in] irqHandler A function pointer of the function to be run on every DIO interrupt 
Implements SX1280.
Definition at line 161 of file sx1280-hal.cpp.
| void OnDioIrq | ( | void | ) |  [protected, inherited] | 
DIOs interrupt callback.
- Remarks:
- Called to handle all 3 DIOs pins
Definition at line 929 of file sx1280.cpp.
| void ProcessIrqs | ( | void | ) |  [inherited] | 
Process the analysis of radio IRQs and calls callback functions depending on radio state.
Definition at line 946 of file sx1280.cpp.
| void RangingClearFilterResult | ( | void | ) |  [inherited] | 
Clears the ranging filter.
Definition at line 833 of file sx1280.cpp.
| void RangingSetFilterNumSamples | ( | uint8_t | numSample ) |  [inherited] | 
Set the number of samples considered in the built-in filter.
- Parameters:
- 
  [in] numSample The number of samples to use built-in filter [8..255] 
- Remarks:
- Value inferior to 8 will be silently set to 8
Definition at line 842 of file sx1280.cpp.
| void ReadBuffer | ( | uint8_t | offset, | 
| uint8_t * | buffer, | ||
| uint8_t | size | ||
| ) |  [virtual] | 
Read data from the buffer holding the payload in the radio.
- Parameters:
- 
  [in] offset The offset to start reading the payload [out] buffer A pointer to a buffer holding the data from the radio [in] size The number of byte to be read 
Implements SX1280.
Definition at line 437 of file sx1280-hal.cpp.
| void ReadCommand | ( | RadioCommands_t | opcode, | 
| uint8_t * | buffer, | ||
| uint16_t | size | ||
| ) |  [virtual] | 
Send a command that read data from the radio.
- Parameters:
- 
  [in] opcode Opcode of the command [out] buffer Buffer holding data from the radio [in] size Size of the buffer 
Implements SX1280.
Definition at line 252 of file sx1280-hal.cpp.
| uint8_t ReadRegister | ( | uint16_t | address ) |  [virtual] | 
Read a single byte of data from the radio memory.
- Parameters:
- 
  [in] address The address of the first byte to write in the radio 
- Return values:
- 
  value The value of the byte at the given address in radio's memory 
Implements SX1280.
Definition at line 400 of file sx1280-hal.cpp.
| void ReadRegister | ( | uint16_t | address, | 
| uint8_t * | buffer, | ||
| uint16_t | size | ||
| ) |  [virtual] | 
Read data from the radio memory.
- Parameters:
- 
  [in] address The address of the first byte to read from the radio [out] buffer The buffer that holds data read from radio [in] size The number of bytes to read from radio's memory 
Implements SX1280.
Definition at line 353 of file sx1280-hal.cpp.
| void Reset | ( | void | ) |  [virtual] | 
| void SendPayload | ( | uint8_t * | payload, | 
| uint8_t | size, | ||
| TickTime_t | timeout, | ||
| uint8_t | offset = 0x00 | ||
| ) |  [inherited] | 
Sends a payload.
- Parameters:
- 
  [in] payload A pointer to the payload to send [in] size The size of the payload to send [in] timeout The timeout for Tx operation [in] offset The address in FIFO where writting first byte (default = 0x00) 
Definition at line 555 of file sx1280.cpp.
| void SetAutoFs | ( | bool | enableAutoFs ) |  [inherited] | 
Sets the chip to stay in FS mode after sending a packet.
- Parameters:
- 
  [in] enableAutoFs Turn on auto FS 
Definition at line 527 of file sx1280.cpp.
| void SetAutoTx | ( | uint16_t | time ) |  [inherited] | 
Sets the chip to automatically send a packet after the end of a packet reception.
- Remarks:
- The offset is automatically compensated inside the function
- Parameters:
- 
  [in] time The delay in us after which a Tx is done 
Definition at line 511 of file sx1280.cpp.
| void SetBleAccessAddress | ( | uint32_t | accessAddress ) |  [inherited] | 
Set the Access Address field of BLE packet.
- Parameters:
- 
  [in] accessAddress The access address to be used for next BLE packet sent 
Definition at line 652 of file sx1280.cpp.
| void SetBleAdvertizerAccessAddress | ( | void | ) |  [inherited] | 
Set the Access Address for Advertizer BLE packets.
All advertizer BLE packets must use a particular value for Access Address field. This method sets it.
- See also:
- SX1280::SetBleAccessAddress
Definition at line 660 of file sx1280.cpp.
| void SetBufferBaseAddresses | ( | uint8_t | txBaseAddress, | 
| uint8_t | rxBaseAddress | ||
| ) |  [inherited] | 
Sets the data buffer base address for transmission and reception.
- Parameters:
- 
  [in] txBaseAddress Transmission base address [in] rxBaseAddress Reception base address 
Definition at line 228 of file sx1280.cpp.
| void SetCad | ( | void | ) |  [inherited] | 
Sets the radio in CAD mode.
- See also:
- SX1280::SetCadParams
Definition at line 157 of file sx1280.cpp.
| void SetCadParams | ( | RadioLoRaCadSymbols_t | cadSymbolNum ) |  [inherited] | 
Sets the number of symbols to be used for Channel Activity Detection operation.
- Parameters:
- 
  [in] cadSymbolNum The number of symbol to use for Channel Activity Detection operations [LORA_CAD_01_SYMBOL, LORA_CAD_02_SYMBOLS, LORA_CAD_04_SYMBOLS, LORA_CAD_08_SYMBOLS, LORA_CAD_16_SYMBOLS] 
Definition at line 222 of file sx1280.cpp.
| void SetCrcPolynomial | ( | uint16_t | polynomial ) |  [inherited] | 
Sets the seed used for the CRC calculation.
- Parameters:
- 
  [in] polynomial The seed value 
Definition at line 665 of file sx1280.cpp.
| uint8_t SetCrcSeed | ( | uint8_t * | seed ) |  [inherited] | 
Sets the Initial value for the LFSR used for the CRC calculation.
- Parameters:
- 
  [in] seed Initial LFSR value ( 4 bytes ) 
- Return values:
- 
  updated [0: failure, 1: success] 
Definition at line 630 of file sx1280.cpp.
| void SetDeviceRangingAddress | ( | uint32_t | address ) |  [inherited] | 
Sets ranging device id.
- Parameters:
- 
  [in] address Device address 
Definition at line 743 of file sx1280.cpp.
| void SetDioIrqParams | ( | uint16_t | irqMask, | 
| uint16_t | dio1Mask, | ||
| uint16_t | dio2Mask, | ||
| uint16_t | dio3Mask | ||
| ) |  [inherited] | 
Sets the IRQ mask and DIO masks.
- Parameters:
- 
  [in] irqMask General IRQ mask [in] dio1Mask DIO1 mask [in] dio2Mask DIO2 mask [in] dio3Mask DIO3 mask 
Definition at line 459 of file sx1280.cpp.
| void SetFs | ( | void | ) |  [inherited] | 
Sets the radio in FS mode.
Definition at line 100 of file sx1280.cpp.
| void SetInterruptMode | ( | void | ) |  [inherited] | 
Set the driver in interrupt mode.
In interrupt mode, the driver communicate with the radio during the interruption by direct calls to ProcessIrqs( ). The main advantage is the possibility to have low power application architecture. This is the default mode.
// Initializations and callbacks declaration/definition radio = SX1280( mosi, miso, sclk, nss, busy, int1, int2, int3, rst, &callbacks ); radio.Init( ); radio.SetInterruptMode( ); // Optionnal. Driver default behavior while( true ) { // Do some applicative work }
- See also:
- SX1280::SetPollingMode
Definition at line 924 of file sx1280.cpp.
| void SetLNAGainSetting | ( | const RadioLnaSettings_t | lnaSetting ) |  [inherited] | 
Configure the LNA regime of operation.
- Parameters:
- 
  [in] lnaSetting The LNA setting. Possible values are LNA_LOW_POWER_MODE and LNA_HIGH_SENSITIVITY_MODE 
Definition at line 714 of file sx1280.cpp.
| void SetLongPreamble | ( | bool | enable ) |  [inherited] | 
Enables or disables long preamble detection mode.
- Parameters:
- 
  [in] enable Turn on long preamble mode 
Definition at line 532 of file sx1280.cpp.
| void SetManualGainValue | ( | uint8_t | gain ) |  [inherited] | 
Set the gain for the AGC.
SX1280::EnableManualGain must be called before using this method
- Parameters:
- 
  [in] gain The value of gain to set, refer to datasheet for value meaning 
Definition at line 709 of file sx1280.cpp.
| void SetModulationParams | ( | ModulationParams_t * | modParams ) |  [inherited] | 
Set the modulation parameters.
- Parameters:
- 
  [in] modParams A structure describing the modulation parameters 
Definition at line 237 of file sx1280.cpp.
| void SetPacketParams | ( | PacketParams_t * | packetParams ) |  [inherited] | 
Sets the packet parameters.
- Parameters:
- 
  [in] packetParams A structure describing the packet parameters 
Definition at line 281 of file sx1280.cpp.
| void SetPacketType | ( | RadioPacketTypes_t | packetType ) |  [inherited] | 
Sets the radio for the given protocol.
- Parameters:
- 
  [in] packetType [PACKET_TYPE_GFSK, PACKET_TYPE_LORA, PACKET_TYPE_RANGING, PACKET_TYPE_FLRC, PACKET_TYPE_BLE] 
- Remarks:
- This method has to be called before SetRfFrequency, SetModulationParams and SetPacketParams
Definition at line 173 of file sx1280.cpp.
| void SetPayload | ( | uint8_t * | payload, | 
| uint8_t | size, | ||
| uint8_t | offset = 0x00 | ||
| ) |  [inherited] | 
Saves the payload to be send in the radio buffer.
- Parameters:
- 
  [in] payload A pointer to the payload [in] size The size of the payload [in] offset The address in FIFO where writting first byte (default = 0x00) 
Definition at line 537 of file sx1280.cpp.
| void SetPollingMode | ( | void | ) |  [inherited] | 
Set the driver in polling mode.
In polling mode the application is responsible to call ProcessIrqs( ) to execute callbacks functions. The default mode is Interrupt Mode.
// Initializations and callbacks declaration/definition radio = SX1280( mosi, miso, sclk, nss, busy, int1, int2, int3, rst, &callbacks ); radio.Init( ); radio.SetPollingMode( ); while( true ) { // IRQ processing is automatically done radio.ProcessIrqs( ); // <-- here, as well as callback functions // calls // Do some applicative work }
- See also:
- SX1280::SetInterruptMode
Definition at line 885 of file sx1280.cpp.
| void SetRangingCalibration | ( | uint16_t | cal ) |  [inherited] | 
Sets the standard processing delay between Master and Slave.
- Parameters:
- 
  [in] cal RxTx delay offset for correcting ranging bias. 
The calibration value reflects the group delay of the radio front end and must be re-performed for each new SX1280 PCB design. The value is obtained empirically by either conducted measurement in a known electrical length coaxial RF cable (where the design is connectorised) or by radiated measurement, at a known distance, where an antenna is present. The result of the calibration process is that the SX1280 ranging result accurately reflects the physical range, the calibration procedure therefore removes the average timing error from the time-of-flight measurement for a given design.
The values are Spreading Factor dependents, and depend also of the board design.
Definition at line 820 of file sx1280.cpp.
| void SetRangingIdLength | ( | RadioRangingIdCheckLengths_t | length ) |  [inherited] | 
Sets the number of bits used to check that ranging request match ranging ID.
- Parameters:
- 
  [in] length [0: 8 bits, 1: 16 bits, 2: 24 bits, 3: 32 bits] 
Definition at line 731 of file sx1280.cpp.
| void SetRangingRequestAddress | ( | uint32_t | address ) |  [inherited] | 
Sets the device id to ping in a ranging request.
- Parameters:
- 
  [in] address Address of the device to ping 
Definition at line 757 of file sx1280.cpp.
| void SetRangingRole | ( | RadioRangingRoles_t | role ) |  [protected, inherited] | 
Set the role of the radio during ranging operations.
- Parameters:
- 
  [in] role Role of the radio 
Definition at line 848 of file sx1280.cpp.
| void SetRegistersDefault | ( | void | ) |  [inherited] | 
Initializes the radio registers to the recommended default values.
Definition at line 48 of file sx1280.cpp.
| void SetRegulatorMode | ( | RadioRegulatorModes_t | mode ) |  [inherited] | 
Sets the power regulators operating mode.
- Parameters:
- 
  [in] mode [0: LDO, 1:DC_DC] 
Definition at line 501 of file sx1280.cpp.
| void SetRfFrequency | ( | uint32_t | rfFrequency ) |  [inherited] | 
Sets the RF frequency.
- Parameters:
- 
  [in] rfFrequency RF frequency [Hz] 
Definition at line 199 of file sx1280.cpp.
| void SetRx | ( | TickTime_t | timeout ) |  [inherited] | 
Sets the radio in reception mode.
- Parameters:
- 
  [in] timeout Structure describing the reception timeout value 
Definition at line 125 of file sx1280.cpp.
| void SetRxDutyCycle | ( | RadioTickSizes_t | periodBase, | 
| uint16_t | periodBaseCountRx, | ||
| uint16_t | periodBaseCountSleep | ||
| ) |  [inherited] | 
Sets the Rx duty cycle management parameters.
- Parameters:
- 
  [in] periodBase Base time for Rx and Sleep TickTime sequences [in] periodBaseCountRx Number of base time for Rx TickTime sequence [in] periodBaseCountSleep Number of base time for Sleep TickTime sequence 
Definition at line 144 of file sx1280.cpp.
| void SetSaveContext | ( | void | ) |  [inherited] | 
Saves the current selected modem configuration into data RAM.
Definition at line 506 of file sx1280.cpp.
| void SetSleep | ( | SleepParams_t | sleepConfig ) |  [inherited] | 
Sets the radio in sleep mode.
- Parameters:
- 
  [in] sleepConfig The sleep configuration describing data retention and RTC wake-up 
Definition at line 76 of file sx1280.cpp.
| void SetSpiSpeed | ( | uint32_t | spiSpeed ) | 
Set the SPI Speed.
- Parameters:
- 
  [in] spiSpeed Speed of the SPI in Hz 
Definition at line 147 of file sx1280-hal.cpp.
| void SetStandby | ( | RadioStandbyModes_t | mode ) |  [inherited] | 
Sets the radio in configuration mode.
- Parameters:
- 
  [in] mode The standby mode to put the radio into 
Definition at line 87 of file sx1280.cpp.
| uint8_t SetSyncWord | ( | uint8_t | syncWordIdx, | 
| uint8_t * | syncWord | ||
| ) |  [inherited] | 
Sets the Sync Word given by index used in GFSK, FLRC and BLE protocols.
- Remarks:
- 5th byte isn't used in FLRC and BLE protocols
- Parameters:
- 
  [in] syncWordIdx Index of SyncWord to be set [1..3] [in] syncWord SyncWord bytes ( 5 bytes ) 
- Return values:
- 
  status [0: OK, 1: NOK] 
Definition at line 561 of file sx1280.cpp.
| void SetSyncWordErrorTolerance | ( | uint8_t | errorBits ) |  [inherited] | 
Defines how many error bits are tolerated in sync word detection.
- Parameters:
- 
  [in] errorBits Number of error bits supported to validate the Sync word detection ( default is 4 bit, minimum is 1 bit ) 
Definition at line 624 of file sx1280.cpp.
| void SetTx | ( | TickTime_t | timeout ) |  [inherited] | 
Sets the radio in transmission mode.
- Parameters:
- 
  [in] timeout Structure describing the transmission timeout value 
Definition at line 106 of file sx1280.cpp.
| void SetTxContinuousPreamble | ( | void | ) |  [inherited] | 
Sets the radio in continuous preamble transmission mode.
Definition at line 168 of file sx1280.cpp.
| void SetTxContinuousWave | ( | void | ) |  [inherited] | 
Sets the radio in continuous wave transmission mode.
Definition at line 163 of file sx1280.cpp.
| void SetTxParams | ( | int8_t | power, | 
| RadioRampTimes_t | rampTime | ||
| ) |  [inherited] | 
Sets the transmission parameters.
- Parameters:
- 
  [in] power RF output power [-18..13] dBm [in] rampTime Transmission ramp up time 
Definition at line 211 of file sx1280.cpp.
| void SetWhiteningSeed | ( | uint8_t | seed ) |  [inherited] | 
Sets the Initial value of the LFSR used for the whitening in GFSK, FLRC and BLE protocols.
- Parameters:
- 
  [in] seed Initial LFSR value 
Definition at line 683 of file sx1280.cpp.
| void SpiInit | ( | void | ) |  [protected, virtual] | 
Initializes SPI object used to communicate with the radio.
Definition at line 133 of file sx1280-hal.cpp.
| void StopAutoTx | ( | void | ) |  [inherited] | 
Stop the chip to automatically send a packet after the end of a packet reception if previously activated with SX1280::SetAutoTx command.
Definition at line 521 of file sx1280.cpp.
| void UartInit | ( | void | ) |  [protected, virtual] | 
Initializes UART object used to communicate with the radio.
Definition at line 152 of file sx1280-hal.cpp.
| void Wakeup | ( | void | ) |  [virtual] | 
| void WriteBuffer | ( | uint8_t | offset, | 
| uint8_t * | buffer, | ||
| uint8_t | size | ||
| ) |  [virtual] | 
Write data to the buffer holding the payload in the radio.
- Parameters:
- 
  [in] offset The offset to start writing the payload [in] buffer The data to be written (the payload) [in] size The number of byte to be written 
Implements SX1280.
Definition at line 408 of file sx1280-hal.cpp.
| void WriteCommand | ( | RadioCommands_t | opcode, | 
| uint8_t * | buffer, | ||
| uint16_t | size | ||
| ) |  [virtual] | 
Send a command that write data to the radio.
- Parameters:
- 
  [in] opcode Opcode of the command [in] buffer Buffer to be send to the radio [in] size Size of the buffer to send 
Implements SX1280.
Definition at line 219 of file sx1280-hal.cpp.
| void WriteRegister | ( | uint16_t | address, | 
| uint8_t * | buffer, | ||
| uint16_t | size | ||
| ) |  [virtual] | 
Write data to the radio memory.
- Parameters:
- 
  [in] address The address of the first byte to write in the radio [in] buffer The data to be written in radio's memory [in] size The number of bytes to write in radio's memory 
Implements SX1280.
Definition at line 303 of file sx1280-hal.cpp.
| void WriteRegister | ( | uint16_t | address, | 
| uint8_t | value | ||
| ) |  [virtual] | 
Write a single byte of data to the radio memory.
- Parameters:
- 
  [in] address The address of the first byte to write in the radio [in] value The data to be written in radio's memory 
Implements SX1280.
Definition at line 348 of file sx1280-hal.cpp.
Field Documentation
| DigitalIn BUSY  [protected] | 
The pin connected to BUSY.
Definition at line 158 of file sx1280-hal.h.
| void( * cadDone)(bool cadFlag)  [protected, inherited] | 
| InterruptIn* DIO1  [protected] | 
The pin connected to DIO1.
Definition at line 159 of file sx1280-hal.h.
| InterruptIn* DIO2  [protected] | 
The pin connected to DIO2.
Definition at line 160 of file sx1280-hal.h.
| InterruptIn* DIO3  [protected] | 
The pin connected to DIO3.
Definition at line 161 of file sx1280-hal.h.
| DigitalOut RadioCtsn  [protected] | 
The Clear To Send radio pin (active low)
Definition at line 156 of file sx1280-hal.h.
| DigitalOut RadioNss  [protected] | 
The pin connected to Radio chip select (active low)
Definition at line 154 of file sx1280-hal.h.
| DigitalInOut RadioReset  [protected] | 
The reset pin connected to the radio.
Definition at line 155 of file sx1280-hal.h.
| SPI* RadioSpi  [protected] | 
The SPI object used to communicate with the radio.
Definition at line 152 of file sx1280-hal.h.
| Serial* RadioUart  [protected] | 
The UART object used to communicate with the radio.
Definition at line 153 of file sx1280-hal.h.
| void( * rangingDone)(IrqRangingCode_t val)  [protected, inherited] | 
| void( * rxDone)(void)  [protected, inherited] | 
| void( * rxError)(IrqErrorCode_t errCode)  [protected, inherited] | 
| void( * rxHeaderDone)(void)  [protected, inherited] | 
| void( * rxSyncWordDone)(void)  [protected, inherited] | 
| void( * rxTimeout)(void)  [protected, inherited] | 
| void( * txDone)(void)  [protected, inherited] | 
Generated on Tue Jul 12 2022 19:08:29 by
 1.7.2
 1.7.2 
     SX1280RF1ZHP
            SX1280RF1ZHP