1 #if !defined(_RADIOLIB_PHYSICAL_LAYER_H)
2 #define _RADIOLIB_PHYSICAL_LAYER_H
4 #include "../../TypeDef.h"
5 #include "../../Module.h"
30 #if defined(RADIOLIB_BUILD_ARDUINO)
40 int16_t
transmit(__FlashStringHelper* fstr, uint8_t addr = 0);
51 int16_t
transmit(String& str, uint8_t addr = 0);
63 int16_t
transmit(
const char* str, uint8_t addr = 0);
76 virtual int16_t
transmit(uint8_t* data,
size_t len, uint8_t addr = 0);
78 #if defined(RADIOLIB_BUILD_ARDUINO)
88 int16_t
receive(String& str,
size_t len = 0);
96 virtual int16_t
sleep();
110 virtual int16_t
standby(uint8_t mode);
125 virtual int16_t
startReceive(uint32_t timeout, uint16_t irqFlags, uint16_t irqMask,
size_t len);
136 virtual int16_t
receive(uint8_t* data,
size_t len);
138 #if defined(RADIOLIB_BUILD_ARDUINO)
175 virtual int16_t
startTransmit(uint8_t* data,
size_t len, uint8_t addr = 0);
184 #if defined(RADIOLIB_BUILD_ARDUINO)
195 int16_t
readData(String& str,
size_t len = 0);
208 virtual int16_t
readData(uint8_t* data,
size_t len);
312 int32_t
random(int32_t max);
323 int32_t
random(int32_t min, int32_t max);
339 #if !defined(RADIOLIB_EXCLUDE_DIRECT_RECEIVE)
363 virtual void readBit(uint32_t pin);
384 uint8_t
read(
bool drop =
true);
410 #if defined(RADIOLIB_INTERRUPT_TIMING)
418 void setInterruptSetup(
void (*func)(uint32_t));
428 #if !defined(RADIOLIB_EXCLUDE_DIRECT_RECEIVE)
430 void updateDirectBuffer(uint8_t bit);
433 #if !defined(RADIOLIB_GODMODE)
437 size_t _maxPacketLength;
439 #if !defined(RADIOLIB_EXCLUDE_DIRECT_RECEIVE)
440 uint8_t _bufferBitPos;
441 uint8_t _bufferWritePos;
442 uint8_t _bufferReadPos;
443 uint8_t _buffer[RADIOLIB_STATIC_ARRAY_SIZE];
444 uint32_t _syncBuffer;
445 uint32_t _directSyncWord;
446 uint8_t _directSyncWordLen;
447 uint32_t _directSyncWordMask;
451 virtual Module* getMod() = 0;
Client for audio-based transmissions. Requires Arduino tone() function, and a module capable of direc...
Definition: AFSK.h:17
Client for AX25 communication.
Definition: AX25.h:279
Client for FSK-4 communication. The public interface is the same as Arduino Serial.
Definition: FSK4.h:16
Client for Hellschreiber transmissions.
Definition: Hellschreiber.h:89
Implements all common low-level methods to control the wireless module. Every module class contains o...
Definition: Module.h:28
Client for Morse Code communication. The public interface is the same as Arduino Serial.
Definition: Morse.h:93
Provides common interface for protocols that run on LoRa/FSK modules, such as RTTY or LoRaWAN....
Definition: PhysicalLayer.h:14
virtual int16_t startReceive(uint32_t timeout, uint16_t irqFlags, uint16_t irqMask, size_t len)
Interrupt-driven receive method. A DIO pin will be activated when full packet is received....
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:290
virtual int16_t finishTransmit()
Clean up after transmission is done.
Definition: PhysicalLayer.cpp:156
virtual int16_t setFrequencyDeviation(float freqDev)
Sets FSK frequency deviation from carrier frequency. Only available in FSK mode. Must be implemented ...
Definition: PhysicalLayer.cpp:230
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:249
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:389
virtual int16_t readData(uint8_t *data, size_t len)
Reads data that was received after calling startReceive method.
Definition: PhysicalLayer.cpp:205
void dropSync()
Forcefully drop synchronization.
Definition: PhysicalLayer.cpp:313
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:320
PhysicalLayer(float freqStep, size_t maxPacketLength)
Default constructor.
Definition: PhysicalLayer.cpp:4
virtual void setDio1Action(void(*func)(void))
Sets interrupt service routine to call when DIO1 activates.
Definition: PhysicalLayer.cpp:395
int16_t startDirect()
Configure module parameters for direct modes. Must be called prior to "ham" modes like RTTY or AX....
Definition: PhysicalLayer.cpp:294
virtual int16_t setFrequency(float freq)
Sets carrier frequency. Must be implemented in module class.
Definition: PhysicalLayer.cpp:220
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:328
int16_t startTransmit(const char *str, uint8_t addr=0)
Interrupt-driven Arduino String transmit method. Unlike the standard transmit method,...
Definition: PhysicalLayer.cpp:145
float getFreqStep() const
Gets the module frequency step size that was set in constructor.
Definition: PhysicalLayer.cpp:245
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:211
virtual float getRSSI()
Gets RSSI (Recorded Signal Strength Indicator) of the last received packet.
Definition: PhysicalLayer.cpp:254
int16_t available()
Get the number of direct mode bytes currently available in buffer.
Definition: PhysicalLayer.cpp:309
virtual int16_t receive(uint8_t *data, size_t len)
Binary receive method. Must be implemented in module class.
Definition: PhysicalLayer.cpp:112
virtual void setDirectAction(void(*func)(void))
Set interrupt service routine function to call when data bit is receveid in direct mode....
Definition: PhysicalLayer.cpp:379
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:240
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:262
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:383
virtual void clearDio1Action()
Clears interrupt service routine to call when DIO1 activates.
Definition: PhysicalLayer.cpp:399
virtual int16_t receiveDirect()
Enables direct reception mode on pins DIO1 (clock) and DIO2 (data). Must be implemented in module cla...
Definition: PhysicalLayer.cpp:216
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:235
virtual int16_t setBitRate(float br)
Sets FSK bit rate. Only available in FSK mode. Must be implemented in module class.
Definition: PhysicalLayer.cpp:225
virtual float getSNR()
Gets SNR (Signal to Noise Ratio) of the last received packet. Only available for LoRa modem.
Definition: PhysicalLayer.cpp:258
virtual int16_t sleep()
Sets module to sleep.
Definition: PhysicalLayer.cpp:118
Client for RTTY communication. The public interface is the same as Arduino Serial.
Definition: RTTY.h:88
Client for SSTV transmissions.
Definition: SSTV.h:120