RadioLib
Universal wireless communication library for Arduino
Loading...
Searching...
No Matches
Module.h
1#if !defined(_RADIOLIB_MODULE_H)
2#define _RADIOLIB_MODULE_H
3
4#include "TypeDef.h"
5#include "Hal.h"
6#include "utils/Utils.h"
7
8#if defined(RADIOLIB_BUILD_ARDUINO)
9 #include <SPI.h>
10#endif
11
16#define END_OF_MODE_TABLE { Module::MODE_END_OF_TABLE, {} }
17
23#define RFSWITCH_PIN_FLAG (0x01UL << 31)
24
31#define RADIOLIB_MODULE_SPI_COMMAND_READ (0)
32
34#define RADIOLIB_MODULE_SPI_COMMAND_WRITE (1)
35
37#define RADIOLIB_MODULE_SPI_COMMAND_NOP (2)
38
40#define RADIOLIB_MODULE_SPI_COMMAND_STATUS (3)
41
52#define RADIOLIB_MODULE_SPI_WIDTH_ADDR (0)
53
55#define RADIOLIB_MODULE_SPI_WIDTH_CMD (1)
56
58#define RADIOLIB_MODULE_SPI_WIDTH_STATUS (2)
59
69class Module {
70 public:
78 static const size_t RFSWITCH_MAX_PINS = 5;
79
87 uint8_t mode;
88
91 };
92
117
118 #if defined(RADIOLIB_BUILD_ARDUINO)
126 Module(uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio = RADIOLIB_NC);
127
137 Module(uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio, SPIClass& spi, SPISettings spiSettings = RADIOLIB_DEFAULT_SPI_SETTINGS);
138 #endif
139
148 Module(RadioLibHal *hal, uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio = RADIOLIB_NC);
149
154 Module(const Module& mod);
155
160 Module& operator=(const Module& mod);
161
162 // public member variables
165
167 typedef int16_t (*SPIparseStatusCb_t)(uint8_t in);
168
170 typedef int16_t (*SPIcheckStatusCb_t)(Module* mod);
171
172 enum BitWidth_t {
173 BITS_0 = 0,
174 BITS_8 = 8,
175 BITS_16 = 16,
176 BITS_24 = 24,
177 BITS_32 = 32,
178 };
179
184 struct SPIConfig_t {
186 bool stream;
187
189 int16_t err;
190
192 uint16_t cmds[4];
193
195 BitWidth_t widths[3];
196
198 uint8_t statusPos;
199
202
205
208 };
209
212 .stream = false,
214 .cmds = { 0x00, 0x80, 0x00, 0x00 },
215 .widths = { Module::BITS_8, Module::BITS_0, Module::BITS_8 },
216 .statusPos = 0,
217 .parseStatusCb = nullptr,
218 .checkStatusCb = nullptr,
219 .timeout = 1000,
220 };
221
222 #if RADIOLIB_INTERRUPT_TIMING
223
227 typedef void (*TimerSetupCb_t)(uint32_t len);
228
232 TimerSetupCb_t TimerSetupCb = nullptr;
233
237 volatile bool TimerFlag = false;
238
239 #endif
240
241 // basic methods
242
246 void init();
247
251 void term();
252
253 // SPI methods
254
262 int16_t SPIgetRegValue(uint32_t reg, uint8_t msb = 7, uint8_t lsb = 0);
263
275 int16_t SPIsetRegValue(uint32_t reg, uint8_t value, uint8_t msb = 7, uint8_t lsb = 0, uint8_t checkInterval = 2, uint8_t checkMask = 0xFF, bool force = false);
276
283 void SPIreadRegisterBurst(uint32_t reg, size_t numBytes, uint8_t* inBytes);
284
290 uint8_t SPIreadRegister(uint32_t reg);
291
298 void SPIwriteRegisterBurst(uint32_t reg, const uint8_t* data, size_t numBytes);
299
305 void SPIwriteRegister(uint32_t reg, uint8_t data);
306
315 void SPItransfer(uint16_t cmd, uint32_t reg, const uint8_t* dataOut, uint8_t* dataIn, size_t numBytes);
316
321 int16_t SPIcheckStream();
322
332 int16_t SPIreadStream(uint16_t cmd, uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
333
344 int16_t SPIreadStream(const uint8_t* cmd, uint8_t cmdLen, uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
345
355 int16_t SPIwriteStream(uint16_t cmd, const uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
356
367 int16_t SPIwriteStream(const uint8_t* cmd, uint8_t cmdLen, const uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
368
380 int16_t SPItransferStream(const uint8_t* cmd, uint8_t cmdLen, bool write, const uint8_t* dataOut, uint8_t* dataIn, size_t numBytes, bool waitForGpio);
381
382 // pin number access methods
383 // getCs is omitted on purpose, as it can interfere when accessing the SPI in a concurrent environment
384 // so it is considered to be part of the SPI pins and hence not accessible from outside
385 // see https://github.com/jgromes/RadioLib/discussions/1364
386
391 uint32_t getIrq() const { return(irqPin); }
392
397 uint32_t getRst() const { return(rstPin); }
398
403 uint32_t getGpio() const { return(gpioPin); }
404
421 void setRfSwitchPins(uint32_t rxEn, uint32_t txEn);
422
485 void setRfSwitchTable(const uint32_t (&pins)[RFSWITCH_MAX_PINS], const RfSwitchMode_t table[]);
486
494 const RfSwitchMode_t *findRfSwitchMode(uint8_t mode) const;
495
500 void setRfSwitchState(uint8_t mode);
501
510
511 #if RADIOLIB_DEBUG
518 void regdump(const char* level, uint16_t start, size_t len);
519 #endif
520
521#if !RADIOLIB_GODMODE
522 private:
523#endif
524 uint32_t csPin = RADIOLIB_NC;
525 uint32_t irqPin = RADIOLIB_NC;
526 uint32_t rstPin = RADIOLIB_NC;
527 uint32_t gpioPin = RADIOLIB_NC;
528
529 // RF switch pins and table
530 uint32_t rfSwitchPins[RFSWITCH_MAX_PINS] = { RADIOLIB_NC, RADIOLIB_NC, RADIOLIB_NC, RADIOLIB_NC, RADIOLIB_NC };
531 const RfSwitchMode_t *rfSwitchTable = nullptr;
532
533 #if RADIOLIB_INTERRUPT_TIMING
534 uint32_t prevTimingLen = 0;
535 #endif
536};
537
538#endif
Implements all common low-level methods to control the wireless module. Every module class contains o...
Definition Module.h:69
static const size_t RFSWITCH_MAX_PINS
The maximum number of pins supported by the RF switch code. Note: It is not recommended to use this c...
Definition Module.h:78
void SPIwriteRegisterBurst(uint32_t reg, const uint8_t *data, size_t numBytes)
SPI burst write method.
Definition Module.cpp:157
int16_t(* SPIcheckStatusCb_t)(Module *mod)
Callback for validation SPI status.
Definition Module.h:170
int16_t SPItransferStream(const uint8_t *cmd, uint8_t cmdLen, bool write, const uint8_t *dataOut, uint8_t *dataIn, size_t numBytes, bool waitForGpio)
SPI single transfer method for modules with stream-type SPI interface (SX126x, SX128x etc....
Definition Module.cpp:330
void SPItransfer(uint16_t cmd, uint32_t reg, const uint8_t *dataOut, uint8_t *dataIn, size_t numBytes)
SPI single transfer method.
Definition Module.cpp:189
int16_t SPIgetRegValue(uint32_t reg, uint8_t msb=7, uint8_t lsb=0)
SPI read method that automatically masks unused bits. This method is the preferred SPI read mechanism...
Definition Module.cpp:61
SPIConfig_t spiConfig
SPI configuration structure. The default configuration corresponds to register-access modules,...
Definition Module.h:211
RadioLibHal * hal
Hardware abstraction layer to be used.
Definition Module.h:164
void term()
Terminate low-level module control.
Definition Module.cpp:56
int16_t SPIwriteStream(uint16_t cmd, const uint8_t *data, size_t numBytes, bool waitForGpio=true, bool verify=true)
Method to perform a write transaction with SPI stream.
Definition Module.cpp:279
Module & operator=(const Module &mod)
Overload for assignment operator.
Definition Module.cpp:27
uint32_t getGpio() const
Access method to get the pin number of second interrupt/GPIO.
Definition Module.h:403
const RfSwitchMode_t * findRfSwitchMode(uint8_t mode) const
Find a mode in the RfSwitchTable.
Definition Module.cpp:527
OpMode_t
Constants to use in a mode table set be setRfSwitchTable. These constants work for most radios,...
Definition Module.h:101
@ MODE_TX
Transmission mode.
Definition Module.h:115
@ MODE_IDLE
Idle mode.
Definition Module.h:109
@ MODE_RX
Receive mode.
Definition Module.h:112
@ MODE_END_OF_TABLE
End of table marker, use END_OF_MODE_TABLE constant instead. Value is zero to ensure zero-initialized...
Definition Module.h:106
int16_t SPIcheckStream()
Method to check the result of last SPI stream transfer.
Definition Module.cpp:307
void SPIwriteRegister(uint32_t reg, uint8_t data)
SPI basic write method. Use of this method is reserved for special cases, SPIsetRegValue should be us...
Definition Module.cpp:173
void setRfSwitchPins(uint32_t rxEn, uint32_t txEn)
Some modules contain external RF switch controlled by pins. This function gives RadioLib control over...
Definition Module.cpp:503
void waitForMicroseconds(RadioLibTime_t start, RadioLibTime_t len)
Wait for time to elapse, either using the microsecond timer, or the TimerFlag. Note that in interrupt...
Definition Module.cpp:470
int16_t(* SPIparseStatusCb_t)(uint8_t in)
Callback for parsing SPI status.
Definition Module.h:167
uint8_t SPIreadRegister(uint32_t reg)
SPI basic read method. Use of this method is reserved for special cases, SPIgetRegValue should be use...
Definition Module.cpp:139
uint32_t getIrq() const
Access method to get the pin number of interrupt/GPIO.
Definition Module.h:391
void setRfSwitchTable(const uint32_t(&pins)[RFSWITCH_MAX_PINS], const RfSwitchMode_t table[])
Some modules contain external RF switch controlled by pins. This function gives RadioLib control over...
Definition Module.cpp:519
void SPIreadRegisterBurst(uint32_t reg, size_t numBytes, uint8_t *inBytes)
SPI burst read method.
Definition Module.cpp:123
void init()
Initialize low-level module control.
Definition Module.cpp:48
uint32_t getRst() const
Access method to get the pin number of hardware reset pin.
Definition Module.h:397
int16_t SPIreadStream(uint16_t cmd, uint8_t *data, size_t numBytes, bool waitForGpio=true, bool verify=true)
Method to perform a read transaction with SPI stream.
Definition Module.cpp:251
int16_t SPIsetRegValue(uint32_t reg, uint8_t value, uint8_t msb=7, uint8_t lsb=0, uint8_t checkInterval=2, uint8_t checkMask=0xFF, bool force=false)
Overwrite-safe SPI write method with verification. This method is the preferred SPI write mechanism.
Definition Module.cpp:71
void setRfSwitchState(uint8_t mode)
Set RF switch state.
Definition Module.cpp:538
Hardware abstraction library base interface.
Definition Hal.h:18
#define RADIOLIB_ERR_UNKNOWN
There was an unexpected, unknown error. If you see this, something went incredibly wrong....
Definition TypeDef.h:115
unsigned long RadioLibTime_t
Type used for durations in RadioLib.
Definition TypeDef.h:679
Description of RF switch pin states for a single mode. See setRfSwitchTable for details.
Definition Module.h:85
uint8_t mode
RF switching mode, one of OpMode_t or a custom radio-defined value.
Definition Module.h:87
uint32_t values[RFSWITCH_MAX_PINS]
Output pin values.
Definition Module.h:90
SPI configuration structure.
Definition Module.h:184
bool stream
Whether the SPI module is stream-type (SX126x/8x) or registrer access type (SX127x,...
Definition Module.h:186
RadioLibTime_t timeout
Timeout in ms when waiting for GPIO signals.
Definition Module.h:207
uint16_t cmds[4]
SPI commands.
Definition Module.h:192
uint8_t statusPos
Byte position of status command in SPI stream.
Definition Module.h:198
BitWidth_t widths[3]
Bit widths of SPI addresses, commands and status bytes.
Definition Module.h:195
SPIparseStatusCb_t parseStatusCb
Callback for parsing SPI status.
Definition Module.h:201
SPIcheckStatusCb_t checkStatusCb
Callback for validation SPI status.
Definition Module.h:204
int16_t err
Last recorded SPI error - only updated for modules that return status during SPI transfers.
Definition Module.h:189