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
12#if defined(STM32WLxx)
13 #include <SubGhz.h>
14#endif
15
20#define END_OF_MODE_TABLE { Module::MODE_END_OF_TABLE, {} }
21
27#define RFSWITCH_PIN_FLAG (0x01UL << 31)
28
35#define RADIOLIB_MODULE_SPI_COMMAND_READ (0)
36
38#define RADIOLIB_MODULE_SPI_COMMAND_WRITE (1)
39
41#define RADIOLIB_MODULE_SPI_COMMAND_NOP (2)
42
44#define RADIOLIB_MODULE_SPI_COMMAND_STATUS (3)
45
56#define RADIOLIB_MODULE_SPI_WIDTH_ADDR (0)
57
59#define RADIOLIB_MODULE_SPI_WIDTH_CMD (1)
60
62#define RADIOLIB_MODULE_SPI_WIDTH_STATUS (2)
63
73class Module {
74 public:
82 static const size_t RFSWITCH_MAX_PINS = 5;
83
91 uint8_t mode;
92
95 };
96
121
122 #if defined(RADIOLIB_BUILD_ARDUINO)
130 Module(uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio = RADIOLIB_NC);
131
141 Module(uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio, SPIClass& spi, SPISettings spiSettings = RADIOLIB_DEFAULT_SPI_SETTINGS);
142 #endif
143
152 Module(RadioLibHal *hal, uint32_t cs, uint32_t irq, uint32_t rst, uint32_t gpio = RADIOLIB_NC);
153
158 Module(const Module& mod);
159
164 Module& operator=(const Module& mod);
165
166 // public member variables
169
171 typedef int16_t (*SPIparseStatusCb_t)(uint8_t in);
172
174 typedef int16_t (*SPIcheckStatusCb_t)(Module* mod);
175
176 enum BitWidth_t {
177 BITS_0 = 0,
178 BITS_8 = 8,
179 BITS_16 = 16,
180 BITS_24 = 24,
181 BITS_32 = 32,
182 };
183
188 struct SPIConfig_t {
190 bool stream;
191
193 int16_t err;
194
196 uint16_t cmds[4];
197
199 BitWidth_t widths[3];
200
202 uint8_t statusPos;
203
206
209
212 };
213
216 .stream = false,
218 .cmds = { 0x00, 0x80, 0x00, 0x00 },
219 .widths = { Module::BITS_8, Module::BITS_0, Module::BITS_8 },
220 .statusPos = 0,
221 .parseStatusCb = nullptr,
222 .checkStatusCb = nullptr,
223 .timeout = 1000,
224 };
225
226 #if RADIOLIB_INTERRUPT_TIMING
227
231 typedef void (*TimerSetupCb_t)(uint32_t len);
232
236 TimerSetupCb_t TimerSetupCb = nullptr;
237
241 volatile bool TimerFlag = false;
242
243 #endif
244
245 // basic methods
246
250 void init();
251
255 void term();
256
257 // SPI methods
258
266 int16_t SPIgetRegValue(uint32_t reg, uint8_t msb = 7, uint8_t lsb = 0);
267
279 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);
280
287 void SPIreadRegisterBurst(uint32_t reg, size_t numBytes, uint8_t* inBytes);
288
294 uint8_t SPIreadRegister(uint32_t reg);
295
302 void SPIwriteRegisterBurst(uint32_t reg, const uint8_t* data, size_t numBytes);
303
309 void SPIwriteRegister(uint32_t reg, uint8_t data);
310
319 void SPItransfer(uint16_t cmd, uint32_t reg, const uint8_t* dataOut, uint8_t* dataIn, size_t numBytes);
320
325 int16_t SPIcheckStream();
326
336 int16_t SPIreadStream(uint16_t cmd, uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
337
348 int16_t SPIreadStream(const uint8_t* cmd, uint8_t cmdLen, uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
349
359 int16_t SPIwriteStream(uint16_t cmd, const uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
360
371 int16_t SPIwriteStream(const uint8_t* cmd, uint8_t cmdLen, const uint8_t* data, size_t numBytes, bool waitForGpio = true, bool verify = true);
372
384 int16_t SPItransferStream(const uint8_t* cmd, uint8_t cmdLen, bool write, const uint8_t* dataOut, uint8_t* dataIn, size_t numBytes, bool waitForGpio);
385
386 // pin number access methods
387 // getCs is omitted on purpose, as it can interfere when accessing the SPI in a concurrent environment
388 // so it is considered to be part of the SPI pins and hence not accessible from outside
389 // see https://github.com/jgromes/RadioLib/discussions/1364
390
395 uint32_t getIrq() const { return(irqPin); }
396
401 uint32_t getRst() const { return(rstPin); }
402
407 uint32_t getGpio() const { return(gpioPin); }
408
425 void setRfSwitchPins(uint32_t rxEn, uint32_t txEn);
426
489 void setRfSwitchTable(const uint32_t (&pins)[RFSWITCH_MAX_PINS], const RfSwitchMode_t table[]);
490
498 const RfSwitchMode_t *findRfSwitchMode(uint8_t mode) const;
499
504 void setRfSwitchState(uint8_t mode);
505
514
515 #if RADIOLIB_DEBUG
522 void regdump(const char* level, uint16_t start, size_t len);
523 #endif
524
525#if !RADIOLIB_GODMODE
526 private:
527#endif
528 uint32_t csPin = RADIOLIB_NC;
529 uint32_t irqPin = RADIOLIB_NC;
530 uint32_t rstPin = RADIOLIB_NC;
531 uint32_t gpioPin = RADIOLIB_NC;
532
533 // RF switch pins and table
534 uint32_t rfSwitchPins[RFSWITCH_MAX_PINS] = { RADIOLIB_NC, RADIOLIB_NC, RADIOLIB_NC, RADIOLIB_NC, RADIOLIB_NC };
535 const RfSwitchMode_t *rfSwitchTable = nullptr;
536
537 #if RADIOLIB_INTERRUPT_TIMING
538 uint32_t prevTimingLen = 0;
539 #endif
540};
541
542#endif
Implements all common low-level methods to control the wireless module. Every module class contains o...
Definition Module.h:73
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:82
void SPIwriteRegisterBurst(uint32_t reg, const uint8_t *data, size_t numBytes)
SPI burst write method.
Definition Module.cpp:145
int16_t(* SPIcheckStatusCb_t)(Module *mod)
Callback for validation SPI status.
Definition Module.h:174
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:318
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:177
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:49
SPIConfig_t spiConfig
SPI configuration structure. The default configuration corresponds to register-access modules,...
Definition Module.h:215
RadioLibHal * hal
Hardware abstraction layer to be used.
Definition Module.h:168
void term()
Terminate low-level module control.
Definition Module.cpp:44
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:267
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:407
const RfSwitchMode_t * findRfSwitchMode(uint8_t mode) const
Find a mode in the RfSwitchTable.
Definition Module.cpp:515
OpMode_t
Constants to use in a mode table set be setRfSwitchTable. These constants work for most radios,...
Definition Module.h:105
@ MODE_TX
Transmission mode.
Definition Module.h:119
@ MODE_IDLE
Idle mode.
Definition Module.h:113
@ MODE_RX
Receive mode.
Definition Module.h:116
@ 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:110
int16_t SPIcheckStream()
Method to check the result of last SPI stream transfer.
Definition Module.cpp:295
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:161
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:491
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:458
int16_t(* SPIparseStatusCb_t)(uint8_t in)
Callback for parsing SPI status.
Definition Module.h:171
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:127
uint32_t getIrq() const
Access method to get the pin number of interrupt/GPIO.
Definition Module.h:395
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:507
void SPIreadRegisterBurst(uint32_t reg, size_t numBytes, uint8_t *inBytes)
SPI burst read method.
Definition Module.cpp:111
void init()
Initialize low-level module control.
Definition Module.cpp:37
uint32_t getRst() const
Access method to get the pin number of hardware reset pin.
Definition Module.h:401
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:239
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:59
void setRfSwitchState(uint8_t mode)
Set RF switch state.
Definition Module.cpp:526
Hardware abstraction library base interface.
Definition Hal.h:16
#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:663
Description of RF switch pin states for a single mode. See setRfSwitchTable for details.
Definition Module.h:89
uint8_t mode
RF switching mode, one of OpMode_t or a custom radio-defined value.
Definition Module.h:91
uint32_t values[RFSWITCH_MAX_PINS]
Output pin values.
Definition Module.h:94
SPI configuration structure.
Definition Module.h:188
bool stream
Whether the SPI module is stream-type (SX126x/8x) or registrer access type (SX127x,...
Definition Module.h:190
RadioLibTime_t timeout
Timeout in ms when waiting for GPIO signals.
Definition Module.h:211
uint16_t cmds[4]
SPI commands.
Definition Module.h:196
uint8_t statusPos
Byte position of status command in SPI stream.
Definition Module.h:202
BitWidth_t widths[3]
Bit widths of SPI addresses, commands and status bytes.
Definition Module.h:199
SPIparseStatusCb_t parseStatusCb
Callback for parsing SPI status.
Definition Module.h:205
SPIcheckStatusCb_t checkStatusCb
Callback for validation SPI status.
Definition Module.h:208
int16_t err
Last recorded SPI error - only updated for modules that return status during SPI transfers.
Definition Module.h:193