RadioLib
Universal wireless communication library for Arduino
Module.h
1 #if !defined(_RADIOLIB_MODULE_H)
2 #define _RADIOLIB_MODULE_H
3 
4 #include "TypeDef.h"
5 #include "Hal.h"
6 
7 #if defined(RADIOLIB_BUILD_ARDUINO)
8  #include <SPI.h>
9 #endif
10 
11 #if defined(STM32WLxx)
12  #include <SubGhz.h>
13 #endif
14 
19 #define END_OF_MODE_TABLE { Module::MODE_END_OF_TABLE, {} }
20 
27 #define RADIOLIB_MODULE_SPI_COMMAND_READ (0)
28 
30 #define RADIOLIB_MODULE_SPI_COMMAND_WRITE (1)
31 
33 #define RADIOLIB_MODULE_SPI_COMMAND_NOP (2)
34 
36 #define RADIOLIB_MODULE_SPI_COMMAND_STATUS (3)
37 
48 #define RADIOLIB_MODULE_SPI_WIDTH_ADDR (0)
49 
51 #define RADIOLIB_MODULE_SPI_WIDTH_CMD (1)
52 
54 #define RADIOLIB_MODULE_SPI_WIDTH_STATUS (2)
55 
65 class Module {
66  public:
74  static const size_t RFSWITCH_MAX_PINS = 5;
75 
81  struct RfSwitchMode_t {
83  uint8_t mode;
84 
87  };
88 
97  enum OpMode_t {
103 
106 
109 
112  };
113 
114  #if defined(RADIOLIB_BUILD_ARDUINO)
122  Module(uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio = RADIOLIB_NC);
123 
133  Module(uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio, SPIClass& spi, SPISettings spiSettings = RADIOLIB_DEFAULT_SPI_SETTINGS);
134  #endif
135 
144  Module(RadioLibHal *hal, uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio = RADIOLIB_NC);
145 
150  Module(const Module& mod);
151 
156  Module& operator=(const Module& mod);
157 
158  // public member variables
160  RadioLibHal* hal = NULL;
161 
163  typedef int16_t (*SPIparseStatusCb_t)(uint8_t in);
164 
166  typedef int16_t (*SPIcheckStatusCb_t)(Module* mod);
167 
168  enum BitWidth_t {
169  BITS_0 = 0,
170  BITS_8 = 8,
171  BITS_16 = 16,
172  BITS_32 = 32,
173  };
174 
179  struct SPIConfig_t {
181  bool stream;
182 
184  int16_t err;
185 
187  uint16_t cmds[4];
188 
190  BitWidth_t widths[3];
191 
193  uint8_t statusPos;
194 
197 
200 
203  };
204 
207  .stream = false,
208  .err = RADIOLIB_ERR_UNKNOWN,
209  .cmds = { 0x00, 0x80, 0x00, 0x00 },
210  .widths = { Module::BITS_8, Module::BITS_0, Module::BITS_8 },
211  .statusPos = 0,
212  .parseStatusCb = nullptr,
213  .checkStatusCb = nullptr,
214  .timeout = 1000,
215  };
216 
217  #if RADIOLIB_INTERRUPT_TIMING
218 
222  typedef void (*TimerSetupCb_t)(uint32_t len);
223 
227  TimerSetupCb_t TimerSetupCb = nullptr;
228 
232  volatile bool TimerFlag = false;
233 
234  #endif
235 
236  // basic methods
237 
241  void init();
242 
246  void term();
247 
248  // SPI methods
249 
257  int16_t SPIgetRegValue(uint32_t reg, uint8_t msb = 7, uint8_t lsb = 0);
258 
269  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);
270 
277  void SPIreadRegisterBurst(uint32_t reg, size_t numBytes, uint8_t* inBytes);
278 
284  uint8_t SPIreadRegister(uint32_t reg);
285 
292  void SPIwriteRegisterBurst(uint32_t reg, uint8_t* data, size_t numBytes);
293 
299  void SPIwriteRegister(uint32_t reg, uint8_t data);
300 
309  void SPItransfer(uint16_t cmd, uint32_t reg, uint8_t* dataOut, uint8_t* dataIn, size_t numBytes);
310 
315  int16_t SPIcheckStream();
316 
326  int16_t SPIreadStream(uint16_t cmd, uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
327 
338  int16_t SPIreadStream(uint8_t* cmd, uint8_t cmdLen, uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
339 
349  int16_t SPIwriteStream(uint16_t cmd, uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
350 
361  int16_t SPIwriteStream(uint8_t* cmd, uint8_t cmdLen, uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
362 
374  int16_t SPItransferStream(const uint8_t* cmd, uint8_t cmdLen, bool write, uint8_t* dataOut, uint8_t* dataIn, size_t numBytes, bool waitForGpio);
375 
376  // pin number access methods
377 
382  uint32_t getCs() const { return(csPin); }
383 
388  uint32_t getIrq() const { return(irqPin); }
389 
394  uint32_t getRst() const { return(rstPin); }
395 
400  uint32_t getGpio() const { return(gpioPin); }
401 
418  void setRfSwitchPins(uint32_t rxEn, uint32_t txEn);
419 
482  void setRfSwitchTable(const uint32_t (&pins)[RFSWITCH_MAX_PINS], const RfSwitchMode_t table[]);
483 
491  const RfSwitchMode_t *findRfSwitchMode(uint8_t mode) const;
492 
497  void setRfSwitchState(uint8_t mode);
498 
507 
514  static uint32_t reflect(uint32_t in, uint8_t bits);
515 
516  #if RADIOLIB_DEBUG
525  static void hexdump(const char* level, uint8_t* data, size_t len, uint32_t offset = 0, uint8_t width = 1, bool be = false);
526 
533  void regdump(const char* level, uint16_t start, size_t len);
534  #endif
535 
536  #if RADIOLIB_DEBUG and defined(RADIOLIB_BUILD_ARDUINO)
537  static size_t serialPrintf(const char* format, ...);
538  #endif
539 
540 #if !RADIOLIB_GODMODE
541  private:
542 #endif
543  uint32_t csPin = RADIOLIB_NC;
544  uint32_t irqPin = RADIOLIB_NC;
545  uint32_t rstPin = RADIOLIB_NC;
546  uint32_t gpioPin = RADIOLIB_NC;
547 
548  // RF switch pins and table
549  uint32_t rfSwitchPins[RFSWITCH_MAX_PINS] = { RADIOLIB_NC, RADIOLIB_NC, RADIOLIB_NC, RADIOLIB_NC, RADIOLIB_NC };
550  const RfSwitchMode_t *rfSwitchTable = nullptr;
551 
552  #if RADIOLIB_INTERRUPT_TIMING
553  uint32_t prevTimingLen = 0;
554  #endif
555 };
556 
557 #endif
Implements all common low-level methods to control the wireless module. Every module class contains o...
Definition: Module.h:65
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:74
int16_t(* SPIcheckStatusCb_t)(Module *mod)
Callback for validation SPI status.
Definition: Module.h:166
void SPIwriteRegisterBurst(uint32_t reg, uint8_t *data, size_t numBytes)
SPI burst write method.
Definition: Module.cpp:143
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:55
SPIConfig_t spiConfig
SPI configuration structure. The default configuration corresponds to register-access modules,...
Definition: Module.h:206
int16_t SPItransferStream(const uint8_t *cmd, uint8_t cmdLen, bool write, 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:316
RadioLibHal * hal
Hardware abstraction layer to be used.
Definition: Module.h:160
void term()
Terminate low-level module control.
Definition: Module.cpp:50
static uint32_t reflect(uint32_t in, uint8_t bits)
Function to reflect bits within a byte.
Definition: Module.cpp:462
Module & operator=(const Module &mod)
Overload for assignment operator.
Definition: Module.cpp:33
uint32_t getGpio() const
Access method to get the pin number of second interrupt/GPIO.
Definition: Module.h:400
const RfSwitchMode_t * findRfSwitchMode(uint8_t mode) const
Find a mode in the RfSwitchTable.
Definition: Module.cpp:588
OpMode_t
Constants to use in a mode table set be setRfSwitchTable. These constants work for most radios,...
Definition: Module.h:97
@ MODE_TX
Transmission mode.
Definition: Module.h:111
@ MODE_IDLE
Idle mode.
Definition: Module.h:105
@ MODE_RX
Receive mode.
Definition: Module.h:108
@ 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:102
int16_t SPIcheckStream()
Method to check the result of last SPI stream transfer.
Definition: Module.cpp:293
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:159
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:565
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:444
Module(RadioLibHal *hal, uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio=RADIOLIB_NC)
Module constructor.
Definition: Module.cpp:25
int16_t(* SPIparseStatusCb_t)(uint8_t in)
Callback for parsing SPI status.
Definition: Module.h:163
uint32_t getCs() const
Access method to get the pin number of SPI chip select.
Definition: Module.h:382
void SPItransfer(uint16_t cmd, uint32_t reg, uint8_t *dataOut, uint8_t *dataIn, size_t numBytes)
SPI single transfer method.
Definition: Module.cpp:175
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:125
uint32_t getIrq() const
Access method to get the pin number of interrupt/GPIO.
Definition: Module.h:388
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:581
void SPIreadRegisterBurst(uint32_t reg, size_t numBytes, uint8_t *inBytes)
SPI burst read method.
Definition: Module.cpp:109
void init()
Initialize low-level module control.
Definition: Module.cpp:43
uint32_t getRst() const
Access method to get the pin number of hardware reset pin.
Definition: Module.h:394
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:237
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)
Overwrite-safe SPI write method with verification. This method is the preferred SPI write mechanism.
Definition: Module.cpp:65
int16_t SPIwriteStream(uint16_t cmd, uint8_t *data, size_t numBytes, bool waitForGpio=true, bool verify=true)
Method to perform a write transaction with SPI stream.
Definition: Module.cpp:265
void setRfSwitchState(uint8_t mode)
Set RF switch state.
Definition: Module.cpp:598
Hardware abstraction library base interface.
Definition: Hal.h:13
#define RADIOLIB_ERR_UNKNOWN
There was an unexpected, unknown error. If you see this, something went incredibly wrong....
Definition: TypeDef.h:110
unsigned long RadioLibTime_t
Type used for durations in RadioLib.
Definition: TypeDef.h:616
Description of RF switch pin states for a single mode. See setRfSwitchTable for details.
Definition: Module.h:81
uint8_t mode
RF switching mode, one of OpMode_t or a custom radio-defined value.
Definition: Module.h:83
uint32_t values[RFSWITCH_MAX_PINS]
Output pin values.
Definition: Module.h:86
SPI configuration structure.
Definition: Module.h:179
bool stream
Whether the SPI module is stream-type (SX126x/8x) or registrer access type (SX127x,...
Definition: Module.h:181
RadioLibTime_t timeout
Timeout in ms when waiting for GPIO signals.
Definition: Module.h:202
uint16_t cmds[4]
SPI commands.
Definition: Module.h:187
uint8_t statusPos
Byte position of status command in SPI stream.
Definition: Module.h:193
BitWidth_t widths[3]
Bit widths of SPI addresses, commands and status bytes.
Definition: Module.h:190
SPIparseStatusCb_t parseStatusCb
Callback for parsing SPI status.
Definition: Module.h:196
SPIcheckStatusCb_t checkStatusCb
Callback for validation SPI status.
Definition: Module.h:199
int16_t err
Last recorded SPI error - only updated for modules that return status during SPI transfers.
Definition: Module.h:184