1 #if !defined(_RADIOLIB_SX1278_H) 2 #define _RADIOLIB_SX1278_H 4 #include "../../TypeDef.h" 6 #if !defined(RADIOLIB_EXCLUDE_SX127X) 8 #include "../../Module.h" 12 #define SX1278_REG_MODEM_CONFIG_3 0x26 13 #define SX1278_REG_PLL_HOP 0x44 14 #define SX1278_REG_TCXO 0x4B 15 #define SX1278_REG_PA_DAC 0x4D 16 #define SX1278_REG_FORMER_TEMP 0x5B 17 #define SX1278_REG_REG_BIT_RATE_FRAC 0x5D 18 #define SX1278_REG_AGC_REF 0x61 19 #define SX1278_REG_AGC_THRESH_1 0x62 20 #define SX1278_REG_AGC_THRESH_2 0x63 21 #define SX1278_REG_AGC_THRESH_3 0x64 22 #define SX1278_REG_PLL 0x70 26 #define SX1278_HIGH_FREQ 0b00000000 // 3 3 access HF test registers 27 #define SX1278_LOW_FREQ 0b00001000 // 3 3 access LF test registers 30 #define SX1278_FRF_MSB 0x6C // 7 0 carrier frequency setting: f_RF = (F(XOSC) * FRF)/2^19 31 #define SX1278_FRF_MID 0x80 // 7 0 where F(XOSC) = 32 MHz 32 #define SX1278_FRF_LSB 0x00 // 7 0 FRF = 3 byte value of FRF registers 35 #define SX1278_MAX_POWER 0b01110000 // 6 4 max power: P_max = 10.8 + 0.6*MAX_POWER [dBm]; P_max(MAX_POWER = 0b111) = 15 dBm 36 #define SX1278_LOW_POWER 0b00100000 // 6 4 39 #define SX1278_LNA_BOOST_LF_OFF 0b00000000 // 4 3 default LNA current 42 #define SX1278_BW_7_80_KHZ 0b00000000 // 7 4 bandwidth: 7.80 kHz 43 #define SX1278_BW_10_40_KHZ 0b00010000 // 7 4 10.40 kHz 44 #define SX1278_BW_15_60_KHZ 0b00100000 // 7 4 15.60 kHz 45 #define SX1278_BW_20_80_KHZ 0b00110000 // 7 4 20.80 kHz 46 #define SX1278_BW_31_25_KHZ 0b01000000 // 7 4 31.25 kHz 47 #define SX1278_BW_41_70_KHZ 0b01010000 // 7 4 41.70 kHz 48 #define SX1278_BW_62_50_KHZ 0b01100000 // 7 4 62.50 kHz 49 #define SX1278_BW_125_00_KHZ 0b01110000 // 7 4 125.00 kHz 50 #define SX1278_BW_250_00_KHZ 0b10000000 // 7 4 250.00 kHz 51 #define SX1278_BW_500_00_KHZ 0b10010000 // 7 4 500.00 kHz 52 #define SX1278_CR_4_5 0b00000010 // 3 1 error coding rate: 4/5 53 #define SX1278_CR_4_6 0b00000100 // 3 1 4/6 54 #define SX1278_CR_4_7 0b00000110 // 3 1 4/7 55 #define SX1278_CR_4_8 0b00001000 // 3 1 4/8 56 #define SX1278_HEADER_EXPL_MODE 0b00000000 // 0 0 explicit header mode 57 #define SX1278_HEADER_IMPL_MODE 0b00000001 // 0 0 implicit header mode 60 #define SX1278_RX_CRC_MODE_OFF 0b00000000 // 2 2 CRC disabled 61 #define SX1278_RX_CRC_MODE_ON 0b00000100 // 2 2 CRC enabled 64 #define SX1278_LOW_DATA_RATE_OPT_OFF 0b00000000 // 3 3 low data rate optimization disabled 65 #define SX1278_LOW_DATA_RATE_OPT_ON 0b00001000 // 3 3 low data rate optimization enabled 66 #define SX1278_AGC_AUTO_OFF 0b00000000 // 2 2 LNA gain set by REG_LNA 67 #define SX1278_AGC_AUTO_ON 0b00000100 // 2 2 LNA gain set by internal AGC loop 70 #define SX1278_CHIP_VERSION 0x12 74 #define SX1278_NO_SHAPING 0b00000000 // 6 5 data shaping: no shaping (default) 75 #define SX1278_FSK_GAUSSIAN_1_0 0b00100000 // 6 5 FSK modulation Gaussian filter, BT = 1.0 76 #define SX1278_FSK_GAUSSIAN_0_5 0b01000000 // 6 5 FSK modulation Gaussian filter, BT = 0.5 77 #define SX1278_FSK_GAUSSIAN_0_3 0b01100000 // 6 5 FSK modulation Gaussian filter, BT = 0.3 78 #define SX1278_OOK_FILTER_BR 0b00100000 // 6 5 OOK modulation filter, f_cutoff = BR 79 #define SX1278_OOK_FILTER_2BR 0b01000000 // 6 5 OOK modulation filter, f_cutoff = 2*BR 82 #define SX1278_AGC_REFERENCE_LEVEL_LF 0x19 // 5 0 floor reference for AGC thresholds: AgcRef = -174 + 10*log(2*RxBw) + 8 + AGC_REFERENCE_LEVEL [dBm]: below 525 MHz 83 #define SX1278_AGC_REFERENCE_LEVEL_HF 0x1C // 5 0 above 779 MHz 86 #define SX1278_AGC_STEP_1_LF 0x0C // 4 0 1st AGC threshold: below 525 MHz 87 #define SX1278_AGC_STEP_1_HF 0x0E // 4 0 above 779 MHz 90 #define SX1278_AGC_STEP_2_LF 0x40 // 7 4 2nd AGC threshold: below 525 MHz 91 #define SX1278_AGC_STEP_2_HF 0x50 // 7 4 above 779 MHz 92 #define SX1278_AGC_STEP_3 0x0B // 3 0 3rd AGC threshold 95 #define SX1278_AGC_STEP_4 0xC0 // 7 4 4th AGC threshold 96 #define SX1278_AGC_STEP_5 0x0C // 4 0 5th AGC threshold 141 int16_t
begin(
float freq = 434.0,
float bw = 125.0, uint8_t sf = 9, uint8_t cr = 7, uint8_t syncWord = SX127X_SYNC_WORD, int8_t power = 10, uint16_t preambleLength = 8, uint8_t gain = 0);
163 int16_t
beginFSK(
float freq = 434.0,
float br = 48.0,
float freqDev = 50.0,
float rxBw = 125.0, int8_t power = 10, uint16_t preambleLength = 16,
bool enableOOK =
false);
168 void reset()
override;
262 int16_t
setCRC(
bool enableCRC);
282 #ifndef RADIOLIB_GODMODE 285 int16_t setBandwidthRaw(uint8_t newBandwidth);
286 int16_t setSpreadingFactorRaw(uint8_t newSpreadingFactor);
287 int16_t setCodingRateRaw(uint8_t newCodingRate);
291 #ifndef RADIOLIB_GODMODE 294 bool _ldroAuto =
true;
295 bool _ldroEnabled =
false;
Base class for SX127x series. All derived classes for SX127x (e.g. SX1278 or SX1272) inherit from thi...
Definition: SX127x.h:536
int16_t setDataShaping(uint8_t sh) override
Sets Gaussian filter bandwidth-time product that will be used for data shaping. Only available in FSK...
Definition: SX1278.cpp:341
float getRSSI()
Gets recorded signal strength indicator of the latest received packet for LoRa modem, or current RSSI level for FSK modem.
Definition: SX1278.cpp:403
int16_t forceLDRO(bool enable)
Forces LoRa low data rate optimization. Only available in LoRa mode. After calling this method...
Definition: SX1278.cpp:457
int16_t setGain(uint8_t gain)
Sets gain of receiver LNA (low-noise amplifier). Can be set to any integer in range 1 to 6 where 1 is...
Definition: SX1278.cpp:316
int16_t autoLDRO()
Re-enables automatic LDRO configuration. Only available in LoRa mode. After calling this method...
Definition: SX1278.cpp:470
int16_t setFrequency(float freq)
Sets carrier frequency. Allowed values range from 137.0 MHz to 525.0 MHz.
Definition: SX1278.cpp:69
int16_t setCRC(bool enableCRC)
Enables/disables CRC check of received packets.
Definition: SX1278.cpp:439
int16_t beginFSK(float freq=434.0, float br=48.0, float freqDev=50.0, float rxBw=125.0, int8_t power=10, uint16_t preambleLength=16, bool enableOOK=false)
FSK modem initialization method. Must be called at least once from Arduino sketch to initialize the m...
Definition: SX1278.cpp:39
int16_t setDataShapingOOK(uint8_t sh)
Sets filter cutoff frequency that will be used for data shaping. Allowed values are 1 for frequency e...
Definition: SX1278.cpp:371
Implements all common low-level SPI/UART/I2C methods to control the wireless module. Every module class contains one private instance of this class.
Definition: Module.h:17
void reset() override
Reset method. Will reset the chip to the default state using RST pin.
Definition: SX1278.cpp:61
SX1278(Module *mod)
Default constructor. Called from Arduino sketch when creating new LoRa instance.
Definition: SX1278.cpp:4
int16_t begin(float freq=434.0, float bw=125.0, uint8_t sf=9, uint8_t cr=7, uint8_t syncWord=SX127X_SYNC_WORD, int8_t power=10, uint16_t preambleLength=8, uint8_t gain=0)
LoRa modem initialization method. Must be called at least once from Arduino sketch to initialize the ...
Definition: SX1278.cpp:8
int16_t setSpreadingFactor(uint8_t sf)
Sets LoRa link spreading factor. Allowed values range from 6 to 12. Only available in LoRa mode...
Definition: SX1278.cpp:197
int16_t setBandwidth(float bw)
Sets LoRa link bandwidth. Allowed values are 10.4, 15.6, 20.8, 31.25, 41.7, 62.5, 125...
Definition: SX1278.cpp:143
Derived class for SX1278 modules. Also used as base class for SX1276, SX1277, SX1279, RFM95 and RFM96. All of these modules use the same basic hardware and only differ in parameter ranges (and names).
Definition: SX1278.h:104
int16_t setOutputPower(int8_t power)
Sets transmission output power. Allowed values range from 2 to 17 dBm.
Definition: SX1278.cpp:287
int16_t setCodingRate(uint8_t cr)
Sets LoRa link coding rate denominator. Allowed values range from 5 to 8. Only available in LoRa mode...
Definition: SX1278.cpp:253