RadioLib
Universal wireless communication library for Arduino
PhysicalLayer.h
1 #if !defined(_RADIOLIB_PHYSICAL_LAYER_H)
2 #define _RADIOLIB_PHYSICAL_LAYER_H
3 
4 #include "../../TypeDef.h"
5 #include "../../Module.h"
6 
7 // common IRQ values - the IRQ flags in RadioLibIrqFlags_t arguments are offset by this value
8 enum RadioLibIrqType_t {
9  RADIOLIB_IRQ_TX_DONE = 0x00,
10  RADIOLIB_IRQ_RX_DONE = 0x01,
11  RADIOLIB_IRQ_PREAMBLE_DETECTED = 0x02,
12  RADIOLIB_IRQ_SYNC_WORD_VALID = 0x03,
13  RADIOLIB_IRQ_HEADER_VALID = 0x04,
14  RADIOLIB_IRQ_HEADER_ERR = 0x05,
15  RADIOLIB_IRQ_CRC_ERR = 0x06,
16  RADIOLIB_IRQ_CAD_DONE = 0x07,
17  RADIOLIB_IRQ_CAD_DETECTED = 0x08,
18  RADIOLIB_IRQ_TIMEOUT = 0x09,
19  RADIOLIB_IRQ_NOT_SUPPORTED = 0x1F, // this must be the last value, intentionally set to 31
20 };
21 
22 // some commonly used default values - defined here to ensure all modules have the same default behavior
23 #define RADIOLIB_IRQ_RX_DEFAULT_FLAGS ((1UL << RADIOLIB_IRQ_RX_DONE) | (1UL << RADIOLIB_IRQ_TIMEOUT) | (1UL << RADIOLIB_IRQ_CRC_ERR) | (1UL << RADIOLIB_IRQ_HEADER_VALID) | (1UL << RADIOLIB_IRQ_HEADER_ERR))
24 #define RADIOLIB_IRQ_RX_DEFAULT_MASK ((1UL << RADIOLIB_IRQ_RX_DONE))
25 #define RADIOLIB_IRQ_CAD_DEFAULT_FLAGS ((1UL << RADIOLIB_IRQ_CAD_DETECTED) | (1UL << RADIOLIB_IRQ_CAD_DONE))
26 #define RADIOLIB_IRQ_CAD_DEFAULT_MASK ((1UL << RADIOLIB_IRQ_CAD_DETECTED) | (1UL << RADIOLIB_IRQ_CAD_DONE))
27 
32 struct LoRaRate_t {
34  uint8_t spreadingFactor;
35 
37  float bandwidth;
38 
40  uint8_t codingRate;
41 };
42 
47 struct FSKRate_t {
49  float bitRate;
50 
52  float freqDev;
53 };
54 
59 struct LrFhssRate_t {
61  uint8_t bw;
62 
64  uint8_t cr;
65 };
66 
71 union DataRate_t {
74 
77 };
78 
85  uint8_t symNum;
86 
88  uint8_t detPeak;
89 
91  uint8_t detMin;
92 
94  uint8_t exitMode;
95 
98 
101 
104 };
105 
112  float limit;
113 };
114 
122 
125 };
126 
136  public:
137 
138  // constructor
139 
145  PhysicalLayer(float step, size_t maxLen);
146 
147  // basic methods
148 
149  #if defined(RADIOLIB_BUILD_ARDUINO)
156  int16_t transmit(__FlashStringHelper* fstr, uint8_t addr = 0);
157 
164  int16_t transmit(String& str, uint8_t addr = 0);
165  #endif
166 
173  int16_t transmit(const char* str, uint8_t addr = 0);
174 
182  virtual int16_t transmit(const uint8_t* data, size_t len, uint8_t addr = 0);
183 
184  #if defined(RADIOLIB_BUILD_ARDUINO)
191  int16_t receive(String& str, size_t len = 0);
192  #endif
193 
198  virtual int16_t sleep();
199 
204  virtual int16_t standby();
205 
210  virtual int16_t standby(uint8_t mode);
211 
216  virtual int16_t startReceive();
217 
228  virtual int16_t startReceive(uint32_t timeout, RadioLibIrqFlags_t irqFlags, RadioLibIrqFlags_t irqMask, size_t len);
229 
236  virtual int16_t receive(uint8_t* data, size_t len);
237 
238  #if defined(RADIOLIB_BUILD_ARDUINO)
246  int16_t startTransmit(String& str, uint8_t addr = 0);
247  #endif
248 
256  int16_t startTransmit(const char* str, uint8_t addr = 0);
257 
265  virtual int16_t startTransmit(const uint8_t* data, size_t len, uint8_t addr = 0);
266 
271  virtual int16_t finishTransmit();
272 
273  #if defined(RADIOLIB_BUILD_ARDUINO)
281  int16_t readData(String& str, size_t len = 0);
282  #endif
283 
291  virtual int16_t readData(uint8_t* data, size_t len);
292 
299  virtual int16_t transmitDirect(uint32_t frf = 0);
300 
306  virtual int16_t receiveDirect();
307 
308  // configuration methods
309 
315  virtual int16_t setFrequency(float freq);
316 
322  virtual int16_t setBitRate(float br);
323 
330  virtual int16_t setFrequencyDeviation(float freqDev);
331 
337  virtual int16_t setDataShaping(uint8_t sh);
338 
344  virtual int16_t setEncoding(uint8_t encoding);
345 
351  virtual int16_t invertIQ(bool enable);
352 
358  virtual int16_t setOutputPower(int8_t power);
359 
366  virtual int16_t checkOutputPower(int8_t power, int8_t* clipped);
367 
374  virtual int16_t setSyncWord(uint8_t* sync, size_t len);
375 
381  virtual int16_t setPreambleLength(size_t len);
382 
388  virtual int16_t setDataRate(DataRate_t dr);
389 
395  virtual int16_t checkDataRate(DataRate_t dr);
396 
401  float getFreqStep() const;
402 
408  virtual size_t getPacketLength(bool update = true);
409 
414  virtual float getRSSI();
415 
420  virtual float getSNR();
421 
427  virtual RadioLibTime_t getTimeOnAir(size_t len);
428 
436 
442  uint32_t getIrqMapped(RadioLibIrqFlags_t irq);
443 
449  int16_t checkIrq(RadioLibIrqType_t irq);
450 
458  int16_t setIrq(RadioLibIrqFlags_t irq);
459 
467  int16_t clearIrq(RadioLibIrqFlags_t irq);
468 
474  virtual uint32_t getIrqFlags();
475 
482  virtual int16_t setIrqFlags(uint32_t irq);
483 
490  virtual int16_t clearIrqFlags(uint32_t irq);
491 
497  virtual int16_t startChannelScan();
498 
505  virtual int16_t startChannelScan(const ChannelScanConfig_t &config);
506 
511  virtual int16_t getChannelScanResult();
512 
519  virtual int16_t scanChannel();
520 
528  virtual int16_t scanChannel(const ChannelScanConfig_t &config);
529 
535  int32_t random(int32_t max);
536 
543  int32_t random(int32_t min, int32_t max);
544 
549  virtual uint8_t randomByte();
550 
556  int16_t startDirect();
557 
558  #if !RADIOLIB_EXCLUDE_DIRECT_RECEIVE
565  int16_t setDirectSyncWord(uint32_t syncWord, uint8_t len);
566 
572  virtual void setDirectAction(void (*func)(void));
573 
578  virtual void readBit(uint32_t pin);
579 
584  int16_t available();
585 
589  void dropSync();
590 
597  uint8_t read(bool drop = true);
598  #endif
599 
606  virtual int16_t setDIOMapping(uint32_t pin, uint32_t value);
607 
612  virtual void setPacketReceivedAction(void (*func)(void));
613 
617  virtual void clearPacketReceivedAction();
618 
623  virtual void setPacketSentAction(void (*func)(void));
624 
628  virtual void clearPacketSentAction();
629 
634  virtual void setChannelScanAction(void (*func)(void));
635 
639  virtual void clearChannelScanAction();
640 
641  #if RADIOLIB_INTERRUPT_TIMING
642 
648  void setInterruptSetup(void (*func)(uint32_t));
649 
654  void setTimerFlag();
655 
656  #endif
657 
658 #if !RADIOLIB_GODMODE
659  protected:
660 #endif
661  uint32_t irqMap[10] = { 0 };
662 
663 #if !RADIOLIB_EXCLUDE_DIRECT_RECEIVE
664  void updateDirectBuffer(uint8_t bit);
665 #endif
666 
667 #if !RADIOLIB_GODMODE
668  private:
669 #endif
670  float freqStep;
671  size_t maxPacketLength;
672 
673  #if !RADIOLIB_EXCLUDE_DIRECT_RECEIVE
674  uint8_t bufferBitPos = 0;
675  uint8_t bufferWritePos = 0;
676  uint8_t bufferReadPos = 0;
677  uint8_t buffer[RADIOLIB_STATIC_ARRAY_SIZE] = { 0 };
678  uint32_t syncBuffer = 0;
679  uint32_t directSyncWord = 0;
680  uint8_t directSyncWordLen = 0;
681  uint32_t directSyncWordMask = 0;
682  bool gotSync = false;
683  #endif
684 
685  virtual Module* getMod() = 0;
686 
687  // allow specific classes access the private getMod method
688  friend class AFSKClient;
689  friend class RTTYClient;
690  friend class MorseClient;
691  friend class HellClient;
692  friend class SSTVClient;
693  friend class AX25Client;
694  friend class FSK4Client;
695  friend class PagerClient;
696  friend class BellClient;
697  friend class FT8Client;
698  friend class LoRaWANNode;
699 };
700 
701 #endif
Client for audio-based transmissions. Requires Arduino tone() function, and a module capable of direc...
Definition: AFSK.h:16
Client for AX25 communication.
Definition: AX25.h:233
Client for Bell modem communication. The public interface is the same as Arduino Serial.
Definition: BellModem.h:57
Client for FSK-4 communication. The public interface is the same as Arduino Serial.
Definition: FSK4.h:15
Client for Hellschreiber transmissions.
Definition: Hellschreiber.h:90
LoRaWAN-compatible node (class A device).
Definition: LoRaWAN.h:530
Implements all common low-level methods to control the wireless module. Every module class contains o...
Definition: Module.h:65
Client for Morse Code communication. The public interface is the same as Arduino Serial.
Definition: Morse.h:93
Client for Pager communication.
Definition: Pager.h:62
Provides common interface for protocols that run on LoRa/FSK modules, such as RTTY or LoRaWAN....
Definition: PhysicalLayer.h:135
virtual int16_t invertIQ(bool enable)
Set IQ inversion. Must be implemented in module class if the module supports it.
Definition: PhysicalLayer.cpp:249
virtual void clearChannelScanAction()
Clears interrupt service routine to call when a channel scan is finished.
Definition: PhysicalLayer.cpp:529
virtual int16_t checkOutputPower(int8_t power, int8_t *clipped)
Check if output power is configurable. Must be implemented in module class if the module supports it.
Definition: PhysicalLayer.cpp:259
virtual int16_t startReceive()
Sets module to received mode using its default configuration.
Definition: PhysicalLayer.cpp:131
virtual uint8_t randomByte()
Get one truly random byte from RSSI noise. Must be implemented in module class.
Definition: PhysicalLayer.cpp:404
virtual int16_t finishTransmit()
Clean up after transmission is done.
Definition: PhysicalLayer.cpp:160
int16_t checkIrq(RadioLibIrqType_t irq)
Check whether a specific IRQ bit is set (e.g. RxTimeout, CadDone).
Definition: PhysicalLayer.cpp:325
virtual int16_t setFrequencyDeviation(float freqDev)
Sets FSK frequency deviation from carrier frequency. Only available in FSK mode. Must be implemented ...
Definition: PhysicalLayer.cpp:234
virtual size_t getPacketLength(bool update=true)
Query modem for the packet length of received payload. Must be implemented in module class.
Definition: PhysicalLayer.cpp:290
virtual void setPacketSentAction(void(*func)(void))
Sets interrupt service routine to call when a packet is sent.
Definition: PhysicalLayer.cpp:517
virtual int16_t setDIOMapping(uint32_t pin, uint32_t value)
Configure DIO pin mapping to get a given signal on a DIO pin (if available).
Definition: PhysicalLayer.cpp:503
virtual int16_t readData(uint8_t *data, size_t len)
Reads data that was received after calling startReceive method.
Definition: PhysicalLayer.cpp:209
void dropSync()
Forcefully drop synchronization.
Definition: PhysicalLayer.cpp:427
int16_t transmit(const char *str, uint8_t addr=0)
C-string transmit method.
Definition: PhysicalLayer.cpp:52
uint8_t read(bool drop=true)
Get data from direct mode buffer.
Definition: PhysicalLayer.cpp:434
virtual RadioLibTime_t getTimeOnAir(size_t len)
Get expected time-on-air for a given size of payload.
Definition: PhysicalLayer.cpp:303
virtual int16_t checkDataRate(DataRate_t dr)
Check the data rate can be configured by this module. Must be implemented in module class if the modu...
Definition: PhysicalLayer.cpp:281
virtual int16_t getChannelScanResult()
Read the channel scan result.
Definition: PhysicalLayer.cpp:364
virtual void clearPacketSentAction()
Clears interrupt service routine to call when a packet is sent.
Definition: PhysicalLayer.cpp:521
virtual int16_t setSyncWord(uint8_t *sync, size_t len)
Set sync word. Must be implemented in module class if the module supports it.
Definition: PhysicalLayer.cpp:265
virtual int16_t setDataRate(DataRate_t dr)
Set data. Must be implemented in module class if the module supports it.
Definition: PhysicalLayer.cpp:276
virtual void clearPacketReceivedAction()
Clears interrupt service routine to call when a packet is received.
Definition: PhysicalLayer.cpp:513
virtual RadioLibTime_t calculateRxTimeout(RadioLibTime_t timeoutUs)
Calculate the timeout value for this specific module / series (in number of symbols or units of time)...
Definition: PhysicalLayer.cpp:308
int16_t setIrq(RadioLibIrqFlags_t irq)
Set interrupt on specific IRQ bit(s) (e.g. RxTimeout, CadDone). Keep in mind that not all radio modul...
Definition: PhysicalLayer.cpp:333
virtual int16_t setPreambleLength(size_t len)
Set preamble length. Must be implemented in module class if the module supports it.
Definition: PhysicalLayer.cpp:271
int16_t startDirect()
Configure module parameters for direct modes. Must be called prior to "ham" modes like RTTY or AX....
Definition: PhysicalLayer.cpp:408
virtual int16_t setFrequency(float freq)
Sets carrier frequency. Must be implemented in module class.
Definition: PhysicalLayer.cpp:224
int16_t setDirectSyncWord(uint32_t syncWord, uint8_t len)
Set sync word to be used to determine start of packet in direct reception mode.
Definition: PhysicalLayer.cpp:442
int16_t startTransmit(const char *str, uint8_t addr=0)
Interrupt-driven Arduino String transmit method. Unlike the standard transmit method,...
Definition: PhysicalLayer.cpp:149
float getFreqStep() const
Gets the module frequency step size that was set in constructor.
Definition: PhysicalLayer.cpp:286
virtual int16_t transmitDirect(uint32_t frf=0)
Enables direct transmission mode on pins DIO1 (clock) and DIO2 (data). Must be implemented in module ...
Definition: PhysicalLayer.cpp:215
virtual float getRSSI()
Gets RSSI (Recorded Signal Strength Indicator) of the last received packet.
Definition: PhysicalLayer.cpp:295
int16_t available()
Get the number of direct mode bytes currently available in buffer.
Definition: PhysicalLayer.cpp:423
virtual int16_t receive(uint8_t *data, size_t len)
Binary receive method. Must be implemented in module class.
Definition: PhysicalLayer.cpp:112
virtual int16_t scanChannel()
Check whether the current communication channel is free or occupied. Performs CAD for LoRa modules,...
Definition: PhysicalLayer.cpp:368
virtual void setDirectAction(void(*func)(void))
Set interrupt service routine function to call when data bit is received in direct mode....
Definition: PhysicalLayer.cpp:493
virtual int16_t clearIrqFlags(uint32_t irq)
Clear interrupt on a specific IRQ bit (e.g. RxTimeout, CadDone). Must be implemented in module class.
Definition: PhysicalLayer.cpp:350
virtual int16_t setEncoding(uint8_t encoding)
Sets FSK data encoding. Only available in FSK mode. Must be implemented in module class.
Definition: PhysicalLayer.cpp:244
virtual int16_t standby()
Sets module to standby.
Definition: PhysicalLayer.cpp:122
int32_t random(int32_t max)
Get truly random number in range 0 - max.
Definition: PhysicalLayer.cpp:377
virtual void readBit(uint32_t pin)
Function to read and process data bit in direct reception mode. Must be implemented in module class.
Definition: PhysicalLayer.cpp:497
virtual int16_t setOutputPower(int8_t power)
Set output power. Must be implemented in module class if the module supports it.
Definition: PhysicalLayer.cpp:254
virtual int16_t receiveDirect()
Enables direct reception mode on pins DIO1 (clock) and DIO2 (data). Must be implemented in module cla...
Definition: PhysicalLayer.cpp:220
PhysicalLayer(float step, size_t maxLen)
Default constructor.
Definition: PhysicalLayer.cpp:4
virtual void setChannelScanAction(void(*func)(void))
Sets interrupt service routine to call when a channel scan is finished.
Definition: PhysicalLayer.cpp:525
virtual int16_t startChannelScan()
Interrupt-driven channel activity detection method. Interrupt will be activated when packet is detect...
Definition: PhysicalLayer.cpp:355
uint32_t getIrqMapped(RadioLibIrqFlags_t irq)
Convert from radio-agnostic IRQ flags to radio-specific flags.
Definition: PhysicalLayer.cpp:313
virtual int16_t setDataShaping(uint8_t sh)
Sets GFSK data shaping. Only available in FSK mode. Must be implemented in module class.
Definition: PhysicalLayer.cpp:239
virtual void setPacketReceivedAction(void(*func)(void))
Sets interrupt service routine to call when a packet is received.
Definition: PhysicalLayer.cpp:509
virtual int16_t setBitRate(float br)
Sets FSK bit rate. Only available in FSK mode. Must be implemented in module class.
Definition: PhysicalLayer.cpp:229
virtual float getSNR()
Gets SNR (Signal to Noise Ratio) of the last received packet. Only available for LoRa modem.
Definition: PhysicalLayer.cpp:299
virtual int16_t sleep()
Sets module to sleep.
Definition: PhysicalLayer.cpp:118
virtual uint32_t getIrqFlags()
Read currently active IRQ flags. Must be implemented in module class.
Definition: PhysicalLayer.cpp:341
virtual int16_t setIrqFlags(uint32_t irq)
Set interrupt on DIO1 to be sent on a specific IRQ bit (e.g. RxTimeout, CadDone). Must be implemented...
Definition: PhysicalLayer.cpp:345
int16_t clearIrq(RadioLibIrqFlags_t irq)
Clear interrupt on a specific IRQ bit (e.g. RxTimeout, CadDone). Keep in mind that not all radio modu...
Definition: PhysicalLayer.cpp:337
Client for RTTY communication. The public interface is the same as Arduino Serial.
Definition: RTTY.h:17
Client for SSTV transmissions.
Definition: SSTV.h:121
unsigned long RadioLibTime_t
Type used for durations in RadioLib.
Definition: TypeDef.h:621
uint32_t RadioLibIrqFlags_t
Type used for radio-agnostic IRQ flags. IRQ to enable corresponds to the bit index (RadioLibIrq_t)....
Definition: TypeDef.h:627
Channel scan configuration interpretation in case LoRa CAD is used.
Definition: PhysicalLayer.h:83
RadioLibTime_t timeout
Timeout in microseconds.
Definition: PhysicalLayer.h:97
uint8_t detPeak
Number of peak detection symbols.
Definition: PhysicalLayer.h:88
uint8_t symNum
Number of symbols to consider signal present.
Definition: PhysicalLayer.h:85
uint8_t exitMode
Exit mode after signal detection is complete - module-specific value.
Definition: PhysicalLayer.h:94
RadioLibIrqFlags_t irqFlags
Optional IRQ flags to set, bits offset by the value of RADIOLIB_IRQ_.
Definition: PhysicalLayer.h:100
RadioLibIrqFlags_t irqMask
Optional IRQ mask to set, bits offset by the value of RADIOLIB_IRQ_.
Definition: PhysicalLayer.h:103
uint8_t detMin
Number of minimum detection symbols.
Definition: PhysicalLayer.h:91
Data rate structure interpretation in case FSK is used.
Definition: PhysicalLayer.h:47
float bitRate
FSK bit rate in kbps.
Definition: PhysicalLayer.h:49
float freqDev
FSK frequency deviation in kHz.
Definition: PhysicalLayer.h:52
Data rate structure interpretation in case LoRa is used.
Definition: PhysicalLayer.h:32
uint8_t spreadingFactor
LoRa spreading factor.
Definition: PhysicalLayer.h:34
float bandwidth
LoRa bandwidth in kHz.
Definition: PhysicalLayer.h:37
uint8_t codingRate
LoRa coding rate.
Definition: PhysicalLayer.h:40
Data rate structure interpretation in case LR-FHSS is used.
Definition: PhysicalLayer.h:59
uint8_t cr
Coding rate.
Definition: PhysicalLayer.h:64
uint8_t bw
Bandwidth.
Definition: PhysicalLayer.h:61
Channel scan configuration interpretation in case RSSI threshold is used.
Definition: PhysicalLayer.h:110
float limit
RSSI limit in dBm.
Definition: PhysicalLayer.h:112
Common channel scan configuration structure.
Definition: PhysicalLayer.h:119
RSSIScanConfig_t rssi
Interpretation for modems that use RSSI threshold.
Definition: PhysicalLayer.h:124
CADScanConfig_t cad
Interpretation for modems that use CAD (usually LoRa modems)
Definition: PhysicalLayer.h:121
Common data rate structure.
Definition: PhysicalLayer.h:71
LoRaRate_t lora
Interpretation for LoRa modems.
Definition: PhysicalLayer.h:73
FSKRate_t fsk
Interpretation for FSK modems.
Definition: PhysicalLayer.h:76