1 #if !defined(_RADIOLIB_CC1101_H) && !RADIOLIB_EXCLUDE_CC1101
2 #define _RADIOLIB_CC1101_H
4 #include "../../TypeDef.h"
5 #include "../../Module.h"
7 #include "../../protocols/PhysicalLayer/PhysicalLayer.h"
10 #define RADIOLIB_CC1101_FREQUENCY_STEP_SIZE 396.7285156
11 #define RADIOLIB_CC1101_MAX_PACKET_LENGTH 63
12 #define RADIOLIB_CC1101_CRYSTAL_FREQ 26.0
13 #define RADIOLIB_CC1101_DIV_EXPONENT 16
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
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
102 #define RADIOLIB_CC1101_STATUS_CHIP_READY 0b00000000
103 #define RADIOLIB_CC1101_STATUS_CHIP_NOT_READY 0b10000000
104 #define RADIOLIB_CC1101_STATUS_IDLE 0b00000000
105 #define RADIOLIB_CC1101_STATUS_RX 0b00010000
106 #define RADIOLIB_CC1101_STATUS_TX 0b00100000
107 #define RADIOLIB_CC1101_STATUS_FSTXON 0b00110000
108 #define RADIOLIB_CC1101_STATUS_CALIBRATE 0b01000000
109 #define RADIOLIB_CC1101_STATUS_SETTLING 0b01010000
110 #define RADIOLIB_CC1101_STATUS_RXFIFO_OVERFLOW 0b01100000
111 #define RADIOLIB_CC1101_STATUS_TXFIFO_UNDERFLOW 0b01110000
114 #define RADIOLIB_CC1101_GDO2_NORM 0b00000000
115 #define RADIOLIB_CC1101_GDO2_INV 0b01000000
118 #define RADIOLIB_CC1101_GDO_DS_LOW 0b00000000
119 #define RADIOLIB_CC1101_GDO_DS_HIGH 0b10000000
120 #define RADIOLIB_CC1101_GDO1_NORM 0b00000000
121 #define RADIOLIB_CC1101_GDO1_INV 0b01000000
124 #define RADIOLIB_CC1101_GDO0_TEMP_SENSOR_OFF 0b00000000
125 #define RADIOLIB_CC1101_GDO0_TEMP_SENSOR_ON 0b10000000
126 #define RADIOLIB_CC1101_GDO0_NORM 0b00000000
127 #define RADIOLIB_CC1101_GDO0_INV 0b01000000
130 #define RADIOLIB_CC1101_GDOX_RX_FIFO_FULL 0x00
131 #define RADIOLIB_CC1101_GDOX_RX_FIFO_FULL_OR_PKT_END 0x01
132 #define RADIOLIB_CC1101_GDOX_TX_FIFO_ABOVE_THR 0x02
133 #define RADIOLIB_CC1101_GDOX_TX_FIFO_FULL 0x03
134 #define RADIOLIB_CC1101_GDOX_RX_FIFO_OVERFLOW 0x04
135 #define RADIOLIB_CC1101_GDOX_TX_FIFO_UNDERFLOW 0x05
136 #define RADIOLIB_CC1101_GDOX_SYNC_WORD_SENT_OR_PKT_RECEIVED 0x06
137 #define RADIOLIB_CC1101_GDOX_PKT_RECEIVED_CRC_OK 0x07
138 #define RADIOLIB_CC1101_GDOX_PREAMBLE_QUALITY_REACHED 0x08
139 #define RADIOLIB_CC1101_GDOX_CHANNEL_CLEAR 0x09
140 #define RADIOLIB_CC1101_GDOX_PLL_LOCKED 0x0A
141 #define RADIOLIB_CC1101_GDOX_SERIAL_CLOCK 0x0B
142 #define RADIOLIB_CC1101_GDOX_SERIAL_DATA_SYNC 0x0C
143 #define RADIOLIB_CC1101_GDOX_SERIAL_DATA_ASYNC 0x0D
144 #define RADIOLIB_CC1101_GDOX_CARRIER_SENSE 0x0E
145 #define RADIOLIB_CC1101_GDOX_CRC_OK 0x0F
146 #define RADIOLIB_CC1101_GDOX_RX_HARD_DATA1 0x16
147 #define RADIOLIB_CC1101_GDOX_RX_HARD_DATA0 0x17
148 #define RADIOLIB_CC1101_GDOX_PA_PD 0x1B
149 #define RADIOLIB_CC1101_GDOX_LNA_PD 0x1C
150 #define RADIOLIB_CC1101_GDOX_RX_SYMBOL_TICK 0x1D
151 #define RADIOLIB_CC1101_GDOX_WOR_EVNT0 0x24
152 #define RADIOLIB_CC1101_GDOX_WOR_EVNT1 0x25
153 #define RADIOLIB_CC1101_GDOX_CLK_256 0x26
154 #define RADIOLIB_CC1101_GDOX_CLK_32K 0x27
155 #define RADIOLIB_CC1101_GDOX_CHIP_RDYN 0x29
156 #define RADIOLIB_CC1101_GDOX_XOSC_STABLE 0x2B
157 #define RADIOLIB_CC1101_GDOX_HIGH_Z 0x2E
158 #define RADIOLIB_CC1101_GDOX_HW_TO_0 0x2F
159 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_1 0x30
160 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_1_5 0x31
161 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_2 0x32
162 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_3 0x33
163 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_4 0x34
164 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_6 0x35
165 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_8 0x36
166 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_12 0x37
167 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_16 0x38
168 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_24 0x39
169 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_32 0x3A
170 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_48 0x3B
171 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_64 0x3C
172 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_96 0x3D
173 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_128 0x3E
174 #define RADIOLIB_CC1101_GDOX_CLOCK_XOSC_192 0x3F
177 #define RADIOLIB_CC1101_ADC_RETENTION_OFF 0b00000000
178 #define RADIOLIB_CC1101_ADC_RETENTION_ON 0b01000000
179 #define RADIOLIB_CC1101_RX_ATTEN_0_DB 0b00000000
180 #define RADIOLIB_CC1101_RX_ATTEN_6_DB 0b00010000
181 #define RADIOLIB_CC1101_RX_ATTEN_12_DB 0b00100000
182 #define RADIOLIB_CC1101_RX_ATTEN_18_DB 0b00110000
183 #define RADIOLIB_CC1101_FIFO_THR_TX_61_RX_4 0b00000000
184 #define RADIOLIB_CC1101_FIFO_THR_TX_33_RX_32 0b00000111
185 #define RADIOLIB_CC1101_FIFO_THRESH_TX 33
186 #define RADIOLIB_CC1101_FIFO_THRESH_RX 32
189 #define RADIOLIB_CC1101_SYNC_WORD_MSB 0xD3
192 #define RADIOLIB_CC1101_SYNC_WORD_LSB 0x91
195 #define RADIOLIB_CC1101_PACKET_LENGTH 0xFF
198 #define RADIOLIB_CC1101_PQT 0x00
199 #define RADIOLIB_CC1101_CRC_AUTOFLUSH_OFF 0b00000000
200 #define RADIOLIB_CC1101_CRC_AUTOFLUSH_ON 0b00001000
201 #define RADIOLIB_CC1101_APPEND_STATUS_OFF 0b00000000
202 #define RADIOLIB_CC1101_APPEND_STATUS_ON 0b00000100
203 #define RADIOLIB_CC1101_ADR_CHK_NONE 0b00000000
204 #define RADIOLIB_CC1101_ADR_CHK_NO_BROADCAST 0b00000001
205 #define RADIOLIB_CC1101_ADR_CHK_SINGLE_BROADCAST 0b00000010
206 #define RADIOLIB_CC1101_ADR_CHK_DOUBLE_BROADCAST 0b00000011
209 #define RADIOLIB_CC1101_WHITE_DATA_OFF 0b00000000
210 #define RADIOLIB_CC1101_WHITE_DATA_ON 0b01000000
211 #define RADIOLIB_CC1101_PKT_FORMAT_NORMAL 0b00000000
212 #define RADIOLIB_CC1101_PKT_FORMAT_SYNCHRONOUS 0b00010000
213 #define RADIOLIB_CC1101_PKT_FORMAT_RANDOM 0b00100000
214 #define RADIOLIB_CC1101_PKT_FORMAT_ASYNCHRONOUS 0b00110000
215 #define RADIOLIB_CC1101_CRC_OFF 0b00000000
216 #define RADIOLIB_CC1101_CRC_ON 0b00000100
217 #define RADIOLIB_CC1101_LENGTH_CONFIG_FIXED 0b00000000
218 #define RADIOLIB_CC1101_LENGTH_CONFIG_VARIABLE 0b00000001
219 #define RADIOLIB_CC1101_LENGTH_CONFIG_INFINITE 0b00000010
222 #define RADIOLIB_CC1101_DEVICE_ADDR 0x00
225 #define RADIOLIB_CC1101_CHAN 0x00
228 #define RADIOLIB_CC1101_FREQ_IF 0x0F
231 #define RADIOLIB_CC1101_FREQOFF 0x00
234 #define RADIOLIB_CC1101_FREQ_MSB 0x1E
235 #define RADIOLIB_CC1101_FREQ_MID 0xC4
236 #define RADIOLIB_CC1101_FREQ_LSB 0xEC
239 #define RADIOLIB_CC1101_CHANBW_E 0b10000000
240 #define RADIOLIB_CC1101_CHANBW_M 0b00000000
241 #define RADIOLIB_CC1101_DRATE_E 0x0C
244 #define RADIOLIB_CC1101_DRATE_M 0x22
247 #define RADIOLIB_CC1101_DEM_DCFILT_OFF 0b10000000
248 #define RADIOLIB_CC1101_DEM_DCFILT_ON 0b00000000
249 #define RADIOLIB_CC1101_MOD_FORMAT_2_FSK 0b00000000
250 #define RADIOLIB_CC1101_MOD_FORMAT_GFSK 0b00010000
251 #define RADIOLIB_CC1101_MOD_FORMAT_ASK_OOK 0b00110000
252 #define RADIOLIB_CC1101_MOD_FORMAT_4_FSK 0b01000000
253 #define RADIOLIB_CC1101_MOD_FORMAT_MFSK 0b01110000
254 #define RADIOLIB_CC1101_MANCHESTER_EN_OFF 0b00000000
255 #define RADIOLIB_CC1101_MANCHESTER_EN_ON 0b00001000
256 #define RADIOLIB_CC1101_SYNC_MODE_NONE 0b00000000
257 #define RADIOLIB_CC1101_SYNC_MODE_15_16 0b00000001
258 #define RADIOLIB_CC1101_SYNC_MODE_16_16 0b00000010
259 #define RADIOLIB_CC1101_SYNC_MODE_30_32 0b00000011
260 #define RADIOLIB_CC1101_SYNC_MODE_NONE_THR 0b00000100
261 #define RADIOLIB_CC1101_SYNC_MODE_15_16_THR 0b00000101
262 #define RADIOLIB_CC1101_SYNC_MODE_16_16_THR 0b00000110
263 #define RADIOLIB_CC1101_SYNC_MODE_30_32_THR 0b00000111
266 #define RADIOLIB_CC1101_FEC_OFF 0b00000000
267 #define RADIOLIB_CC1101_FEC_ON 0b10000000
268 #define RADIOLIB_CC1101_NUM_PREAMBLE_2 0b00000000
269 #define RADIOLIB_CC1101_NUM_PREAMBLE_3 0b00010000
270 #define RADIOLIB_CC1101_NUM_PREAMBLE_4 0b00100000
271 #define RADIOLIB_CC1101_NUM_PREAMBLE_6 0b00110000
272 #define RADIOLIB_CC1101_NUM_PREAMBLE_8 0b01000000
273 #define RADIOLIB_CC1101_NUM_PREAMBLE_12 0b01010000
274 #define RADIOLIB_CC1101_NUM_PREAMBLE_16 0b01100000
275 #define RADIOLIB_CC1101_NUM_PREAMBLE_24 0b01110000
276 #define RADIOLIB_CC1101_CHANSPC_E 0x02
279 #define RADIOLIB_CC1101_CHANSPC_M 0xF8
282 #define RADIOLIB_CC1101_DEVIATION_E 0b01000000
283 #define RADIOLIB_CC1101_DEVIATION_M 0b00000111
284 #define RADIOLIB_CC1101_MSK_PHASE_CHANGE_PERIOD 0x07
287 #define RADIOLIB_CC1101_RX_TIMEOUT_RSSI_OFF 0b00000000
288 #define RADIOLIB_CC1101_RX_TIMEOUT_RSSI_ON 0b00010000
289 #define RADIOLIB_CC1101_RX_TIMEOUT_QUAL_OFF 0b00000000
290 #define RADIOLIB_CC1101_RX_TIMEOUT_QUAL_ON 0b00001000
291 #define RADIOLIB_CC1101_RX_TIMEOUT_OFF 0b00000111
292 #define RADIOLIB_CC1101_RX_TIMEOUT_MAX 0b00000000
295 #define RADIOLIB_CC1101_CCA_MODE_ALWAYS 0b00000000
296 #define RADIOLIB_CC1101_CCA_MODE_RSSI_THR 0b00010000
297 #define RADIOLIB_CC1101_CCA_MODE_RX_PKT 0b00100000
298 #define RADIOLIB_CC1101_CCA_MODE_RSSI_THR_RX_PKT 0b00110000
299 #define RADIOLIB_CC1101_RXOFF_IDLE 0b00000000
300 #define RADIOLIB_CC1101_RXOFF_FSTXON 0b00000100
301 #define RADIOLIB_CC1101_RXOFF_TX 0b00001000
302 #define RADIOLIB_CC1101_RXOFF_RX 0b00001100
303 #define RADIOLIB_CC1101_TXOFF_IDLE 0b00000000
304 #define RADIOLIB_CC1101_TXOFF_FSTXON 0b00000001
305 #define RADIOLIB_CC1101_TXOFF_TX 0b00000010
306 #define RADIOLIB_CC1101_TXOFF_RX 0b00000011
309 #define RADIOLIB_CC1101_FS_AUTOCAL_NEVER 0b00000000
310 #define RADIOLIB_CC1101_FS_AUTOCAL_IDLE_TO_RXTX 0b00010000
311 #define RADIOLIB_CC1101_FS_AUTOCAL_RXTX_TO_IDLE 0b00100000
312 #define RADIOLIB_CC1101_FS_AUTOCAL_RXTX_TO_IDLE_4TH 0b00110000
313 #define RADIOLIB_CC1101_PO_TIMEOUT_COUNT_1 0b00000000
314 #define RADIOLIB_CC1101_PO_TIMEOUT_COUNT_16 0b00000100
315 #define RADIOLIB_CC1101_PO_TIMEOUT_COUNT_64 0b00001000
316 #define RADIOLIB_CC1101_PO_TIMEOUT_COUNT_256 0b00001100
317 #define RADIOLIB_CC1101_PIN_CTRL_OFF 0b00000000
318 #define RADIOLIB_CC1101_PIN_CTRL_ON 0b00000010
319 #define RADIOLIB_CC1101_XOSC_FORCE_OFF 0b00000000
320 #define RADIOLIB_CC1101_XOSC_FORCE_ON 0b00000001
323 #define RADIOLIB_CC1101_FOC_BS_CS_GATE_OFF 0b00000000
324 #define RADIOLIB_CC1101_FOC_BS_CS_GATE_ON 0b00100000
325 #define RADIOLIB_CC1101_FOC_PRE_K 0b00000000
326 #define RADIOLIB_CC1101_FOC_PRE_2K 0b00001000
327 #define RADIOLIB_CC1101_FOC_PRE_3K 0b00010000
328 #define RADIOLIB_CC1101_FOC_PRE_4K 0b00011000
329 #define RADIOLIB_CC1101_FOC_POST_K 0b00000000
330 #define RADIOLIB_CC1101_FOC_POST_K_2 0b00000100
331 #define RADIOLIB_CC1101_FOC_LIMIT_NO_COMPENSATION 0b00000000
332 #define RADIOLIB_CC1101_FOC_LIMIT_BW_CHAN_8 0b00000001
333 #define RADIOLIB_CC1101_FOC_LIMIT_BW_CHAN_4 0b00000010
334 #define RADIOLIB_CC1101_FOC_LIMIT_BW_CHAN_2 0b00000011
337 #define RADIOLIB_CC1101_BS_PRE_KI 0b00000000
338 #define RADIOLIB_CC1101_BS_PRE_2KI 0b01000000
339 #define RADIOLIB_CC1101_BS_PRE_3KI 0b10000000
340 #define RADIOLIB_CC1101_BS_PRE_4KI 0b11000000
341 #define RADIOLIB_CC1101_BS_PRE_KP 0b00000000
342 #define RADIOLIB_CC1101_BS_PRE_2KP 0b00010000
343 #define RADIOLIB_CC1101_BS_PRE_3KP 0b00100000
344 #define RADIOLIB_CC1101_BS_PRE_4KP 0b00110000
345 #define RADIOLIB_CC1101_BS_POST_KI 0b00000000
346 #define RADIOLIB_CC1101_BS_POST_KI_2 0b00001000
347 #define RADIOLIB_CC1101_BS_POST_KP 0b00000000
348 #define RADIOLIB_CC1101_BS_POST_KP_1 0b00000100
349 #define RADIOLIB_CC1101_BS_LIMIT_NO_COMPENSATION 0b00000000
350 #define RADIOLIB_CC1101_BS_LIMIT_3_125 0b00000001
351 #define RADIOLIB_CC1101_BS_LIMIT_6_25 0b00000010
352 #define RADIOLIB_CC1101_BS_LIMIT_12_5 0b00000011
355 #define RADIOLIB_CC1101_MAX_DVGA_GAIN_0 0b00000000
356 #define RADIOLIB_CC1101_MAX_DVGA_GAIN_1 0b01000000
357 #define RADIOLIB_CC1101_MAX_DVGA_GAIN_2 0b10000000
358 #define RADIOLIB_CC1101_MAX_DVGA_GAIN_3 0b11000000
359 #define RADIOLIB_CC1101_LNA_GAIN_REDUCE_0_DB 0b00000000
360 #define RADIOLIB_CC1101_LNA_GAIN_REDUCE_2_6_DB 0b00001000
361 #define RADIOLIB_CC1101_LNA_GAIN_REDUCE_6_1_DB 0b00010000
362 #define RADIOLIB_CC1101_LNA_GAIN_REDUCE_7_4_DB 0b00011000
363 #define RADIOLIB_CC1101_LNA_GAIN_REDUCE_9_2_DB 0b00100000
364 #define RADIOLIB_CC1101_LNA_GAIN_REDUCE_11_5_DB 0b00101000
365 #define RADIOLIB_CC1101_LNA_GAIN_REDUCE_14_6_DB 0b00110000
366 #define RADIOLIB_CC1101_LNA_GAIN_REDUCE_17_1_DB 0b00111000
367 #define RADIOLIB_CC1101_MAGN_TARGET_24_DB 0b00000000
368 #define RADIOLIB_CC1101_MAGN_TARGET_27_DB 0b00000001
369 #define RADIOLIB_CC1101_MAGN_TARGET_30_DB 0b00000010
370 #define RADIOLIB_CC1101_MAGN_TARGET_33_DB 0b00000011
371 #define RADIOLIB_CC1101_MAGN_TARGET_36_DB 0b00000100
372 #define RADIOLIB_CC1101_MAGN_TARGET_38_DB 0b00000101
373 #define RADIOLIB_CC1101_MAGN_TARGET_40_DB 0b00000110
374 #define RADIOLIB_CC1101_MAGN_TARGET_42_DB 0b00000111
377 #define RADIOLIB_CC1101_AGC_LNA_PRIORITY_LNA2 0b00000000
378 #define RADIOLIB_CC1101_AGC_LNA_PRIORITY_LNA 0b01000000
379 #define RADIOLIB_CC1101_CARRIER_SENSE_REL_THR_OFF 0b00000000
380 #define RADIOLIB_CC1101_CARRIER_SENSE_REL_THR_6_DB 0b00010000
381 #define RADIOLIB_CC1101_CARRIER_SENSE_REL_THR_10_DB 0b00100000
382 #define RADIOLIB_CC1101_CARRIER_SENSE_REL_THR_14_DB 0b00110000
383 #define RADIOLIB_CC1101_CARRIER_SENSE_ABS_THR 0x00
386 #define RADIOLIB_CC1101_HYST_LEVEL_NONE 0b00000000
387 #define RADIOLIB_CC1101_HYST_LEVEL_LOW 0b01000000
388 #define RADIOLIB_CC1101_HYST_LEVEL_MEDIUM 0b10000000
389 #define RADIOLIB_CC1101_HYST_LEVEL_HIGH 0b11000000
390 #define RADIOLIB_CC1101_WAIT_TIME_8_SAMPLES 0b00000000
391 #define RADIOLIB_CC1101_WAIT_TIME_16_SAMPLES 0b00010000
392 #define RADIOLIB_CC1101_WAIT_TIME_24_SAMPLES 0b00100000
393 #define RADIOLIB_CC1101_WAIT_TIME_32_SAMPLES 0b00110000
394 #define RADIOLIB_CC1101_AGC_FREEZE_NEVER 0b00000000
395 #define RADIOLIB_CC1101_AGC_FREEZE_SYNC_WORD 0b00000100
396 #define RADIOLIB_CC1101_AGC_FREEZE_MANUAL_A 0b00001000
397 #define RADIOLIB_CC1101_AGC_FREEZE_MANUAL_AD 0b00001100
398 #define RADIOLIB_CC1101_FILTER_LENGTH_8 0b00000000
399 #define RADIOLIB_CC1101_FILTER_LENGTH_16 0b00000001
400 #define RADIOLIB_CC1101_FILTER_LENGTH_32 0b00000010
401 #define RADIOLIB_CC1101_FILTER_LENGTH_64 0b00000011
402 #define RADIOLIB_CC1101_ASK_OOK_BOUNDARY_4_DB 0b00000000
403 #define RADIOLIB_CC1101_ASK_OOK_BOUNDARY_8_DB 0b00000001
404 #define RADIOLIB_CC1101_ASK_OOK_BOUNDARY_12_DB 0b00000010
405 #define RADIOLIB_CC1101_ASK_OOK_BOUNDARY_16_DB 0b00000011
408 #define RADIOLIB_CC1101_EVENT0_TIMEOUT_MSB 0x87
409 #define RADIOLIB_CC1101_EVENT0_TIMEOUT_LSB 0x6B
412 #define RADIOLIB_CC1101_RC_POWER_UP 0b00000000
413 #define RADIOLIB_CC1101_RC_POWER_DOWN 0b10000000
414 #define RADIOLIB_CC1101_EVENT1_TIMEOUT_4 0b00000000
415 #define RADIOLIB_CC1101_EVENT1_TIMEOUT_6 0b00010000
416 #define RADIOLIB_CC1101_EVENT1_TIMEOUT_8 0b00100000
417 #define RADIOLIB_CC1101_EVENT1_TIMEOUT_12 0b00110000
418 #define RADIOLIB_CC1101_EVENT1_TIMEOUT_16 0b01000000
419 #define RADIOLIB_CC1101_EVENT1_TIMEOUT_24 0b01010000
420 #define RADIOLIB_CC1101_EVENT1_TIMEOUT_32 0b01100000
421 #define RADIOLIB_CC1101_EVENT1_TIMEOUT_48 0b01110000
422 #define RADIOLIB_CC1101_RC_CAL_OFF 0b00000000
423 #define RADIOLIB_CC1101_RC_CAL_ON 0b00001000
424 #define RADIOLIB_CC1101_WOR_RES_1 0b00000000
425 #define RADIOLIB_CC1101_WOR_RES_2_5 0b00000001
426 #define RADIOLIB_CC1101_WOR_RES_2_10 0b00000010
427 #define RADIOLIB_CC1101_WOR_RES_2_15 0b00000011
430 #define RADIOLIB_CC1101_LNA_CURRENT 0x01
431 #define RADIOLIB_CC1101_LNA2MIX_CURRENT 0x01
432 #define RADIOLIB_CC1101_LODIV_BUF_CURRENT_RX 0x01
433 #define RADIOLIB_CC1101_MIX_CURRENT 0x02
436 #define RADIOLIB_CC1101_LODIV_BUF_CURRENT_TX 0x01
437 #define RADIOLIB_CC1101_PA_POWER 0x00
440 #define RADIOLIB_CC1101_CHP_CURR_CAL_OFF 0b00000000
441 #define RADIOLIB_CC1101_CHP_CURR_CAL_ON 0b00100000
442 #define RADIOLIB_CC1101_FSCAL3 0x09
445 #define RADIOLIB_CC1101_VCO_CORE_LOW 0b00000000
446 #define RADIOLIB_CC1101_VCO_CORE_HIGH 0b00100000
447 #define RADIOLIB_CC1101_FSCAL2 0x0A
450 #define RADIOLIB_CC1101_FSCAL1 0x20
453 #define RADIOLIB_CC1101_FSCAL0 0x0D
456 #define RADIOLIB_CC1101_RCCTRL1 0x41
459 #define RADIOLIB_CC1101_RCCTRL0 0x00
462 #define RADIOLIB_CC1101_TEMP_SENS_IDLE_OFF 0x7F
463 #define RADIOLIB_CC1101_TEMP_SENS_IDLE_ON 0xBF
466 #define RADIOLIB_CC1101_VCO_SEL_CAL_OFF 0b00000000
467 #define RADIOLIB_CC1101_VCO_SEL_CAL_ON 0b00000010
470 #define RADIOLIB_CC1101_PARTNUM 0x00
473 #define RADIOLIB_CC1101_VERSION_CURRENT 0x14
474 #define RADIOLIB_CC1101_VERSION_LEGACY 0x04
475 #define RADIOLIB_CC1101_VERSION_CLONE 0x17
478 #define RADIOLIB_CC1101_MARC_STATE_SLEEP 0x00
479 #define RADIOLIB_CC1101_MARC_STATE_IDLE 0x01
480 #define RADIOLIB_CC1101_MARC_STATE_XOFF 0x02
481 #define RADIOLIB_CC1101_MARC_STATE_VCOON_MC 0x03
482 #define RADIOLIB_CC1101_MARC_STATE_REGON_MC 0x04
483 #define RADIOLIB_CC1101_MARC_STATE_MANCAL 0x05
484 #define RADIOLIB_CC1101_MARC_STATE_VCOON 0x06
485 #define RADIOLIB_CC1101_MARC_STATE_REGON 0x07
486 #define RADIOLIB_CC1101_MARC_STATE_STARTCAL 0x08
487 #define RADIOLIB_CC1101_MARC_STATE_BWBOOST 0x09
488 #define RADIOLIB_CC1101_MARC_STATE_FS_LOCK 0x0A
489 #define RADIOLIB_CC1101_MARC_STATE_IFADCON 0x0B
490 #define RADIOLIB_CC1101_MARC_STATE_ENDCAL 0x0C
491 #define RADIOLIB_CC1101_MARC_STATE_RX 0x0D
492 #define RADIOLIB_CC1101_MARC_STATE_RX_END 0x0E
493 #define RADIOLIB_CC1101_MARC_STATE_RX_RST 0x0F
494 #define RADIOLIB_CC1101_MARC_STATE_TXRX_SWITCH 0x10
495 #define RADIOLIB_CC1101_MARC_STATE_RXFIFO_OVERFLOW 0x11
496 #define RADIOLIB_CC1101_MARC_STATE_FSTXON 0x12
497 #define RADIOLIB_CC1101_MARC_STATE_TX 0x13
498 #define RADIOLIB_CC1101_MARC_STATE_TX_END 0x14
499 #define RADIOLIB_CC1101_MARC_STATE_RXTX_SWITCH 0x15
500 #define RADIOLIB_CC1101_MARC_STATE_TXFIFO_UNDERFLOW 0x16
503 #define RADIOLIB_CC1101_WORTIME_MSB 0x00
504 #define RADIOLIB_CC1101_WORTIME_LSB 0x00
507 #define RADIOLIB_CC1101_CRC_OK 0b10000000
508 #define RADIOLIB_CC1101_CRC_ERROR 0b00000000
509 #define RADIOLIB_CC1101_CS 0b01000000
510 #define RADIOLIB_CC1101_PQT_REACHED 0b00100000
511 #define RADIOLIB_CC1101_CCA 0b00010000
512 #define RADIOLIB_CC1101_SFD 0b00001000
513 #define RADIOLIB_CC1101_GDO2_ACTIVE 0b00000100
514 #define RADIOLIB_CC1101_GDO0_ACTIVE 0b00000001
517 #define RADIOLIB_CC1101_DEFAULT_FREQ 434.0
518 #define RADIOLIB_CC1101_DEFAULT_BR 4.8
519 #define RADIOLIB_CC1101_DEFAULT_FREQDEV 5.0
520 #define RADIOLIB_CC1101_DEFAULT_RXBW 58.0
521 #define RADIOLIB_CC1101_DEFAULT_POWER 10
522 #define RADIOLIB_CC1101_DEFAULT_PREAMBLELEN 16
523 #define RADIOLIB_CC1101_DEFAULT_SW {0x12, 0xAD}
524 #define RADIOLIB_CC1101_DEFAULT_SW_LEN 2
558 float freq = RADIOLIB_CC1101_DEFAULT_FREQ,
559 float br = RADIOLIB_CC1101_DEFAULT_BR,
560 float freqDev = RADIOLIB_CC1101_DEFAULT_FREQDEV,
561 float rxBw = RADIOLIB_CC1101_DEFAULT_RXBW,
562 int8_t pwr = RADIOLIB_CC1101_DEFAULT_POWER,
563 uint8_t preambleLength = RADIOLIB_CC1101_DEFAULT_PREAMBLELEN);
578 int16_t
transmit(uint8_t* data,
size_t len, uint8_t addr = 0)
override;
587 int16_t
receive(uint8_t* data,
size_t len)
override;
600 int16_t
standby(uint8_t mode)
override;
690 int16_t
startTransmit(uint8_t* data,
size_t len, uint8_t addr = 0)
override;
712 int16_t
startReceive(uint32_t timeout, uint32_t irqFlags, uint32_t irqMask,
size_t len)
override;
722 int16_t
readData(uint8_t* data,
size_t len)
override;
804 int16_t
setSyncWord(uint8_t syncH, uint8_t syncL, uint8_t maxErrBits = 0,
bool requireCarrierSense =
false);
814 int16_t
setSyncWord(uint8_t* syncWord, uint8_t len, uint8_t maxErrBits = 0,
bool requireCarrierSense =
false);
831 int16_t
setNodeAddress(uint8_t nodeAddr, uint8_t numBroadcastAddrs = 0);
844 int16_t
setOOK(
bool enableOOK);
952 #if !RADIOLIB_EXCLUDE_DIRECT_RECEIVE
963 void readBit(uint32_t pin)
override;
972 int16_t
setDIOMapping(uint32_t pin, uint32_t value)
override;
974 #if !RADIOLIB_GODMODE && !RADIOLIB_LOW_LEVEL
977 Module* getMod()
override;
980 int16_t SPIgetRegValue(uint8_t reg, uint8_t msb = 7, uint8_t lsb = 0);
981 int16_t SPIsetRegValue(uint8_t reg, uint8_t value, uint8_t msb = 7, uint8_t lsb = 0, uint8_t checkInterval = 2);
982 void SPIreadRegisterBurst(uint8_t reg, uint8_t numBytes, uint8_t* inBytes);
983 uint8_t SPIreadRegister(uint8_t reg);
984 void SPIwriteRegisterBurst(uint8_t reg, uint8_t* data,
size_t len);
985 void SPIwriteRegister(uint8_t reg, uint8_t data);
987 void SPIsendCommand(uint8_t cmd);
989 #if !RADIOLIB_GODMODE
994 float frequency = RADIOLIB_CC1101_DEFAULT_FREQ;
995 float bitRate = RADIOLIB_CC1101_DEFAULT_BR;
998 uint8_t modulation = RADIOLIB_CC1101_MOD_FORMAT_2_FSK;
1000 size_t packetLength = 0;
1001 bool packetLengthQueried =
false;
1002 uint8_t packetLengthConfig = RADIOLIB_CC1101_LENGTH_CONFIG_VARIABLE;
1004 bool promiscuous =
false;
1006 bool directModeEnabled =
true;
1008 int8_t power = RADIOLIB_CC1101_DEFAULT_POWER;
1013 int16_t directMode(
bool sync);
1014 static void getExpMant(
float target, uint16_t mantOffset, uint8_t divExp, uint8_t expMax, uint8_t& exp, uint8_t& mant);
1015 int16_t setPacketMode(uint8_t mode, uint16_t len);
Control class for CC1101 module.
Definition: CC1101.h:530
void clearPacketReceivedAction() override
Clears interrupt service routine to call when a packet is received.
Definition: CC1101.cpp:265
int16_t setFrequencyDeviation(float freqDev) override
Sets frequency deviation. Allowed values range from 1.587 to 380.8 kHz.
Definition: CC1101.cpp:510
void readBit(uint32_t pin) override
Function to read and process data bit in direct reception mode.
Definition: CC1101.cpp:1002
size_t getPacketLength(bool update=true) override
Query modem for the packet length of received payload.
Definition: CC1101.cpp:820
uint8_t randomByte() override
Get one truly random byte from RSSI noise.
Definition: CC1101.cpp:974
void reset()
Reset method - resets the chip using manual reset sequence (without RESET pin).
Definition: CC1101.cpp:90
int16_t transmitDirect(uint32_t frf=0) override
Starts synchronous direct mode transmission.
Definition: CC1101.cpp:194
void setDirectAction(void(*func)(void)) override
Set interrupt service routine function to call when data bit is receveid in direct mode.
Definition: CC1101.cpp:998
void clearPacketSentAction() override
Clears interrupt service routine to call when a packet is sent.
Definition: CC1101.cpp:273
void setPacketReceivedAction(void(*func)(void)) override
Sets interrupt service routine to call when a packet is received.
Definition: CC1101.cpp:261
int16_t getChipVersion()
Read version SPI register. Should return CC1101_VERSION_LEGACY (0x04) or CC1101_VERSION_CURRENT (0x14...
Definition: CC1101.cpp:993
void setPacketSentAction(void(*func)(void)) override
Sets interrupt service routine to call when a packet is sent.
Definition: CC1101.cpp:269
virtual int16_t readData(uint8_t *data, size_t len)
Reads data that was received after calling startReceive method.
Definition: PhysicalLayer.cpp:209
int16_t setRxBandwidth(float rxBw)
Sets receiver bandwidth. Allowed values are 58, 68, 81, 102, 116, 135, 162, 203, 232,...
Definition: CC1101.cpp:471
int16_t packetMode()
Stops direct mode. It is required to call this method to switch from direct transmissions to packet-b...
Definition: CC1101.cpp:246
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:699
int16_t autoSetRxBandwidth()
calculates and sets Rx bandwidth based on the freq, baud and freq uncertainty. Reimplement of atlas0f...
Definition: CC1101.cpp:492
int16_t transmit(const char *str, uint8_t addr=0)
C-string transmit method.
Definition: PhysicalLayer.cpp:52
int16_t disableSyncWordFiltering(bool requireCarrierSense=false)
Disable preamble and sync word filtering and generation.
Definition: CC1101.cpp:867
int16_t variablePacketLengthMode(uint8_t maxLen=RADIOLIB_CC1101_MAX_PACKET_LENGTH)
Set modem in variable packet length mode.
Definition: CC1101.cpp:844
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:1007
uint8_t getLQI() const
Gets LQI (Link Quality Indicator) of the last received packet.
Definition: CC1101.cpp:816
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:562
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:966
int16_t setCrcFiltering(bool enable=true)
Enable CRC filtering and generation.
Definition: CC1101.cpp:872
CC1101(Module *module)
Default constructor.
Definition: CC1101.cpp:5
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:746
int16_t setBitRate(float br) override
Sets bit rate. Allowed values range from 0.025 to 600.0 kbps.
Definition: CC1101.cpp:451
int16_t enableSyncWordFiltering(uint8_t maxErrBits=0, bool requireCarrierSense=false)
Enable sync word filtering and generation.
Definition: CC1101.cpp:848
int16_t standby() override
Sets the module to standby mode.
Definition: CC1101.cpp:170
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:970
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
int16_t disableAddressFiltering()
Disables address filtering. Calling this method will also erase previously set addresses.
Definition: CC1101.cpp:757
void setGdo0Action(void(*func)(void), uint32_t dir)
Sets interrupt service routine to call when GDO0 activates.
Definition: CC1101.cpp:253
int16_t receiveDirectAsync()
Starts asynchronous direct mode reception.
Definition: CC1101.cpp:229
int16_t receiveDirect() override
Starts synchronous direct mode reception.
Definition: CC1101.cpp:225
int16_t setEncoding(uint8_t encoding) override
Sets transmission encoding. Allowed values are RADIOLIB_ENCODING_NRZ, RADIOLIB_ENCODING_MANCHESTER,...
Definition: CC1101.cpp:942
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:587
void clearGdo0Action()
Clears interrupt service routine to call when GDO0 activates.
Definition: CC1101.cpp:257
float getRSSI() override
Gets RSSI (Recorded Signal Strength Indicator) of the last received packet. In asynchronous direct mo...
Definition: CC1101.cpp:796
virtual int16_t receive(uint8_t *data, size_t len)
Binary receive method. Must be implemented in module class.
Definition: PhysicalLayer.cpp:112
int16_t getFrequencyDeviation(float *freqDev)
Gets frequency deviation.
Definition: CC1101.cpp:537
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:882
void clearGdo2Action()
Clears interrupt service routine to call when GDO0 activates.
Definition: CC1101.cpp:285
int16_t fixedPacketLengthMode(uint8_t len=RADIOLIB_CC1101_MAX_PACKET_LENGTH)
Set modem in fixed packet length mode.
Definition: CC1101.cpp:834
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:425
void setGdo2Action(void(*func)(void), uint32_t dir)
Sets interrupt service routine to call when GDO2 activates.
Definition: CC1101.cpp:277
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 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:923
int16_t startReceive() override
Interrupt-driven receive method. GDO0 will be activated when full packet is received.
Definition: CC1101.cpp:342
int16_t setPreambleLength(uint8_t preambleLength, uint8_t qualityThreshold)
Sets preamble length.
Definition: CC1101.cpp:704
bool getPromiscuousMode()
Get whether the modem is in promiscuous mode: no packet filtering (e.g., no preamble,...
Definition: CC1101.cpp:919
int16_t transmitDirectAsync(uint32_t frf=0)
Starts asynchronous direct mode transmission.
Definition: CC1101.cpp:198
int16_t finishTransmit() override
Clean up after transmission is done.
Definition: CC1101.cpp:331
int16_t setOOK(bool enableOOK)
Enables/disables OOK modulation instead of FSK.
Definition: CC1101.cpp:767
Implements all common low-level methods to control the wireless module. Every module class contains o...
Definition: Module.h:65
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:74
Provides common interface for protocols that run on LoRa/FSK modules, such as RTTY or LoRaWAN....
Definition: PhysicalLayer.h:54
virtual int16_t readData(uint8_t *data, size_t len)
Reads data that was received after calling startReceive method.
Definition: PhysicalLayer.cpp:209
int16_t transmit(const char *str, uint8_t addr=0)
C-string transmit method.
Definition: PhysicalLayer.cpp:52
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
virtual int16_t receive(uint8_t *data, size_t len)
Binary receive method. Must be implemented in module class.
Definition: PhysicalLayer.cpp:112
Description of RF switch pin states for a single mode. See setRfSwitchTable for details.
Definition: Module.h:81