RadioLib
Universal wireless communication library for Arduino
Loading...
Searching...
No Matches
CC1101.h
1#if !defined(_RADIOLIB_CC1101_H) && !RADIOLIB_EXCLUDE_CC1101
2#define _RADIOLIB_CC1101_H
3
4#include "../../TypeDef.h"
5#include "../../Module.h"
6
7#include "../../protocols/PhysicalLayer/PhysicalLayer.h"
8
9// CC1101 physical layer properties
10#define RADIOLIB_CC1101_FREQUENCY_STEP_SIZE 396.7285156
11#define RADIOLIB_CC1101_MAX_PACKET_LENGTH 64
12#define RADIOLIB_CC1101_CRYSTAL_FREQ 26.0f
13#define RADIOLIB_CC1101_DIV_EXPONENT 16
14
15// CC1101 SPI commands
16#define RADIOLIB_CC1101_CMD_READ 0b10000000
17#define RADIOLIB_CC1101_CMD_WRITE 0b00000000
18#define RADIOLIB_CC1101_CMD_BURST 0b01000000
19#define RADIOLIB_CC1101_CMD_ACCESS_STATUS_REG 0b01000000
20#define RADIOLIB_CC1101_CMD_FIFO_RX 0b10000000
21#define RADIOLIB_CC1101_CMD_FIFO_TX 0b00000000
22#define RADIOLIB_CC1101_CMD_RESET 0x30
23#define RADIOLIB_CC1101_CMD_FSTXON 0x31
24#define RADIOLIB_CC1101_CMD_XOFF 0x32
25#define RADIOLIB_CC1101_CMD_CAL 0x33
26#define RADIOLIB_CC1101_CMD_RX 0x34
27#define RADIOLIB_CC1101_CMD_TX 0x35
28#define RADIOLIB_CC1101_CMD_IDLE 0x36
29#define RADIOLIB_CC1101_CMD_WOR 0x38
30#define RADIOLIB_CC1101_CMD_POWER_DOWN 0x39
31#define RADIOLIB_CC1101_CMD_FLUSH_RX 0x3A
32#define RADIOLIB_CC1101_CMD_FLUSH_TX 0x3B
33#define RADIOLIB_CC1101_CMD_WOR_RESET 0x3C
34#define RADIOLIB_CC1101_CMD_NOP 0x3D
35
36// CC1101 register map
37#define RADIOLIB_CC1101_REG_IOCFG2 0x00
38#define RADIOLIB_CC1101_REG_IOCFG1 0x01
39#define RADIOLIB_CC1101_REG_IOCFG0 0x02
40#define RADIOLIB_CC1101_REG_FIFOTHR 0x03
41#define RADIOLIB_CC1101_REG_SYNC1 0x04
42#define RADIOLIB_CC1101_REG_SYNC0 0x05
43#define RADIOLIB_CC1101_REG_PKTLEN 0x06
44#define RADIOLIB_CC1101_REG_PKTCTRL1 0x07
45#define RADIOLIB_CC1101_REG_PKTCTRL0 0x08
46#define RADIOLIB_CC1101_REG_ADDR 0x09
47#define RADIOLIB_CC1101_REG_CHANNR 0x0A
48#define RADIOLIB_CC1101_REG_FSCTRL1 0x0B
49#define RADIOLIB_CC1101_REG_FSCTRL0 0x0C
50#define RADIOLIB_CC1101_REG_FREQ2 0x0D
51#define RADIOLIB_CC1101_REG_FREQ1 0x0E
52#define RADIOLIB_CC1101_REG_FREQ0 0x0F
53#define RADIOLIB_CC1101_REG_MDMCFG4 0x10
54#define RADIOLIB_CC1101_REG_MDMCFG3 0x11
55#define RADIOLIB_CC1101_REG_MDMCFG2 0x12
56#define RADIOLIB_CC1101_REG_MDMCFG1 0x13
57#define RADIOLIB_CC1101_REG_MDMCFG0 0x14
58#define RADIOLIB_CC1101_REG_DEVIATN 0x15
59#define RADIOLIB_CC1101_REG_MCSM2 0x16
60#define RADIOLIB_CC1101_REG_MCSM1 0x17
61#define RADIOLIB_CC1101_REG_MCSM0 0x18
62#define RADIOLIB_CC1101_REG_FOCCFG 0x19
63#define RADIOLIB_CC1101_REG_BSCFG 0x1A
64#define RADIOLIB_CC1101_REG_AGCCTRL2 0x1B
65#define RADIOLIB_CC1101_REG_AGCCTRL1 0x1C
66#define RADIOLIB_CC1101_REG_AGCCTRL0 0x1D
67#define RADIOLIB_CC1101_REG_WOREVT1 0x1E
68#define RADIOLIB_CC1101_REG_WOREVT0 0x1F
69#define RADIOLIB_CC1101_REG_WORCTRL 0x20
70#define RADIOLIB_CC1101_REG_FREND1 0x21
71#define RADIOLIB_CC1101_REG_FREND0 0x22
72#define RADIOLIB_CC1101_REG_FSCAL3 0x23
73#define RADIOLIB_CC1101_REG_FSCAL2 0x24
74#define RADIOLIB_CC1101_REG_FSCAL1 0x25
75#define RADIOLIB_CC1101_REG_FSCAL0 0x26
76#define RADIOLIB_CC1101_REG_RCCTRL1 0x27
77#define RADIOLIB_CC1101_REG_RCCTRL0 0x28
78#define RADIOLIB_CC1101_REG_FSTEST 0x29
79#define RADIOLIB_CC1101_REG_PTEST 0x2A
80#define RADIOLIB_CC1101_REG_AGCTEST 0x2B
81#define RADIOLIB_CC1101_REG_TEST2 0x2C
82#define RADIOLIB_CC1101_REG_TEST1 0x2D
83#define RADIOLIB_CC1101_REG_TEST0 0x2E
84#define RADIOLIB_CC1101_REG_PARTNUM 0x30
85#define RADIOLIB_CC1101_REG_VERSION 0x31
86#define RADIOLIB_CC1101_REG_FREQEST 0x32
87#define RADIOLIB_CC1101_REG_LQI 0x33
88#define RADIOLIB_CC1101_REG_RSSI 0x34
89#define RADIOLIB_CC1101_REG_MARCSTATE 0x35
90#define RADIOLIB_CC1101_REG_WORTIME1 0x36
91#define RADIOLIB_CC1101_REG_WORTIME0 0x37
92#define RADIOLIB_CC1101_REG_PKTSTATUS 0x38
93#define RADIOLIB_CC1101_REG_VCO_VC_DAC 0x39
94#define RADIOLIB_CC1101_REG_TXBYTES 0x3A
95#define RADIOLIB_CC1101_REG_RXBYTES 0x3B
96#define RADIOLIB_CC1101_REG_RCCTRL1_STATUS 0x3C
97#define RADIOLIB_CC1101_REG_RCCTRL0_STATUS 0x3D
98#define RADIOLIB_CC1101_REG_PATABLE 0x3E
99#define RADIOLIB_CC1101_REG_FIFO 0x3F
100
101// status byte (returned during SPI transactions) MSB LSB DESCRIPTION
102#define RADIOLIB_CC1101_STATUS_CHIP_READY 0b00000000 // 7 7 chip ready
103#define RADIOLIB_CC1101_STATUS_CHIP_NOT_READY 0b10000000 // 7 7 chip not ready (power/crystal not stable)
104#define RADIOLIB_CC1101_STATUS_IDLE 0b00000000 // 6 4 idle
105#define RADIOLIB_CC1101_STATUS_RX 0b00010000 // 6 4 Rx
106#define RADIOLIB_CC1101_STATUS_TX 0b00100000 // 6 4 Tx
107#define RADIOLIB_CC1101_STATUS_FSTXON 0b00110000 // 6 4 Fast Tx ready
108#define RADIOLIB_CC1101_STATUS_CALIBRATE 0b01000000 // 6 4 synthesizer calibration running
109#define RADIOLIB_CC1101_STATUS_SETTLING 0b01010000 // 6 4 PLL settling
110#define RADIOLIB_CC1101_STATUS_RXFIFO_OVERFLOW 0b01100000 // 6 4 Rx FIFO overflow
111#define RADIOLIB_CC1101_STATUS_TXFIFO_UNDERFLOW 0b01110000 // 6 4 Tx FIFO underflow
112
113// RADIOLIB_CC1101_REG_IOCFG2
114#define RADIOLIB_CC1101_GDO2_NORM 0b00000000 // 6 6 GDO2 output: active high (default)
115#define RADIOLIB_CC1101_GDO2_INV 0b01000000 // 6 6 active low
116
117// RADIOLIB_CC1101_REG_IOCFG1
118#define RADIOLIB_CC1101_GDO_DS_LOW 0b00000000 // 7 7 GDOx output drive strength: low (default)
119#define RADIOLIB_CC1101_GDO_DS_HIGH 0b10000000 // 7 7 high
120#define RADIOLIB_CC1101_GDO1_NORM 0b00000000 // 6 6 GDO1 output: active high (default)
121#define RADIOLIB_CC1101_GDO1_INV 0b01000000 // 6 6 active low
122
123// RADIOLIB_CC1101_REG_IOCFG0
124#define RADIOLIB_CC1101_GDO0_TEMP_SENSOR_OFF 0b00000000 // 7 7 analog temperature sensor output: disabled (default)
125#define RADIOLIB_CC1101_GDO0_TEMP_SENSOR_ON 0b10000000 // 7 7 enabled
126#define RADIOLIB_CC1101_GDO0_NORM 0b00000000 // 6 6 GDO0 output: active high (default)
127#define RADIOLIB_CC1101_GDO0_INV 0b01000000 // 6 6 active low
128
129// RADIOLIB_CC1101_REG_IOCFG2 + REG_IOCFG1 + REG_IOCFG0
130#define RADIOLIB_CC1101_GDOX_RX_FIFO_FULL 0x00 // 5 0 Rx FIFO full or above threshold
131#define RADIOLIB_CC1101_GDOX_RX_FIFO_FULL_OR_PKT_END 0x01 // 5 0 Rx FIFO full or above threshold or reached packet end
132#define RADIOLIB_CC1101_GDOX_TX_FIFO_ABOVE_THR 0x02 // 5 0 Tx FIFO above threshold
133#define RADIOLIB_CC1101_GDOX_TX_FIFO_FULL 0x03 // 5 0 Tx FIFO full
134#define RADIOLIB_CC1101_GDOX_RX_FIFO_OVERFLOW 0x04 // 5 0 Rx FIFO overflowed
135#define RADIOLIB_CC1101_GDOX_TX_FIFO_UNDERFLOW 0x05 // 5 0 Tx FIFO underflowed
136#define RADIOLIB_CC1101_GDOX_SYNC_WORD_SENT_OR_PKT_RECEIVED 0x06 // 5 0 sync word was sent or packet was received
137#define RADIOLIB_CC1101_GDOX_PKT_RECEIVED_CRC_OK 0x07 // 5 0 packet received and CRC check passed
138#define RADIOLIB_CC1101_GDOX_PREAMBLE_QUALITY_REACHED 0x08 // 5 0 received preamble quality is above threshold
139#define RADIOLIB_CC1101_GDOX_CHANNEL_CLEAR 0x09 // 5 0 RSSI level below threshold (channel is clear)
140#define RADIOLIB_CC1101_GDOX_PLL_LOCKED 0x0A // 5 0 PLL is locked
141#define RADIOLIB_CC1101_GDOX_SERIAL_CLOCK 0x0B // 5 0 serial data clock
142#define RADIOLIB_CC1101_GDOX_SERIAL_DATA_SYNC 0x0C // 5 0 serial data output in: synchronous mode
143#define RADIOLIB_CC1101_GDOX_SERIAL_DATA_ASYNC 0x0D // 5 0 asynchronous mode
144#define RADIOLIB_CC1101_GDOX_CARRIER_SENSE 0x0E // 5 0 RSSI above threshold
145#define RADIOLIB_CC1101_GDOX_CRC_OK 0x0F // 5 0 CRC check passed
146#define RADIOLIB_CC1101_GDOX_RX_HARD_DATA1 0x16 // 5 0 direct access to demodulated data
147#define RADIOLIB_CC1101_GDOX_RX_HARD_DATA0 0x17 // 5 0 direct access to demodulated data
148#define RADIOLIB_CC1101_GDOX_PA_PD 0x1B // 5 0 power amplifier circuit is powered down
149#define RADIOLIB_CC1101_GDOX_LNA_PD 0x1C // 5 0 low-noise amplifier circuit is powered down
150#define RADIOLIB_CC1101_GDOX_RX_SYMBOL_TICK 0x1D // 5 0 direct access to symbol tick of received data
151#define RADIOLIB_CC1101_GDOX_WOR_EVNT0 0x24 // 5 0 wake-on-radio event 0
152#define RADIOLIB_CC1101_GDOX_WOR_EVNT1 0x25 // 5 0 wake-on-radio event 1
153#define RADIOLIB_CC1101_GDOX_CLK_256 0x26 // 5 0 256 Hz clock
154#define RADIOLIB_CC1101_GDOX_CLK_32K 0x27 // 5 0 32 kHz clock
155#define RADIOLIB_CC1101_GDOX_CHIP_RDYN 0x29 // 5 0 (default for GDO2)
156#define RADIOLIB_CC1101_GDOX_XOSC_STABLE 0x2B // 5 0
157#define RADIOLIB_CC1101_GDOX_HIGH_Z 0x2E // 5 0 high impedance state (default for GDO1)
158#define RADIOLIB_CC1101_GDOX_HW_TO_0 0x2F // 5 0
159#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_1 0x30 // 5 0 crystal oscillator clock: f = f(XOSC)/1
160#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_1_5 0x31 // 5 0 f = f(XOSC)/1.5
161#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_2 0x32 // 5 0 f = f(XOSC)/2
162#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_3 0x33 // 5 0 f = f(XOSC)/3
163#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_4 0x34 // 5 0 f = f(XOSC)/4
164#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_6 0x35 // 5 0 f = f(XOSC)/6
165#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_8 0x36 // 5 0 f = f(XOSC)/8
166#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_12 0x37 // 5 0 f = f(XOSC)/12
167#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_16 0x38 // 5 0 f = f(XOSC)/16
168#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_24 0x39 // 5 0 f = f(XOSC)/24
169#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_32 0x3A // 5 0 f = f(XOSC)/32
170#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_48 0x3B // 5 0 f = f(XOSC)/48
171#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_64 0x3C // 5 0 f = f(XOSC)/64
172#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_96 0x3D // 5 0 f = f(XOSC)/96
173#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_128 0x3E // 5 0 f = f(XOSC)/128
174#define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_192 0x3F // 5 0 f = f(XOSC)/192 (default for GDO0)
175
176// RADIOLIB_CC1101_REG_FIFOTHR
177#define RADIOLIB_CC1101_ADC_RETENTION_OFF 0b00000000 // 6 6 do not retain ADC settings in sleep mode (default)
178#define RADIOLIB_CC1101_ADC_RETENTION_ON 0b01000000 // 6 6 retain ADC settings in sleep mode
179#define RADIOLIB_CC1101_RX_ATTEN_0_DB 0b00000000 // 5 4 Rx attenuation: 0 dB (default)
180#define RADIOLIB_CC1101_RX_ATTEN_6_DB 0b00010000 // 5 4 6 dB
181#define RADIOLIB_CC1101_RX_ATTEN_12_DB 0b00100000 // 5 4 12 dB
182#define RADIOLIB_CC1101_RX_ATTEN_18_DB 0b00110000 // 5 4 18 dB
183#define RADIOLIB_CC1101_FIFO_THR_TX_61_RX_4 0b00000000 // 3 0 TX fifo threshold: 61, RX fifo threshold: 4
184#define RADIOLIB_CC1101_FIFO_THR_TX_33_RX_32 0b00000111 // 3 0 TX fifo threshold: 33, RX fifo threshold: 32
185#define RADIOLIB_CC1101_FIFO_THRESH_TX 33
186#define RADIOLIB_CC1101_FIFO_THRESH_RX 32
187
188// RADIOLIB_CC1101_REG_SYNC1
189#define RADIOLIB_CC1101_SYNC_WORD_MSB 0xD3 // 7 0 sync word MSB
190
191// RADIOLIB_CC1101_REG_SYNC0
192#define RADIOLIB_CC1101_SYNC_WORD_LSB 0x91 // 7 0 sync word LSB
193
194// RADIOLIB_CC1101_REG_PKTCTRL1
195#define RADIOLIB_CC1101_PQT 0x00 // 7 5 preamble quality threshold
196#define RADIOLIB_CC1101_CRC_AUTOFLUSH_OFF 0b00000000 // 3 3 automatic Rx FIFO flush on CRC check fail: disabled (default)
197#define RADIOLIB_CC1101_CRC_AUTOFLUSH_ON 0b00001000 // 3 3 enabled
198#define RADIOLIB_CC1101_APPEND_STATUS_OFF 0b00000000 // 2 2 append 2 status bytes to packet: disabled
199#define RADIOLIB_CC1101_APPEND_STATUS_ON 0b00000100 // 2 2 enabled (default)
200#define RADIOLIB_CC1101_ADR_CHK_NONE 0b00000000 // 1 0 address check: none (default)
201#define RADIOLIB_CC1101_ADR_CHK_NO_BROADCAST 0b00000001 // 1 0 without broadcast
202#define RADIOLIB_CC1101_ADR_CHK_SINGLE_BROADCAST 0b00000010 // 1 0 broadcast address 0x00
203#define RADIOLIB_CC1101_ADR_CHK_DOUBLE_BROADCAST 0b00000011 // 1 0 broadcast addresses 0x00 and 0xFF
204
205// RADIOLIB_CC1101_REG_PKTCTRL0
206#define RADIOLIB_CC1101_WHITE_DATA_OFF 0b00000000 // 6 6 data whitening: disabled
207#define RADIOLIB_CC1101_WHITE_DATA_ON 0b01000000 // 6 6 enabled (default)
208#define RADIOLIB_CC1101_PKT_FORMAT_NORMAL 0b00000000 // 5 4 packet format: normal (FIFOs)
209#define RADIOLIB_CC1101_PKT_FORMAT_SYNCHRONOUS 0b00010000 // 5 4 synchronous serial
210#define RADIOLIB_CC1101_PKT_FORMAT_RANDOM 0b00100000 // 5 4 random transmissions
211#define RADIOLIB_CC1101_PKT_FORMAT_ASYNCHRONOUS 0b00110000 // 5 4 asynchronous serial
212#define RADIOLIB_CC1101_CRC_OFF 0b00000000 // 2 2 CRC disabled
213#define RADIOLIB_CC1101_CRC_ON 0b00000100 // 2 2 CRC enabled (default)
214#define RADIOLIB_CC1101_LENGTH_CONFIG_FIXED 0b00000000 // 1 0 packet length: fixed
215#define RADIOLIB_CC1101_LENGTH_CONFIG_VARIABLE 0b00000001 // 1 0 variable (default)
216#define RADIOLIB_CC1101_LENGTH_CONFIG_INFINITE 0b00000010 // 1 0 infinite
217
218// RADIOLIB_CC1101_REG_ADDR
219#define RADIOLIB_CC1101_DEVICE_ADDR 0x00 // 7 0 device address
220
221// RADIOLIB_CC1101_REG_CHANNR
222#define RADIOLIB_CC1101_CHAN 0x00 // 7 0 channel number
223
224// RADIOLIB_CC1101_REG_FSCTRL1
225#define RADIOLIB_CC1101_FREQ_IF 0x0F // 4 0 IF frequency setting; f_IF = (f(XOSC) / 2^10) * CC1101_FREQ_IF
226
227// CC1101_REG_FSCTRL0
228#define RADIOLIB_CC1101_FREQOFF 0x00 // 7 0 base frequency offset (2s-compliment)
229
230// RADIOLIB_CC1101_REG_FREQ2 + REG_FREQ1 + REG_FREQ0
231#define RADIOLIB_CC1101_FREQ_MSB 0x1E // 5 0 base frequency setting: f_carrier = (f(XOSC) / 2^16) * FREQ
232#define RADIOLIB_CC1101_FREQ_MID 0xC4 // 7 0 where f(XOSC) = 26 MHz
233#define RADIOLIB_CC1101_FREQ_LSB 0xEC // 7 0 FREQ = 3-byte value of FREQ registers
234
235// RADIOLIB_CC1101_REG_MDMCFG4
236#define RADIOLIB_CC1101_CHANBW_E 0b10000000 // 7 6 channel bandwidth: BW_channel = f(XOSC) / (8 * (4 + CHANBW_M)*2^CHANBW_E) [Hz]
237#define RADIOLIB_CC1101_CHANBW_M 0b00000000 // 5 4 default value for 26 MHz crystal: 203 125 Hz
238#define RADIOLIB_CC1101_DRATE_E 0x0C // 3 0 symbol rate: R_data = (((256 + DRATE_M) * 2^DRATE_E) / 2^28) * f(XOSC) [Baud]
239
240// RADIOLIB_CC1101_REG_MDMCFG3
241#define RADIOLIB_CC1101_DRATE_M 0x22 // 7 0 default value for 26 MHz crystal: 115 051 Baud
242
243// RADIOLIB_CC1101_REG_MDMCFG2
244#define RADIOLIB_CC1101_DEM_DCFILT_OFF 0b10000000 // 7 7 digital DC filter: disabled
245#define RADIOLIB_CC1101_DEM_DCFILT_ON 0b00000000 // 7 7 enabled - only for data rates above 250 kBaud (default)
246#define RADIOLIB_CC1101_MOD_FORMAT_2_FSK 0b00000000 // 6 4 modulation format: 2-FSK (default)
247#define RADIOLIB_CC1101_MOD_FORMAT_GFSK 0b00010000 // 6 4 GFSK
248#define RADIOLIB_CC1101_MOD_FORMAT_ASK_OOK 0b00110000 // 6 4 ASK/OOK
249#define RADIOLIB_CC1101_MOD_FORMAT_4_FSK 0b01000000 // 6 4 4-FSK
250#define RADIOLIB_CC1101_MOD_FORMAT_MFSK 0b01110000 // 6 4 MFSK - only for data rates above 26 kBaud
251#define RADIOLIB_CC1101_MANCHESTER_EN_OFF 0b00000000 // 3 3 Manchester encoding: disabled (default)
252#define RADIOLIB_CC1101_MANCHESTER_EN_ON 0b00001000 // 3 3 enabled
253#define RADIOLIB_CC1101_SYNC_MODE_NONE 0b00000000 // 2 0 synchronization: no preamble/sync
254#define RADIOLIB_CC1101_SYNC_MODE_15_16 0b00000001 // 2 0 15/16 sync word bits
255#define RADIOLIB_CC1101_SYNC_MODE_16_16 0b00000010 // 2 0 16/16 sync word bits (default)
256#define RADIOLIB_CC1101_SYNC_MODE_30_32 0b00000011 // 2 0 30/32 sync word bits
257#define RADIOLIB_CC1101_SYNC_MODE_NONE_THR 0b00000100 // 2 0 no preamble sync, carrier sense above threshold
258#define RADIOLIB_CC1101_SYNC_MODE_15_16_THR 0b00000101 // 2 0 15/16 sync word bits, carrier sense above threshold
259#define RADIOLIB_CC1101_SYNC_MODE_16_16_THR 0b00000110 // 2 0 16/16 sync word bits, carrier sense above threshold
260#define RADIOLIB_CC1101_SYNC_MODE_30_32_THR 0b00000111 // 2 0 30/32 sync word bits, carrier sense above threshold
261
262// RADIOLIB_CC1101_REG_MDMCFG1
263#define RADIOLIB_CC1101_FEC_OFF 0b00000000 // 7 7 forward error correction: disabled (default)
264#define RADIOLIB_CC1101_FEC_ON 0b10000000 // 7 7 enabled - only for fixed packet length
265#define RADIOLIB_CC1101_NUM_PREAMBLE_2 0b00000000 // 6 4 number of preamble bytes: 2
266#define RADIOLIB_CC1101_NUM_PREAMBLE_3 0b00010000 // 6 4 3
267#define RADIOLIB_CC1101_NUM_PREAMBLE_4 0b00100000 // 6 4 4 (default)
268#define RADIOLIB_CC1101_NUM_PREAMBLE_6 0b00110000 // 6 4 6
269#define RADIOLIB_CC1101_NUM_PREAMBLE_8 0b01000000 // 6 4 8
270#define RADIOLIB_CC1101_NUM_PREAMBLE_12 0b01010000 // 6 4 12
271#define RADIOLIB_CC1101_NUM_PREAMBLE_16 0b01100000 // 6 4 16
272#define RADIOLIB_CC1101_NUM_PREAMBLE_24 0b01110000 // 6 4 24
273#define RADIOLIB_CC1101_CHANSPC_E 0x02 // 1 0 channel spacing: df_channel = (f(XOSC) / 2^18) * (256 + CHANSPC_M) * 2^CHANSPC_E [Hz]
274
275// RADIOLIB_CC1101_REG_MDMCFG0
276#define RADIOLIB_CC1101_CHANSPC_M 0xF8 // 7 0 default value for 26 MHz crystal: 199 951 kHz
277
278// RADIOLIB_CC1101_REG_DEVIATN
279#define RADIOLIB_CC1101_DEVIATION_E 0b01000000 // 6 4 frequency deviation: f_dev = (f(XOSC) / 2^17) * (8 + DEVIATION_M) * 2^DEVIATION_E [Hz]
280#define RADIOLIB_CC1101_DEVIATION_M 0b00000111 // 2 0 default value for 26 MHz crystal: +- 47 607 Hz
281#define RADIOLIB_CC1101_MSK_PHASE_CHANGE_PERIOD 0x07 // 2 0 phase change symbol period fraction: 1 / (MSK_PHASE_CHANGE_PERIOD + 1)
282
283// RADIOLIB_CC1101_REG_MCSM2
284#define RADIOLIB_CC1101_RX_TIMEOUT_RSSI_OFF 0b00000000 // 4 4 Rx timeout based on RSSI value: disabled (default)
285#define RADIOLIB_CC1101_RX_TIMEOUT_RSSI_ON 0b00010000 // 4 4 enabled
286#define RADIOLIB_CC1101_RX_TIMEOUT_QUAL_OFF 0b00000000 // 3 3 check for sync word on Rx timeout
287#define RADIOLIB_CC1101_RX_TIMEOUT_QUAL_ON 0b00001000 // 3 3 check for PQI set on Rx timeout
288#define RADIOLIB_CC1101_RX_TIMEOUT_OFF 0b00000111 // 2 0 Rx timeout: disabled (default)
289#define RADIOLIB_CC1101_RX_TIMEOUT_MAX 0b00000000 // 2 0 max value (actual value depends on WOR_RES, EVENT0 and f(XOSC))
290
291// RADIOLIB_CC1101_REG_MCSM1
292#define RADIOLIB_CC1101_CCA_MODE_ALWAYS 0b00000000 // 5 4 clear channel indication: always
293#define RADIOLIB_CC1101_CCA_MODE_RSSI_THR 0b00010000 // 5 4 RSSI below threshold
294#define RADIOLIB_CC1101_CCA_MODE_RX_PKT 0b00100000 // 5 4 unless receiving packet
295#define RADIOLIB_CC1101_CCA_MODE_RSSI_THR_RX_PKT 0b00110000 // 5 4 RSSI below threshold unless receiving packet (default)
296#define RADIOLIB_CC1101_RXOFF_IDLE 0b00000000 // 3 2 next mode after packet reception: idle (default)
297#define RADIOLIB_CC1101_RXOFF_FSTXON 0b00000100 // 3 2 FSTxOn
298#define RADIOLIB_CC1101_RXOFF_TX 0b00001000 // 3 2 Tx
299#define RADIOLIB_CC1101_RXOFF_RX 0b00001100 // 3 2 Rx
300#define RADIOLIB_CC1101_TXOFF_IDLE 0b00000000 // 1 0 next mode after packet transmission: idle (default)
301#define RADIOLIB_CC1101_TXOFF_FSTXON 0b00000001 // 1 0 FSTxOn
302#define RADIOLIB_CC1101_TXOFF_TX 0b00000010 // 1 0 Tx
303#define RADIOLIB_CC1101_TXOFF_RX 0b00000011 // 1 0 Rx
304
305// RADIOLIB_CC1101_REG_MCSM0
306#define RADIOLIB_CC1101_FS_AUTOCAL_NEVER 0b00000000 // 5 4 automatic calibration: never (default)
307#define RADIOLIB_CC1101_FS_AUTOCAL_IDLE_TO_RXTX 0b00010000 // 5 4 every transition from idle to Rx/Tx
308#define RADIOLIB_CC1101_FS_AUTOCAL_RXTX_TO_IDLE 0b00100000 // 5 4 every transition from Rx/Tx to idle
309#define RADIOLIB_CC1101_FS_AUTOCAL_RXTX_TO_IDLE_4TH 0b00110000 // 5 4 every 4th transition from Rx/Tx to idle
310#define RADIOLIB_CC1101_PO_TIMEOUT_COUNT_1 0b00000000 // 3 2 number of counter expirations before CHP_RDYN goes low: 1 (default)
311#define RADIOLIB_CC1101_PO_TIMEOUT_COUNT_16 0b00000100 // 3 2 16
312#define RADIOLIB_CC1101_PO_TIMEOUT_COUNT_64 0b00001000 // 3 2 64
313#define RADIOLIB_CC1101_PO_TIMEOUT_COUNT_256 0b00001100 // 3 2 256
314#define RADIOLIB_CC1101_PIN_CTRL_OFF 0b00000000 // 1 1 pin radio control: disabled (default)
315#define RADIOLIB_CC1101_PIN_CTRL_ON 0b00000010 // 1 1 enabled
316#define RADIOLIB_CC1101_XOSC_FORCE_OFF 0b00000000 // 0 0 do not force XOSC to remain on in sleep (default)
317#define RADIOLIB_CC1101_XOSC_FORCE_ON 0b00000001 // 0 0 force XOSC to remain on in sleep
318
319// RADIOLIB_CC1101_REG_FOCCFG
320#define RADIOLIB_CC1101_FOC_BS_CS_GATE_OFF 0b00000000 // 5 5 do not freeze frequency compensation until CS goes high
321#define RADIOLIB_CC1101_FOC_BS_CS_GATE_ON 0b00100000 // 5 5 freeze frequency compensation until CS goes high (default)
322#define RADIOLIB_CC1101_FOC_PRE_K 0b00000000 // 4 3 frequency compensation loop gain before sync word: K
323#define RADIOLIB_CC1101_FOC_PRE_2K 0b00001000 // 4 3 2K
324#define RADIOLIB_CC1101_FOC_PRE_3K 0b00010000 // 4 3 3K (default)
325#define RADIOLIB_CC1101_FOC_PRE_4K 0b00011000 // 4 3 4K
326#define RADIOLIB_CC1101_FOC_POST_K 0b00000000 // 2 2 frequency compensation loop gain after sync word: same as FOC_PRE
327#define RADIOLIB_CC1101_FOC_POST_K_2 0b00000100 // 2 2 K/2 (default)
328#define RADIOLIB_CC1101_FOC_LIMIT_NO_COMPENSATION 0b00000000 // 1 0 frequency compensation saturation point: no compensation - required for ASK/OOK
329#define RADIOLIB_CC1101_FOC_LIMIT_BW_CHAN_8 0b00000001 // 1 0 +- BW_chan/8
330#define RADIOLIB_CC1101_FOC_LIMIT_BW_CHAN_4 0b00000010 // 1 0 +- BW_chan/4 (default)
331#define RADIOLIB_CC1101_FOC_LIMIT_BW_CHAN_2 0b00000011 // 1 0 +- BW_chan/2
332
333// RADIOLIB_CC1101_REG_BSCFG
334#define RADIOLIB_CC1101_BS_PRE_KI 0b00000000 // 7 6 clock recovery integral gain before sync word: Ki
335#define RADIOLIB_CC1101_BS_PRE_2KI 0b01000000 // 7 6 2Ki (default)
336#define RADIOLIB_CC1101_BS_PRE_3KI 0b10000000 // 7 6 3Ki
337#define RADIOLIB_CC1101_BS_PRE_4KI 0b11000000 // 7 6 4Ki
338#define RADIOLIB_CC1101_BS_PRE_KP 0b00000000 // 5 4 clock recovery proportional gain before sync word: Kp
339#define RADIOLIB_CC1101_BS_PRE_2KP 0b00010000 // 5 4 2Kp
340#define RADIOLIB_CC1101_BS_PRE_3KP 0b00100000 // 5 4 3Kp (default)
341#define RADIOLIB_CC1101_BS_PRE_4KP 0b00110000 // 5 4 4Kp
342#define RADIOLIB_CC1101_BS_POST_KI 0b00000000 // 3 3 clock recovery integral gain after sync word: same as BS_PRE
343#define RADIOLIB_CC1101_BS_POST_KI_2 0b00001000 // 3 3 Ki/2 (default)
344#define RADIOLIB_CC1101_BS_POST_KP 0b00000000 // 2 2 clock recovery proportional gain after sync word: same as BS_PRE
345#define RADIOLIB_CC1101_BS_POST_KP_1 0b00000100 // 2 2 Kp (default)
346#define RADIOLIB_CC1101_BS_LIMIT_NO_COMPENSATION 0b00000000 // 1 0 data rate compensation saturation point: no compensation
347#define RADIOLIB_CC1101_BS_LIMIT_3_125 0b00000001 // 1 0 +- 3.125 %
348#define RADIOLIB_CC1101_BS_LIMIT_6_25 0b00000010 // 1 0 +- 6.25 %
349#define RADIOLIB_CC1101_BS_LIMIT_12_5 0b00000011 // 1 0 +- 12.5 %
350
351// RADIOLIB_CC1101_REG_AGCCTRL2
352#define RADIOLIB_CC1101_MAX_DVGA_GAIN_0 0b00000000 // 7 6 reduce maximum available DVGA gain: no reduction (default)
353#define RADIOLIB_CC1101_MAX_DVGA_GAIN_1 0b01000000 // 7 6 disable top gain setting
354#define RADIOLIB_CC1101_MAX_DVGA_GAIN_2 0b10000000 // 7 6 disable top two gain setting
355#define RADIOLIB_CC1101_MAX_DVGA_GAIN_3 0b11000000 // 7 6 disable top three gain setting
356#define RADIOLIB_CC1101_LNA_GAIN_REDUCE_0_DB 0b00000000 // 5 3 reduce maximum LNA gain by: 0 dB (default)
357#define RADIOLIB_CC1101_LNA_GAIN_REDUCE_2_6_DB 0b00001000 // 5 3 2.6 dB
358#define RADIOLIB_CC1101_LNA_GAIN_REDUCE_6_1_DB 0b00010000 // 5 3 6.1 dB
359#define RADIOLIB_CC1101_LNA_GAIN_REDUCE_7_4_DB 0b00011000 // 5 3 7.4 dB
360#define RADIOLIB_CC1101_LNA_GAIN_REDUCE_9_2_DB 0b00100000 // 5 3 9.2 dB
361#define RADIOLIB_CC1101_LNA_GAIN_REDUCE_11_5_DB 0b00101000 // 5 3 11.5 dB
362#define RADIOLIB_CC1101_LNA_GAIN_REDUCE_14_6_DB 0b00110000 // 5 3 14.6 dB
363#define RADIOLIB_CC1101_LNA_GAIN_REDUCE_17_1_DB 0b00111000 // 5 3 17.1 dB
364#define RADIOLIB_CC1101_MAGN_TARGET_24_DB 0b00000000 // 2 0 average amplitude target for filter: 24 dB
365#define RADIOLIB_CC1101_MAGN_TARGET_27_DB 0b00000001 // 2 0 27 dB
366#define RADIOLIB_CC1101_MAGN_TARGET_30_DB 0b00000010 // 2 0 30 dB
367#define RADIOLIB_CC1101_MAGN_TARGET_33_DB 0b00000011 // 2 0 33 dB (default)
368#define RADIOLIB_CC1101_MAGN_TARGET_36_DB 0b00000100 // 2 0 36 dB
369#define RADIOLIB_CC1101_MAGN_TARGET_38_DB 0b00000101 // 2 0 38 dB
370#define RADIOLIB_CC1101_MAGN_TARGET_40_DB 0b00000110 // 2 0 40 dB
371#define RADIOLIB_CC1101_MAGN_TARGET_42_DB 0b00000111 // 2 0 42 dB
372
373// RADIOLIB_CC1101_REG_AGCCTRL1
374#define RADIOLIB_CC1101_AGC_LNA_PRIORITY_LNA2 0b00000000 // 6 6 LNA priority setting: LNA2 first
375#define RADIOLIB_CC1101_AGC_LNA_PRIORITY_LNA 0b01000000 // 6 6 LNA first (default)
376#define RADIOLIB_CC1101_CARRIER_SENSE_REL_THR_OFF 0b00000000 // 5 4 RSSI relative change to assert carrier sense: disabled (default)
377#define RADIOLIB_CC1101_CARRIER_SENSE_REL_THR_6_DB 0b00010000 // 5 4 6 dB
378#define RADIOLIB_CC1101_CARRIER_SENSE_REL_THR_10_DB 0b00100000 // 5 4 10 dB
379#define RADIOLIB_CC1101_CARRIER_SENSE_REL_THR_14_DB 0b00110000 // 5 4 14 dB
380#define RADIOLIB_CC1101_CARRIER_SENSE_ABS_THR 0x00 // 3 0 RSSI threshold to assert carrier sense in 2s compliment, Thr = MAGN_TARGET + CARRIER_SENSE_ABS_TH [dB]
381
382// RADIOLIB_CC1101_REG_AGCCTRL0
383#define RADIOLIB_CC1101_HYST_LEVEL_NONE 0b00000000 // 7 6 AGC hysteresis level: none
384#define RADIOLIB_CC1101_HYST_LEVEL_LOW 0b01000000 // 7 6 low
385#define RADIOLIB_CC1101_HYST_LEVEL_MEDIUM 0b10000000 // 7 6 medium (default)
386#define RADIOLIB_CC1101_HYST_LEVEL_HIGH 0b11000000 // 7 6 high
387#define RADIOLIB_CC1101_WAIT_TIME_8_SAMPLES 0b00000000 // 5 4 AGC wait time: 8 samples
388#define RADIOLIB_CC1101_WAIT_TIME_16_SAMPLES 0b00010000 // 5 4 16 samples (default)
389#define RADIOLIB_CC1101_WAIT_TIME_24_SAMPLES 0b00100000 // 5 4 24 samples
390#define RADIOLIB_CC1101_WAIT_TIME_32_SAMPLES 0b00110000 // 5 4 32 samples
391#define RADIOLIB_CC1101_AGC_FREEZE_NEVER 0b00000000 // 3 2 freeze AGC gain: never (default)
392#define RADIOLIB_CC1101_AGC_FREEZE_SYNC_WORD 0b00000100 // 3 2 when sync word is found
393#define RADIOLIB_CC1101_AGC_FREEZE_MANUAL_A 0b00001000 // 3 2 manually freeze analog control
394#define RADIOLIB_CC1101_AGC_FREEZE_MANUAL_AD 0b00001100 // 3 2 manually freeze analog and digital control
395#define RADIOLIB_CC1101_FILTER_LENGTH_8 0b00000000 // 1 0 averaging length for channel filter: 8 samples
396#define RADIOLIB_CC1101_FILTER_LENGTH_16 0b00000001 // 1 0 16 samples (default)
397#define RADIOLIB_CC1101_FILTER_LENGTH_32 0b00000010 // 1 0 32 samples
398#define RADIOLIB_CC1101_FILTER_LENGTH_64 0b00000011 // 1 0 64 samples
399#define RADIOLIB_CC1101_ASK_OOK_BOUNDARY_4_DB 0b00000000 // 1 0 ASK/OOK decision boundary: 4 dB
400#define RADIOLIB_CC1101_ASK_OOK_BOUNDARY_8_DB 0b00000001 // 1 0 8 dB (default)
401#define RADIOLIB_CC1101_ASK_OOK_BOUNDARY_12_DB 0b00000010 // 1 0 12 dB
402#define RADIOLIB_CC1101_ASK_OOK_BOUNDARY_16_DB 0b00000011 // 1 0 16 dB
403
404// RADIOLIB_CC1101_REG_WOREVT1 + REG_WOREVT0
405#define RADIOLIB_CC1101_EVENT0_TIMEOUT_MSB 0x87 // 7 0 EVENT0 timeout: t_event0 = (750 / f(XOSC)) * EVENT0_TIMEOUT * 2^(5 * WOR_RES) [s]
406#define RADIOLIB_CC1101_EVENT0_TIMEOUT_LSB 0x6B // 7 0 default value for 26 MHz crystal: 1.0 s
407
408// RADIOLIB_CC1101_REG_WORCTRL
409#define RADIOLIB_CC1101_RC_POWER_UP 0b00000000 // 7 7 power up RC oscillator
410#define RADIOLIB_CC1101_RC_POWER_DOWN 0b10000000 // 7 7 power down RC oscillator
411#define RADIOLIB_CC1101_EVENT1_TIMEOUT_4 0b00000000 // 6 4 EVENT1 timeout: 4 RC periods
412#define RADIOLIB_CC1101_EVENT1_TIMEOUT_6 0b00010000 // 6 4 6 RC periods
413#define RADIOLIB_CC1101_EVENT1_TIMEOUT_8 0b00100000 // 6 4 8 RC periods
414#define RADIOLIB_CC1101_EVENT1_TIMEOUT_12 0b00110000 // 6 4 12 RC periods
415#define RADIOLIB_CC1101_EVENT1_TIMEOUT_16 0b01000000 // 6 4 16 RC periods
416#define RADIOLIB_CC1101_EVENT1_TIMEOUT_24 0b01010000 // 6 4 24 RC periods
417#define RADIOLIB_CC1101_EVENT1_TIMEOUT_32 0b01100000 // 6 4 32 RC periods
418#define RADIOLIB_CC1101_EVENT1_TIMEOUT_48 0b01110000 // 6 4 48 RC periods (default)
419#define RADIOLIB_CC1101_RC_CAL_OFF 0b00000000 // 3 3 disable RC oscillator calibration
420#define RADIOLIB_CC1101_RC_CAL_ON 0b00001000 // 3 3 enable RC oscillator calibration (default)
421#define RADIOLIB_CC1101_WOR_RES_1 0b00000000 // 1 0 EVENT0 resolution: 1 period (default)
422#define RADIOLIB_CC1101_WOR_RES_2_5 0b00000001 // 1 0 2^5 periods
423#define RADIOLIB_CC1101_WOR_RES_2_10 0b00000010 // 1 0 2^10 periods
424#define RADIOLIB_CC1101_WOR_RES_2_15 0b00000011 // 1 0 2^15 periods
425
426// RADIOLIB_CC1101_REG_FREND1
427#define RADIOLIB_CC1101_LNA_CURRENT 0x01 // 7 6 front-end LNA PTAT current output adjustment
428#define RADIOLIB_CC1101_LNA2MIX_CURRENT 0x01 // 5 4 front-end PTAT output adjustment
429#define RADIOLIB_CC1101_LODIV_BUF_CURRENT_RX 0x01 // 3 2 Rx LO buffer current adjustment
430#define RADIOLIB_CC1101_MIX_CURRENT 0x02 // 1 0 mixer current adjustment
431
432// RADIOLIB_CC1101_REG_FREND0
433#define RADIOLIB_CC1101_LODIV_BUF_CURRENT_TX 0x01 // 5 4 Tx LO buffer current adjustment
434#define RADIOLIB_CC1101_PA_POWER 0x00 // 2 0 set power amplifier power according to PATABLE
435
436// RADIOLIB_CC1101_REG_FSCAL3
437#define RADIOLIB_CC1101_CHP_CURR_CAL_OFF 0b00000000 // 5 4 disable charge pump calibration
438#define RADIOLIB_CC1101_CHP_CURR_CAL_ON 0b00100000 // 5 4 enable charge pump calibration (default)
439#define RADIOLIB_CC1101_FSCAL3 0x09 // 3 0 charge pump output current: I_out = I_0 * 2^(FSCAL3/4) [A]
440
441// RADIOLIB_CC1101_REG_FSCAL2
442#define RADIOLIB_CC1101_VCO_CORE_LOW 0b00000000 // 5 5 VCO: low (default)
443#define RADIOLIB_CC1101_VCO_CORE_HIGH 0b00100000 // 5 5 high
444#define RADIOLIB_CC1101_FSCAL2 0x0A // 4 0 VCO current result/override
445
446// RADIOLIB_CC1101_REG_FSCAL1
447#define RADIOLIB_CC1101_FSCAL1 0x20 // 5 0 capacitor array setting for coarse VCO tuning
448
449// RADIOLIB_CC1101_REG_FSCAL0
450#define RADIOLIB_CC1101_FSCAL0 0x0D // 6 0 frequency synthesizer calibration setting
451
452// RADIOLIB_CC1101_REG_RCCTRL1
453#define RADIOLIB_CC1101_RCCTRL1 0x41 // 6 0 RC oscillator configuration
454
455// RADIOLIB_CC1101_REG_RCCTRL0
456#define RADIOLIB_CC1101_RCCTRL0 0x00 // 6 0 RC oscillator configuration
457
458// RADIOLIB_CC1101_REG_PTEST
459#define RADIOLIB_CC1101_TEMP_SENS_IDLE_OFF 0x7F // 7 0 temperature sensor will not be available in idle mode (default)
460#define RADIOLIB_CC1101_TEMP_SENS_IDLE_ON 0xBF // 7 0 temperature sensor will be available in idle mode
461
462// RADIOLIB_CC1101_REG_TEST0
463#define RADIOLIB_CC1101_VCO_SEL_CAL_OFF 0b00000000 // 1 1 disable VCO selection calibration stage
464#define RADIOLIB_CC1101_VCO_SEL_CAL_ON 0b00000010 // 1 1 enable VCO selection calibration stage
465
466// RADIOLIB_CC1101_REG_PARTNUM
467#define RADIOLIB_CC1101_PARTNUM 0x00
468
469// RADIOLIB_CC1101_REG_VERSION
470#define RADIOLIB_CC1101_VERSION_CURRENT 0x14
471#define RADIOLIB_CC1101_VERSION_LEGACY 0x04
472#define RADIOLIB_CC1101_VERSION_CLONE 0x17
473
474// RADIOLIB_CC1101_REG_MARCSTATE
475#define RADIOLIB_CC1101_MARC_STATE_SLEEP 0x00 // 4 0 main radio control state: sleep
476#define RADIOLIB_CC1101_MARC_STATE_IDLE 0x01 // 4 0 idle
477#define RADIOLIB_CC1101_MARC_STATE_XOFF 0x02 // 4 0 XOFF
478#define RADIOLIB_CC1101_MARC_STATE_VCOON_MC 0x03 // 4 0 VCOON_MC
479#define RADIOLIB_CC1101_MARC_STATE_REGON_MC 0x04 // 4 0 REGON_MC
480#define RADIOLIB_CC1101_MARC_STATE_MANCAL 0x05 // 4 0 MANCAL
481#define RADIOLIB_CC1101_MARC_STATE_VCOON 0x06 // 4 0 VCOON
482#define RADIOLIB_CC1101_MARC_STATE_REGON 0x07 // 4 0 REGON
483#define RADIOLIB_CC1101_MARC_STATE_STARTCAL 0x08 // 4 0 STARTCAL
484#define RADIOLIB_CC1101_MARC_STATE_BWBOOST 0x09 // 4 0 BWBOOST
485#define RADIOLIB_CC1101_MARC_STATE_FS_LOCK 0x0A // 4 0 FS_LOCK
486#define RADIOLIB_CC1101_MARC_STATE_IFADCON 0x0B // 4 0 IFADCON
487#define RADIOLIB_CC1101_MARC_STATE_ENDCAL 0x0C // 4 0 ENDCAL
488#define RADIOLIB_CC1101_MARC_STATE_RX 0x0D // 4 0 RX
489#define RADIOLIB_CC1101_MARC_STATE_RX_END 0x0E // 4 0 RX_END
490#define RADIOLIB_CC1101_MARC_STATE_RX_RST 0x0F // 4 0 RX_RST
491#define RADIOLIB_CC1101_MARC_STATE_TXRX_SWITCH 0x10 // 4 0 TXRX_SWITCH
492#define RADIOLIB_CC1101_MARC_STATE_RXFIFO_OVERFLOW 0x11 // 4 0 RXFIFO_OVERFLOW
493#define RADIOLIB_CC1101_MARC_STATE_FSTXON 0x12 // 4 0 FSTXON
494#define RADIOLIB_CC1101_MARC_STATE_TX 0x13 // 4 0 TX
495#define RADIOLIB_CC1101_MARC_STATE_TX_END 0x14 // 4 0 TX_END
496#define RADIOLIB_CC1101_MARC_STATE_RXTX_SWITCH 0x15 // 4 0 RXTX_SWITCH
497#define RADIOLIB_CC1101_MARC_STATE_TXFIFO_UNDERFLOW 0x16 // 4 0 TXFIFO_UNDERFLOW
498
499// RADIOLIB_CC1101_REG_WORTIME1 + REG_WORTIME0
500#define RADIOLIB_CC1101_WORTIME_MSB 0x00 // 7 0 WOR timer value
501#define RADIOLIB_CC1101_WORTIME_LSB 0x00 // 7 0
502
503// RADIOLIB_CC1101_REG_PKTSTATUS
504#define RADIOLIB_CC1101_CRC_OK 0b10000000 // 7 7 CRC check passed
505#define RADIOLIB_CC1101_CRC_ERROR 0b00000000 // 7 7 CRC check failed
506#define RADIOLIB_CC1101_CS 0b01000000 // 6 6 carrier sense
507#define RADIOLIB_CC1101_PQT_REACHED 0b00100000 // 5 5 preamble quality reached
508#define RADIOLIB_CC1101_CCA 0b00010000 // 4 4 channel clear
509#define RADIOLIB_CC1101_SFD 0b00001000 // 3 3 start of frame delimiter - sync word received
510#define RADIOLIB_CC1101_GDO2_ACTIVE 0b00000100 // 2 2 GDO2 is active/asserted
511#define RADIOLIB_CC1101_GDO0_ACTIVE 0b00000001 // 0 0 GDO0 is active/asserted
512
513// RadioLib defaults
514#define RADIOLIB_CC1101_DEFAULT_FREQ 434.0
515#define RADIOLIB_CC1101_DEFAULT_BR 4.8
516#define RADIOLIB_CC1101_DEFAULT_FREQDEV 5.0
517#define RADIOLIB_CC1101_DEFAULT_RXBW 58.0
518#define RADIOLIB_CC1101_DEFAULT_POWER 10
519#define RADIOLIB_CC1101_DEFAULT_PREAMBLELEN 16
520#define RADIOLIB_CC1101_DEFAULT_SW {0x12, 0xAD}
521#define RADIOLIB_CC1101_DEFAULT_SW_LEN 2
522
527class CC1101: public PhysicalLayer {
528 public:
529 // introduce PhysicalLayer overloads
534
539 // cppcheck-suppress noExplicitConstructor
540 CC1101(Module* module);
541
542 // basic methods
543
554 int16_t begin(
555 float freq = RADIOLIB_CC1101_DEFAULT_FREQ,
556 float br = RADIOLIB_CC1101_DEFAULT_BR,
557 float freqDev = RADIOLIB_CC1101_DEFAULT_FREQDEV,
558 float rxBw = RADIOLIB_CC1101_DEFAULT_RXBW,
559 int8_t pwr = RADIOLIB_CC1101_DEFAULT_POWER,
560 uint8_t preambleLength = RADIOLIB_CC1101_DEFAULT_PREAMBLELEN);
561
572 int16_t beginFSK4(
573 float freq = RADIOLIB_CC1101_DEFAULT_FREQ,
574 float br = RADIOLIB_CC1101_DEFAULT_BR,
575 float freqDev = RADIOLIB_CC1101_DEFAULT_FREQDEV,
576 float rxBw = RADIOLIB_CC1101_DEFAULT_RXBW,
577 int8_t pwr = RADIOLIB_CC1101_DEFAULT_POWER,
578 uint8_t preambleLength = RADIOLIB_CC1101_DEFAULT_PREAMBLELEN);
579
583 void reset();
584
593 int16_t transmit(const uint8_t* data, size_t len, uint8_t addr = 0) override;
594
602 int16_t receive(uint8_t* data, size_t len) override;
603
608 int16_t standby() override;
609
615 int16_t standby(uint8_t mode) override;
616
621 int16_t sleep() override;
622
628 int16_t transmitDirect(uint32_t frf = 0) override;
629
634 int16_t receiveDirect() override;
635
641 int16_t transmitDirectAsync(uint32_t frf = 0);
642
647 int16_t receiveDirectAsync();
648
653 int16_t packetMode();
654
655 // interrupt methods
656
662 void setGdo0Action(void (*func)(void), uint32_t dir);
663
667 void clearGdo0Action();
668
674 void setGdo2Action(void (*func)(void), uint32_t dir);
675
679 void clearGdo2Action();
680
685 void setPacketReceivedAction(void (*func)(void)) override;
686
690 void clearPacketReceivedAction() override;
691
696 void setPacketSentAction(void (*func)(void)) override;
697
701 void clearPacketSentAction() override;
702
711 int16_t startTransmit(const uint8_t* data, size_t len, uint8_t addr = 0) override;
712
717 int16_t finishTransmit() override;
718
723 int16_t startReceive() override;
724
733 int16_t startReceive(uint32_t timeout, uint32_t irqFlags, uint32_t irqMask, size_t len) override;
734
743 int16_t readData(uint8_t* data, size_t len) override;
744
745 // configuration methods
746
753 int16_t setFrequency(float freq) override;
754
760 int16_t setBitRate(float br) override;
761
767 int16_t setBitRateTolerance(uint8_t brt);
768
775 int16_t setRxBandwidth(float rxBw);
776
783 int16_t autoSetRxBandwidth();
784
790 int16_t setFrequencyDeviation(float freqDev) override;
791
797 int16_t getFrequencyDeviation(float *freqDev);
798
804 int16_t setOutputPower(int8_t pwr) override;
805
813 int16_t checkOutputPower(int8_t power, int8_t* clipped) override;
814
822 int16_t checkOutputPower(int8_t power, int8_t* clipped, uint8_t* raw);
823
832 int16_t setSyncWord(uint8_t syncH, uint8_t syncL, uint8_t maxErrBits = 0, bool requireCarrierSense = false);
833
842 int16_t setSyncWord(const uint8_t* syncWord, uint8_t len, uint8_t maxErrBits = 0, bool requireCarrierSense = false);
843
850 int16_t setPreambleLength(uint8_t preambleLength, uint8_t qualityThreshold);
851
859 int16_t setNodeAddress(uint8_t nodeAddr, uint8_t numBroadcastAddrs = 0);
860
865 int16_t disableAddressFiltering();
866
872 int16_t setOOK(bool enableOOK);
873
879 float getRSSI() override;
880
885 uint8_t getLQI() const;
886
892 size_t getPacketLength(bool update = true) override;
893
899 int16_t fixedPacketLengthMode(uint8_t len = RADIOLIB_CC1101_MAX_PACKET_LENGTH);
900
906 int16_t variablePacketLengthMode(uint8_t maxLen = RADIOLIB_CC1101_MAX_PACKET_LENGTH);
907
914 int16_t enableSyncWordFiltering(uint8_t maxErrBits = 0, bool requireCarrierSense = false);
915
921 int16_t disableSyncWordFiltering(bool requireCarrierSense = false);
922
928 int16_t setCrcFiltering(bool enable = true);
929
936 int16_t setPromiscuousMode(bool enable = true, bool requireCarrierSense = false);
937
943 bool getPromiscuousMode();
944
951 int16_t setDataShaping(uint8_t sh) override;
952
959 int16_t setEncoding(uint8_t encoding) override;
960
962 void setRfSwitchPins(uint32_t rxEn, uint32_t txEn);
963
965 void setRfSwitchTable(const uint32_t (&pins)[Module::RFSWITCH_MAX_PINS], const Module::RfSwitchMode_t table[]);
966
971 uint8_t randomByte() override;
972
978 int16_t getChipVersion();
979
980 #if !RADIOLIB_EXCLUDE_DIRECT_RECEIVE
985 void setDirectAction(void (*func)(void)) override;
986
991 void readBit(uint32_t pin) override;
992 #endif
993
1000 int16_t setDIOMapping(uint32_t pin, uint32_t value) override;
1001
1002 #if !RADIOLIB_GODMODE && !RADIOLIB_LOW_LEVEL
1003 protected:
1004 #endif
1005 Module* getMod() override;
1006
1007 // SPI read overrides to set bit for burst write and status registers access
1008 int16_t SPIgetRegValue(uint8_t reg, uint8_t msb = 7, uint8_t lsb = 0);
1009 int16_t SPIsetRegValue(uint8_t reg, uint8_t value, uint8_t msb = 7, uint8_t lsb = 0, uint8_t checkInterval = 2);
1010 void SPIreadRegisterBurst(uint8_t reg, uint8_t numBytes, uint8_t* inBytes);
1011 uint8_t SPIreadRegister(uint8_t reg);
1012 void SPIwriteRegisterBurst(uint8_t reg, const uint8_t* data, size_t len);
1013 void SPIwriteRegister(uint8_t reg, uint8_t data);
1014
1015 void SPIsendCommand(uint8_t cmd);
1016
1017 #if !RADIOLIB_GODMODE
1018 private:
1019 #endif
1020 Module* mod;
1021
1022 float frequency = RADIOLIB_CC1101_DEFAULT_FREQ;
1023 float bitRate = RADIOLIB_CC1101_DEFAULT_BR;
1024 uint8_t rawRSSI = 0;
1025 uint8_t rawLQI = 0;
1026 uint8_t modulation = RADIOLIB_CC1101_MOD_FORMAT_2_FSK;
1027
1028 size_t packetLength = 0;
1029 bool packetLengthQueried = false;
1030 uint8_t packetLengthConfig = RADIOLIB_CC1101_LENGTH_CONFIG_VARIABLE;
1031
1032 bool promiscuous = false;
1033 bool crcOn = true;
1034 bool directModeEnabled = false;
1035
1036 int8_t power = RADIOLIB_CC1101_DEFAULT_POWER;
1037
1038 int16_t beginCommon(float freq, float br, float freqDev, float rxBw, int8_t pwr, uint8_t preambleLength);
1039 int16_t config();
1040 int16_t transmitDirect(bool sync, uint32_t frf);
1041 int16_t receiveDirect(bool sync);
1042 int16_t directMode(bool sync);
1043 static void getExpMant(float target, uint16_t mantOffset, uint8_t divExp, uint8_t expMax, uint8_t& exp, uint8_t& mant);
1044 int16_t setPacketMode(uint8_t mode, uint16_t len);
1045};
1046
1047#endif
Control class for CC1101 module.
Definition CC1101.h:527
void clearPacketReceivedAction() override
Clears interrupt service routine to call when a packet is received.
Definition CC1101.cpp:200
int16_t setFrequencyDeviation(float freqDev) override
Sets frequency deviation. Allowed values range from 1.587 to 380.8 kHz.
Definition CC1101.cpp:456
int16_t sleep() override
Sets the module to sleep mode.
Definition CC1101.cpp:119
void readBit(uint32_t pin) override
Function to read and process data bit in direct reception mode.
Definition CC1101.cpp:927
size_t getPacketLength(bool update=true) override
Query modem for the packet length of received payload.
Definition CC1101.cpp:745
uint8_t randomByte() override
Get one truly random byte from RSSI noise.
Definition CC1101.cpp:899
void reset()
Reset method - resets the chip using manual reset sequence (without RESET pin).
Definition CC1101.cpp:21
int16_t transmitDirect(uint32_t frf=0) override
Starts synchronous direct mode transmission.
Definition CC1101.cpp:125
void setDirectAction(void(*func)(void)) override
Set interrupt service routine function to call when data bit is receveid in direct mode.
Definition CC1101.cpp:923
void clearPacketSentAction() override
Clears interrupt service routine to call when a packet is sent.
Definition CC1101.cpp:208
void setPacketReceivedAction(void(*func)(void)) override
Sets interrupt service routine to call when a packet is received.
Definition CC1101.cpp:196
int16_t getChipVersion()
Read version SPI register. Should return CC1101_VERSION_LEGACY (0x04) or CC1101_VERSION_CURRENT (0x14...
Definition CC1101.cpp:918
void setPacketSentAction(void(*func)(void)) override
Sets interrupt service routine to call when a packet is sent.
Definition CC1101.cpp:204
int16_t setRxBandwidth(float rxBw)
Sets receiver bandwidth. Allowed values are 58, 68, 81, 102, 116, 135, 162, 203, 232,...
Definition CC1101.cpp:417
int16_t packetMode()
Stops direct mode. It is required to call this method to switch from direct transmissions to packet-b...
Definition CC1101.cpp:181
int16_t setSyncWord(uint8_t syncH, uint8_t syncL, uint8_t maxErrBits=0, bool requireCarrierSense=false)
Sets 16-bit sync word as a two byte value.
Definition CC1101.cpp:624
int16_t autoSetRxBandwidth()
calculates and sets Rx bandwidth based on the freq, baud and freq uncertainty. Reimplement of atlas0f...
Definition CC1101.cpp:438
int16_t disableSyncWordFiltering(bool requireCarrierSense=false)
Disable preamble and sync word filtering and generation.
Definition CC1101.cpp:792
int16_t transmit(const uint8_t *data, size_t len, uint8_t addr=0) override
Blocking binary transmit method. Overloads for string-based transmissions are implemented in Physical...
Definition CC1101.cpp:26
int16_t variablePacketLengthMode(uint8_t maxLen=RADIOLIB_CC1101_MAX_PACKET_LENGTH)
Set modem in variable packet length mode.
Definition CC1101.cpp:769
int16_t setDIOMapping(uint32_t pin, uint32_t value) override
Configure DIO pin mapping to get a given signal on a DIO pin (if available).
Definition CC1101.cpp:932
uint8_t getLQI() const
Gets LQI (Link Quality Indicator) of the last received packet.
Definition CC1101.cpp:741
int16_t setOutputPower(int8_t pwr) override
Sets output power. Allowed values are -30, -20, -15, -10, 0, 5, 7 or 10 dBm.
Definition CC1101.cpp:508
void setRfSwitchPins(uint32_t rxEn, uint32_t txEn)
Some modules contain external RF switch controlled by pins. This function gives RadioLib control over...
Definition CC1101.cpp:891
int16_t setCrcFiltering(bool enable=true)
Enable CRC filtering and generation.
Definition CC1101.cpp:797
int16_t setNodeAddress(uint8_t nodeAddr, uint8_t numBroadcastAddrs=0)
Sets node and broadcast addresses. Calling this method will also enable address filtering.
Definition CC1101.cpp:671
int16_t setBitRate(float br) override
Sets bit rate. Allowed values range from 0.025 to 600.0 kbps.
Definition CC1101.cpp:388
int16_t enableSyncWordFiltering(uint8_t maxErrBits=0, bool requireCarrierSense=false)
Enable sync word filtering and generation.
Definition CC1101.cpp:773
int16_t startTransmit(const uint8_t *data, size_t len, uint8_t addr=0) override
Interrupt-driven binary transmit method. Overloads for string-based transmissions are implemented in ...
Definition CC1101.cpp:227
int16_t standby() override
Sets the module to standby mode.
Definition CC1101.cpp:95
void setRfSwitchTable(const uint32_t(&pins)[Module::RFSWITCH_MAX_PINS], const Module::RfSwitchMode_t table[])
Some modules contain external RF switch controlled by pins. This function gives RadioLib control over...
Definition CC1101.cpp:895
int16_t readData(uint8_t *data, size_t len) override
Reads data received after calling startReceive method. When the packet length is not known in advance...
Definition CC1101.cpp:307
int16_t disableAddressFiltering()
Disables address filtering. Calling this method will also erase previously set addresses.
Definition CC1101.cpp:682
void setGdo0Action(void(*func)(void), uint32_t dir)
Sets interrupt service routine to call when GDO0 activates.
Definition CC1101.cpp:188
int16_t receiveDirectAsync()
Starts asynchronous direct mode reception.
Definition CC1101.cpp:160
int16_t receiveDirect() override
Starts synchronous direct mode reception.
Definition CC1101.cpp:156
int16_t setEncoding(uint8_t encoding) override
Sets transmission encoding. Allowed values are RADIOLIB_ENCODING_NRZ, RADIOLIB_ENCODING_MANCHESTER,...
Definition CC1101.cpp:867
int16_t checkOutputPower(int8_t power, int8_t *clipped) override
Check if output power is configurable. This method is needed for compatibility with PhysicalLayer::ch...
Definition CC1101.cpp:533
void clearGdo0Action()
Clears interrupt service routine to call when GDO0 activates.
Definition CC1101.cpp:192
float getRSSI() override
Gets RSSI (Recorded Signal Strength Indicator) of the last received packet. In direct or asynchronous...
Definition CC1101.cpp:721
int16_t getFrequencyDeviation(float *freqDev)
Gets frequency deviation.
Definition CC1101.cpp:483
int16_t setPromiscuousMode(bool enable=true, bool requireCarrierSense=false)
Set modem in "sniff" mode: no packet filtering (e.g., no preamble, sync word, address,...
Definition CC1101.cpp:807
void clearGdo2Action()
Clears interrupt service routine to call when GDO0 activates.
Definition CC1101.cpp:220
int16_t fixedPacketLengthMode(uint8_t len=RADIOLIB_CC1101_MAX_PACKET_LENGTH)
Set modem in fixed packet length mode.
Definition CC1101.cpp:759
int16_t setFrequency(float freq) override
Sets carrier frequency. Allowed values are in bands 300.0 to 348.0 MHz, 387.0 to 464....
Definition CC1101.cpp:360
void setGdo2Action(void(*func)(void), uint32_t dir)
Sets interrupt service routine to call when GDO2 activates.
Definition CC1101.cpp:212
int16_t begin(float freq=RADIOLIB_CC1101_DEFAULT_FREQ, float br=RADIOLIB_CC1101_DEFAULT_BR, float freqDev=RADIOLIB_CC1101_DEFAULT_FREQDEV, float rxBw=RADIOLIB_CC1101_DEFAULT_RXBW, int8_t pwr=RADIOLIB_CC1101_DEFAULT_POWER, uint8_t preambleLength=RADIOLIB_CC1101_DEFAULT_PREAMBLELEN)
Initialization method.
Definition CC1101.cpp:9
int16_t setBitRateTolerance(uint8_t brt)
Sets bit rate tolerance in BSCFG register. Allowed values are 0:(0%), 1(3,125%), 2:(6,...
Definition CC1101.cpp:408
int16_t setDataShaping(uint8_t sh) override
Sets Gaussian filter bandwidth-time product that will be used for data shaping. Allowed value is RADI...
Definition CC1101.cpp:848
int16_t startReceive() override
Interrupt-driven receive method. GDO0 will be activated when full packet is received.
Definition CC1101.cpp:277
int16_t setPreambleLength(uint8_t preambleLength, uint8_t qualityThreshold)
Sets preamble length.
Definition CC1101.cpp:629
int16_t receive(uint8_t *data, size_t len) override
Blocking binary receive method. Overloads for string-based transmissions are implemented in PhysicalL...
Definition CC1101.cpp:59
bool getPromiscuousMode()
Get whether the modem is in promiscuous mode: no packet filtering (e.g., no preamble,...
Definition CC1101.cpp:844
int16_t transmitDirectAsync(uint32_t frf=0)
Starts asynchronous direct mode transmission.
Definition CC1101.cpp:129
int16_t finishTransmit() override
Clean up after transmission is done.
Definition CC1101.cpp:266
int16_t setOOK(bool enableOOK)
Enables/disables OOK modulation instead of FSK.
Definition CC1101.cpp:692
int16_t beginFSK4(float freq=RADIOLIB_CC1101_DEFAULT_FREQ, float br=RADIOLIB_CC1101_DEFAULT_BR, float freqDev=RADIOLIB_CC1101_DEFAULT_FREQDEV, float rxBw=RADIOLIB_CC1101_DEFAULT_RXBW, int8_t pwr=RADIOLIB_CC1101_DEFAULT_POWER, uint8_t preambleLength=RADIOLIB_CC1101_DEFAULT_PREAMBLELEN)
Initialization method for 4-FSK modulation.
Definition CC1101.cpp:15
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
Provides common interface for protocols that run on LoRa/FSK modules, such as RTTY or LoRaWAN....
Definition PhysicalLayer.h:216
virtual int16_t readData(uint8_t *data, size_t len)
Reads data that was received after calling startReceive method.
Definition PhysicalLayer.cpp:220
int16_t transmit(const char *str, uint8_t addr=0)
C-string transmit method.
Definition PhysicalLayer.cpp:53
int16_t startTransmit(const char *str, uint8_t addr=0)
Interrupt-driven Arduino String transmit method. Unlike the standard transmit method,...
Definition PhysicalLayer.cpp:155
virtual int16_t receive(uint8_t *data, size_t len)
Binary receive method. Must be implemented in module class.
Definition PhysicalLayer.cpp:111
Description of RF switch pin states for a single mode. See setRfSwitchTable for details.
Definition Module.h:89