32#ifndef IIO_FREQUENCY_AD9361_H_
33#define IIO_FREQUENCY_AD9361_H_
39#define REG_SPI_CONF 0x000
40#define REG_MULTICHIP_SYNC_AND_TX_MON_CTRL 0x001
41#define REG_TX_ENABLE_FILTER_CTRL 0x002
42#define REG_RX_ENABLE_FILTER_CTRL 0x003
43#define REG_INPUT_SELECT 0x004
44#define REG_RFPLL_DIVIDERS 0x005
45#define REG_RX_CLOCK_DATA_DELAY 0x006
46#define REG_TX_CLOCK_DATA_DELAY 0x007
47#define REG_CLOCK_ENABLE 0x009
48#define REG_BBPLL 0x00A
49#define REG_TEMP_OFFSET 0x00B
50#define REG_START_TEMP_READING 0x00C
51#define REG_TEMP_SENSE2 0x00D
52#define REG_TEMPERATURE 0x00E
53#define REG_TEMP_SENSOR_CONFIG 0x00F
54#define REG_PARALLEL_PORT_CONF_1 0x010
55#define REG_PARALLEL_PORT_CONF_2 0x011
56#define REG_PARALLEL_PORT_CONF_3 0x012
57#define REG_ENSM_MODE 0x013
58#define REG_ENSM_CONFIG_1 0x014
59#define REG_ENSM_CONFIG_2 0x015
60#define REG_CALIBRATION_CTRL 0x016
61#define REG_STATE 0x017
62#define REG_AUXDAC_1_WORD 0x018
63#define REG_AUXDAC_2_WORD 0x019
64#define REG_AUXDAC_1_CONFIG 0x01A
65#define REG_AUXDAC_2_CONFIG 0x01B
66#define REG_AUXADC_CLOCK_DIVIDER 0x01C
67#define REG_AUXADC_CONFIG 0x01D
68#define REG_AUXADC_WORD_MSB 0x01E
69#define REG_AUXADC_LSB 0x01F
70#define REG_AUTO_GPO 0x020
71#define REG_AGC_GAIN_LOCK_DELAY 0x021
72#define REG_AGC_ATTACK_DELAY 0x022
73#define REG_AUXDAC_ENABLE_CTRL 0x023
74#define REG_RX_LOAD_SYNTH_DELAY 0x024
75#define REG_TX_LOAD_SYNTH_DELAY 0x025
76#define REG_EXTERNAL_LNA_CTRL 0x026
77#define REG_GPO_FORCE_AND_INIT 0x027
78#define REG_GPO0_RX_DELAY 0x028
79#define REG_GPO1_RX_DELAY 0x029
80#define REG_GPO2_RX_DELAY 0x02A
81#define REG_GPO3_RX_DELAY 0x02B
82#define REG_GPO0_TX_DELAY 0x02C
83#define REG_GPO1_TX_DELAY 0x02D
84#define REG_GPO2_TX_DELAY 0x02E
85#define REG_GPO3_TX_DELAY 0x02F
86#define REG_AUXDAC1_RX_DELAY 0x030
87#define REG_AUXDAC1_TX_DELAY 0x031
88#define REG_AUXDAC2_RX_DELAY 0x032
89#define REG_AUXDAC2_TX_DELAY 0x033
90#define REG_CTRL_OUTPUT_POINTER 0x035
91#define REG_CTRL_OUTPUT_ENABLE 0x036
92#define REG_PRODUCT_ID 0x037
93#define REG_REFERENCE_CLOCK_CYCLES 0x03A
94#define REG_DIGITAL_IO_CTRL 0x03B
95#define REG_LVDS_BIAS_CTRL 0x03C
96#define REG_LVDS_INVERT_CTRL1 0x03D
97#define REG_LVDS_INVERT_CTRL2 0x03E
98#define REG_SDM_CTRL_1 0x03F
99#define REG_FRACT_BB_FREQ_WORD_1 0x041
100#define REG_FRACT_BB_FREQ_WORD_2 0x042
101#define REG_FRACT_BB_FREQ_WORD_3 0x043
102#define REG_INTEGER_BB_FREQ_WORD 0x044
103#define REG_CLOCK_CTRL 0x045
104#define REG_CP_CURRENT 0x046
105#define REG_CP_BLEED_CURRENT 0x047
106#define REG_LOOP_FILTER_1 0x048
107#define REG_LOOP_FILTER_2 0x049
108#define REG_LOOP_FILTER_3 0x04A
109#define REG_VCO_CTRL 0x04B
110#define REG_VCO_PROGRAM_1 0x04C
111#define REG_VCO_PROGRAM_2 0x04D
112#define REG_SDM_CTRL 0x04E
113#define REG_RX_SYNTH_POWER_DOWN_OVERRIDE 0x050
114#define REG_TX_SYNTH_POWER_DOWN_OVERRIDE 0x051
115#define REG_RX_ANALOG_POWER_DOWN_OVERRIDE_1 0x052
116#define REG_RX_ANALOG_POWER_DOWN_OVERRIDE_2 0x053
117#define REG_RX1_ADC_POWER_DOWN_OVERRIDE 0x054
118#define REG_RX2_ADC_POWER_DOWN_OVERRIDE 0x055
119#define REG_TX_ANALOG_POWER_DOWN_OVERRIDE_1 0x056
120#define REG_ANALOG_POWER_DOWN_OVERRIDE 0x057
121#define REG_MISC_POWER_DOWN_OVERRIDE 0x058
122#define REG_CH_1_OVERFLOW 0x05E
123#define REG_CH_2_OVERFLOW 0x05F
124#define REG_TX_FILTER_COEF_ADDR 0x060
125#define REG_TX_FILTER_COEF_WRITE_DATA_1 0x061
126#define REG_TX_FILTER_COEF_WRITE_DATA_2 0x062
127#define REG_TX_FILTER_COEF_READ_DATA_1 0x063
128#define REG_TX_FILTER_COEF_READ_DATA_2 0x064
129#define REG_TX_FILTER_CONF 0x065
130#define REG_TX_MON_LOW_GAIN 0x067
131#define REG_TX_MON_HIGH_GAIN 0x068
132#define REG_TX_MON_DELAY 0x069
133#define REG_TX_LEVEL_THRESH 0x06A
134#define REG_TX_RSSI1 0x06B
135#define REG_TX_RSSI2 0x06C
136#define REG_TX_RSSI_LSB 0x06D
137#define REG_TPM_MODE_ENABLE 0x06E
138#define REG_TX_MON_TEMP_GAIN_COEF 0x06F
139#define REG_TX_MON_1_CONFIG 0x070
140#define REG_TX_MON_2_CONFIG 0x071
141#define REG_TX1_ATTEN_0 0x073
142#define REG_TX1_ATTEN_1 0x074
143#define REG_TX2_ATTEN_0 0x075
144#define REG_TX2_ATTEN_1 0x076
145#define REG_TX_ATTEN_OFFSET 0x077
146#define REG_TX_ATTEN_THRESH 0x078
147#define REG_TX1_DIG_ATTEN 0x079
148#define REG_TX2_DIG_ATTEN 0x07C
149#define REG_TX1_SYMBOL_ATTEN 0x07F
150#define REG_TX2_SYMBOL_ATTEN 0x080
151#define REG_TX_SYMBOL_ATTEN_CONFIG 0x081
152#define REG_TX1_OUT_1_PHASE_CORR 0x08E
153#define REG_TX1_OUT_1_GAIN_CORR 0x08F
154#define REG_TX2_OUT_1_PHASE_CORR 0x090
155#define REG_TX2_OUT_1_GAIN_CORR 0x091
156#define REG_TX1_OUT_1_OFFSET_I 0x092
157#define REG_TX1_OUT_1_OFFSET_Q 0x093
158#define REG_TX2_OUT_1_OFFSET_I 0x094
159#define REG_TX2_OUT_1_OFFSET_Q 0x095
160#define REG_TX1_OUT_2_PHASE_CORR 0x096
161#define REG_TX1_OUT_2_GAIN_CORR 0x097
162#define REG_TX2_OUT_2_PHASE_CORR 0x098
163#define REG_TX2_OUT_2_GAIN_CORR 0x099
164#define REG_TX1_OUT_2_OFFSET_I 0x09A
165#define REG_TX1_OUT_2_OFFSET_Q 0x09B
166#define REG_TX2_OUT_2_OFFSET_I 0x09C
167#define REG_TX2_OUT_2_OFFSET_Q 0x09D
168#define REG_TX_FORCE_BITS 0x09F
169#define REG_QUAD_CAL_NCO_FREQ_PHASE_OFFSET 0x0A0
170#define REG_QUAD_CAL_CTRL 0x0A1
171#define REG_KEXP_1 0x0A2
172#define REG_KEXP_2 0x0A3
173#define REG_QUAD_SETTLE_COUNT 0x0A4
174#define REG_MAG_FTEST_THRESH 0x0A5
175#define REG_MAG_FTEST_THRESH_2 0x0A6
176#define REG_QUAD_CAL_STATUS_TX1 0x0A7
177#define REG_QUAD_CAL_STATUS_TX2 0x0A8
178#define REG_QUAD_CAL_COUNT 0x0A9
179#define REG_TX_QUAD_FULL_LMT_GAIN 0x0AA
180#define REG_SQUARER_CONFIG 0x0AB
181#define REG_TX_QUAD_CAL_ATTEN 0x0AC
182#define REG_THRESH_ACCUM 0x0AD
183#define REG_TX_QUAD_LPF_GAIN 0x0AE
184#define REG_TXDAC_VDS_I 0x0B0
185#define REG_TXDAC_VDS_Q 0x0B1
186#define REG_TXDAC_GN_I 0x0B2
187#define REG_TXDAC_GN_Q 0x0B3
188#define REG_TXBBF_OPAMP_A 0x0C0
189#define REG_TXBBF_OPAMP_B 0x0C1
190#define REG_TX_BBF_R1 0x0C2
191#define REG_TX_BBF_R2 0x0C3
192#define REG_TX_BBF_R3 0x0C4
193#define REG_TX_BBF_R4 0x0C5
194#define REG_TX_BBF_RP 0x0C6
195#define REG_TX_BBF_C1 0x0C7
196#define REG_TX_BBF_C2 0x0C8
197#define REG_TX_BBF_CP 0x0C9
198#define REG_TX_TUNE_CTRL 0x0CA
199#define REG_TX_BBF_R2B 0x0CB
200#define REG_TX_BBF_TUNE 0x0CC
201#define REG_CONFIG0 0x0D0
202#define REG_RESISTOR 0x0D1
203#define REG_CAPACITOR 0x0D2
204#define REG_LO_CM 0x0D3
205#define REG_TX_BBF_TUNE_DIVIDER 0x0D6
206#define REG_TX_BBF_TUNE_MODE 0x0D7
207#define REG_RX_FILTER_COEF_ADDR 0x0F0
208#define REG_RX_FILTER_COEF_DATA_1 0x0F1
209#define REG_RX_FILTER_COEF_DATA_2 0x0F2
210#define REG_RX_FILTER_COEF_READ_DATA_1 0x0F3
211#define REG_RX_FILTER_COEF_READ_DATA_2 0x0F4
212#define REG_RX_FILTER_CONFIG 0x0F5
213#define REG_RX_FILTER_GAIN 0x0F6
214#define REG_AGC_CONFIG_1 0x0FA
215#define REG_AGC_CONFIG_2 0x0FB
216#define REG_AGC_CONFIG_3 0x0FC
217#define REG_MAX_LMT_FULL_GAIN 0x0FD
218#define REG_PEAK_WAIT_TIME 0x0FE
219#define REG_DIGITAL_GAIN 0x100
220#define REG_AGC_LOCK_LEVEL 0x101
221#define REG_ADC_NOISE_CORRECTION_FACTOR 0x102
222#define REG_GAIN_STP_CONFIG1 0x103
223#define REG_ADC_SMALL_OVERLOAD_THRESH 0x104
224#define REG_ADC_LARGE_OVERLOAD_THRESH 0x105
225#define REG_GAIN_STP_CONFIG_2 0x106
226#define REG_SMALL_LMT_OVERLOAD_THRESH 0x107
227#define REG_LARGE_LMT_OVERLOAD_THRESH 0x108
228#define REG_RX1_MANUAL_LMT_FULL_GAIN 0x109
229#define REG_RX1_MANUAL_LPF_GAIN 0x10A
230#define REG_RX1_MANUAL_DIGITALFORCED_GAIN 0x10B
231#define REG_RX2_MANUAL_LMT_FULL_GAIN 0x10C
232#define REG_RX2_MANUAL_LPF_GAIN 0x10D
233#define REG_RX2_MANUAL_DIGITALFORCED_GAIN 0x10E
234#define REG_FAST_CONFIG_1 0x110
235#define REG_FAST_CONFIG_2_SETTLING_DELAY 0x111
236#define REG_FAST_ENERGY_LOST_THRESH 0x112
237#define REG_FAST_STRONGER_SIGNAL_THRESH 0x113
238#define REG_FAST_LOW_POWER_THRESH 0x114
239#define REG_FAST_STRONG_SIGNAL_FREEZE 0x115
240#define REG_FAST_FINAL_OVER_RANGE_AND_OPT_GAIN 0x116
241#define REG_FAST_ENERGY_DETECT_COUNT 0x117
242#define REG_FAST_AGCLL_UPPER_LIMIT 0x118
243#define REG_FAST_GAIN_LOCK_EXIT_COUNT 0x119
244#define REG_FAST_INITIAL_LMT_GAIN_LIMIT 0x11A
245#define REG_FAST_INCREMENT_TIME 0x11B
246#define REG_AGC_INNER_LOW_THRESH 0x120
247#define REG_LMT_OVERLOAD_COUNTERS 0x121
248#define REG_ADC_OVERLOAD_COUNTERS 0x122
249#define REG_GAIN_STP1 0x123
250#define REG_GAIN_UPDATE_COUNTER1 0x124
251#define REG_GAIN_UPDATE_COUNTER2 0x125
252#define REG_DIGITAL_SAT_COUNTER 0x128
253#define REG_OUTER_POWER_THRESHS 0x129
254#define REG_GAIN_STP_2 0x12A
255#define REG_EXT_LNA_HIGH_GAIN 0x12C
256#define REG_EXT_LNA_LOW_GAIN 0x12D
257#define REG_GAIN_TABLE_ADDRESS 0x130
258#define REG_GAIN_TABLE_WRITE_DATA1 0x131
259#define REG_GAIN_TABLE_WRITE_DATA2 0x132
260#define REG_GAIN_TABLE_WRITE_DATA3 0x133
261#define REG_GAIN_TABLE_READ_DATA1 0x134
262#define REG_GAIN_TABLE_READ_DATA2 0x135
263#define REG_GAIN_TABLE_READ_DATA3 0x136
264#define REG_GAIN_TABLE_CONFIG 0x137
265#define REG_GM_SUB_TABLE_ADDRESS 0x138
266#define REG_GM_SUB_TABLE_GAIN_WRITE 0x139
267#define REG_GM_SUB_TABLE_BIAS_WRITE 0x13A
268#define REG_GM_SUB_TABLE_CTRL_WRITE 0x13B
269#define REG_GM_SUB_TABLE_GAIN_READ 0x13C
270#define REG_GM_SUB_TABLE_BIAS_READ 0x13D
271#define REG_GM_SUB_TABLE_CTRL_READ 0x13E
272#define REG_GM_SUB_TABLE_CONFIG 0x13F
273#define REG_WORD_ADDRESS 0x140
274#define REG_GAIN_DIFF_WORDERROR_WRITE 0x141
275#define REG_GAIN_ERROR_READ 0x142
276#define REG_CONFIG 0x143
277#define REG_LNA_GAIN_DIFF_READ_BACK 0x144
278#define REG_MAX_MIXER_CALIBRATION_GAIN_INDEX 0x145
279#define REG_TEMP_GAIN_COEF 0x146
280#define REG_SETTLE_TIME 0x147
281#define REG_MEASURE_DURATION 0x148
282#define REG_CAL_TEMP_SENSOR_WORD 0x149
283#define REG_MEASURE_DURATION_01 0x150
284#define REG_MEASURE_DURATION_23 0x151
285#define REG_RSSI_WEIGHT_0 0x152
286#define REG_RSSI_WEIGHT_1 0x153
287#define REG_RSSI_WEIGHT_2 0x154
288#define REG_RSSI_WEIGHT_3 0x155
289#define REG_RSSI_DELAY 0x156
290#define REG_RSSI_WAIT_TIME 0x157
291#define REG_RSSI_CONFIG 0x158
292#define REG_ADC_MEASURE_DURATION_01 0x159
293#define REG_ADC_WEIGHT_0 0x15A
294#define REG_ADC_WEIGHT_1 0x15B
295#define REG_DEC_POWER_MEASURE_DURATION_0 0x15C
296#define REG_LNA_GAIN 0x15D
297#define REG_CH1_ADC_POWER 0x160
298#define REG_CH1_RX_FILTER_POWER 0x161
299#define REG_CH2_ADC_POWER 0x162
300#define REG_CH2_RX_FILTER_POWER 0x163
301#define REG_RX_QUAD_CAL_LEVEL 0x168
302#define REG_CALIBRATION_CONFIG_1 0x169
303#define REG_CALIBRATION_CONFIG_2 0x16A
304#define REG_CALIBRATION_CONFIG_3 0x16B
305#define REG_CALIB_COUNT 0x16C
306#define REG_SETTLE_COUNT 0x16D
307#define REG_RX_QUAD_GAIN1 0x16E
308#define REG_RX_QUAD_GAIN2 0x16F
309#define REG_RX1_INPUT_A_PHASE_CORR 0x170
310#define REG_RX1_INPUT_A_GAIN_CORR 0x171
311#define REG_RX2_INPUT_A_PHASE_CORR 0x172
312#define REG_RX2_INPUT_A_GAIN_CORR 0x173
313#define REG_RX1_INPUT_A_Q_OFFSET 0x174
314#define REG_RX1_INPUT_A_OFFSETS 0x175
315#define REG_INPUT_A_OFFSETS_1 0x176
316#define REG_RX2_INPUT_A_OFFSETS 0x177
317#define REG_RX2_INPUT_A_I_OFFSET 0x178
318#define REG_RX1_INPUT_BC_PHASE_CORR 0x179
319#define REG_RX1_INPUT_BC_GAIN_CORR 0x17A
320#define REG_RX2_INPUT_BC_PHASE_CORR 0x17B
321#define REG_RX2_INPUT_BC_GAIN_CORR 0x17C
322#define REG_RX1_INPUT_BC_Q_OFFSET 0x17D
323#define REG_RX1_INPUT_BC_OFFSETS 0x17E
324#define REG_INPUT_BC_OFFSETS_1 0x17F
325#define REG_RX2_INPUT_BC_OFFSETS 0x180
326#define REG_RX2_INPUT_BC_I_OFFSET 0x181
327#define REG_FORCE_BITS 0x182
328#define REG_WAIT_COUNT 0x185
329#define REG_RF_DC_OFFSET_COUNT 0x186
330#define REG_RF_DC_OFFSET_CONFIG_1 0x187
331#define REG_RF_DC_OFFSET_ATTEN 0x188
332#define REG_INVERT_BITS 0x189
333#define REG_DC_OFFSET_CONFIG2 0x18B
334#define REG_RF_CAL_GAIN_INDEX 0x18C
335#define REG_SOI_THRESH 0x18D
336#define REG_BB_DC_OFFSET_SHIFT 0x190
337#define REG_BB_DC_OFFSET_FAST_SETTLE_SHIFT 0x191
338#define REG_BB_FAST_SETTLE_DUR 0x192
339#define REG_BB_DC_OFFSET_COUNT 0x193
340#define REG_BB_DC_OFFSET_ATTEN 0x194
341#define REG_RX1_BB_DC_WORD_I_MSB 0x19A
342#define REG_RX1_BB_DC_WORD_I_LSB 0x19B
343#define REG_RX1_BB_DC_WORD_Q_MSB 0x19C
344#define REG_RX1_BB_DC_WORD_Q_LSB 0x19D
345#define REG_RX2_BB_DC_WORD_I_MSB 0x19E
346#define REG_RX2_BB_DC_WORD_I_LSB 0x19F
347#define REG_RX2_BB_DC_WORD_Q_MSB 0x1A0
348#define REG_RX2_BB_DC_WORD_Q_LSB 0x1A1
349#define REG_BB_TRACK_CORR_WORD_I_MSB 0x1A2
350#define REG_BB_TRACK_CORR_WORD_I_LSB 0x1A3
351#define REG_BB_TRACK_CORR_WORD_Q_MSB 0x1A4
352#define REG_BB_TRACK_CORR_WORD_Q_LSB 0x1A5
353#define REG_RX1_RSSI_SYMBOL 0x1A7
354#define REG_RX1_RSSI_PREAMBLE 0x1A8
355#define REG_RX2_RSSI_SYMBOL 0x1A9
356#define REG_RX2_RSSI_PREAMBLE 0x1AA
357#define REG_SYMBOL_LSB 0x1AB
358#define REG_PREAMBLE_LSB 0x1AC
359#define REG_RX_PATH_GAIN_MSB 0x1AD
360#define REG_RX_PATH_GAIN_LSB 0x1AE
361#define REG_RX_DIFF_LNA_FORCE 0x1B0
362#define REG_RX_LNA_BIAS_COARSE 0x1B1
363#define REG_RX_LNA_BIAS_FINE_0 0x1B2
364#define REG_RX_LNA_BIAS_FINE_1 0x1B3
365#define REG_RX_MIX_GM_CONFIG 0x1C0
366#define REG_RX1_MIX_GM_FORCE 0x1C1
367#define REG_RX1_MIX_GM_BIAS_FORCE 0x1C2
368#define REG_RX2_MIX_GM_FORCE 0x1C3
369#define REG_RX2_MIX_GM_BIAS_FORCE 0x1C4
370#define REG_INPUT_A_MSBS 0x1C8
371#define REG_INPUT_A_RX1_I 0x1C9
372#define REG_INPUT_A_RX1_Q 0x1CA
373#define REG_INPUT_A_RX2_I 0x1CB
374#define REG_INPUT_A_RX2_Q 0x1CC
375#define REG_INPUTS_BC_RX1_I 0x1CD
376#define REG_BAND1_RX1_Q 0x1CE
377#define REG_INPUTS_BC_RX2_I 0x1CF
378#define REG_INPUTS_BC_RX2_Q 0x1D0
379#define REG_INPUTS_BC_MSBS 0x1D1
380#define REG_FORCE_OS_DAC 0x1D2
381#define REG_RX_MIX_LO_CM 0x1D5
382#define REG_RX_CGB_SEG_ENABLE 0x1D6
383#define REG_RX_MIX_INPUTBIAS 0x1D7
384#define REG_RX_TIA_CONFIG 0x1DB
385#define REG_TIA1_C_LSB 0x1DC
386#define REG_TIA1_C_MSB 0x1DD
387#define REG_TIA2_C_LSB 0x1DE
388#define REG_TIA2_C_MSB 0x1DF
389#define REG_RX1_BBF_R1A 0x1E0
390#define REG_RX2_BBF_R1A 0x1E1
391#define REG_RX1_TUNE_CTRL 0x1E2
392#define REG_RX2_TUNE_CTRL 0x1E3
393#define REG_RX1_BBF_R5 0x1E4
394#define REG_RX2_BBF_R5 0x1E5
395#define REG_RX_BBF_R2346 0x1E6
396#define REG_RX_BBF_C1_MSB 0x1E7
397#define REG_RX_BBF_C1_LSB 0x1E8
398#define REG_RX_BBF_C2_MSB 0x1E9
399#define REG_RX_BBF_C2_LSB 0x1EA
400#define REG_RX_BBF_C3_MSB 0x1EB
401#define REG_RX_BBF_C3_LSB 0x1EC
402#define REG_RX_BBF_CC1_CTR 0x1ED
403#define REG_RX_BBF_POW_RZ_BYTE0 0x1EE
404#define REG_RX_BBF_CC2_CTR 0x1EF
405#define REG_RX_BBF_POW_RZ_BYTE1 0x1F0
406#define REG_RX_BBF_CC3_CTR 0x1F1
407#define REG_RX_BBF_R5_TUNE 0x1F2
408#define REG_RX_BBF_TUNE 0x1F3
409#define REG_RX1_BBF_MAN_GAIN 0x1F4
410#define REG_RX2_BBF_MAN_GAIN 0x1F5
411#define REG_RX_BBF_TUNE_DIVIDE 0x1F8
412#define REG_RX_BBF_TUNE_CONFIG 0x1F9
413#define REG_POLE_GAIN 0x1FA
414#define REG_RX_BBBW_MHZ 0x1FB
415#define REG_RX_BBBW_KHZ 0x1FC
416#define REG_FB_DAC_CLK_DELAY1 0x201
417#define REG_FB_DAC_CLK_DELAY2 0x202
418#define REG_FLASH_SAMPLE_CLK_DELAY_3P 0x203
419#define REG_FLASH_SAMPLE_CLK_DELAY_3N 0x204
420#define REG_TEST_MUX_2I 0x205
421#define REG_TEST_MUX_2Q 0x206
422#define REG_INTEGRATOR_1_RESISTANCE 0x207
423#define REG_INTEGRATOR_1_CAPACITANCE 0x208
424#define REG_INTEGRATOR_23_RESISTANCE 0x209
425#define REG_INTEGRATOR_2_RESISTANCE 0x20A
426#define REG_INTEGRATOR_2_CAPACITANCE 0x20B
427#define REG_INTEGRATOR_3_RESISTANCE 0x20C
428#define REG_INTEGRATOR_3_CAPACITANCE 0x20D
429#define REG_INTEGRATOR_AMP_CC 0x20E
430#define REG_INT_1_FB_DAC_NMOS_CURRENT_SOURCE 0x20F
431#define REG_INT_1_FB_DAC_NMOS_CASOADE_BIAS_CURRENT 0x210
432#define REG_INT_1_FB_DAC_PMOS_CURRENT_SOURCE 0x211
433#define REG_INT_2_FB_DAC_NMOS_CURRENT_SOURCE 0x212
434#define REG_INT_2_FB_DAC_NMOS_CASCODE_BIAS_CURRENT 0x213
435#define REG_INT_2_FB_DAC_PMOS_CURRENT_SOURCE 0x214
436#define REG_INT_3_FB_DAC_NMOS_CURRENT_SOURCE 0x215
437#define REG_INT_3_FB_DAC_NMOS_CASCODE_BIAS_CURRENT 0x216
438#define REG_INT_3_FB_DAC_PMOS_CURRENT_SOURCE 0x217
439#define REG_FB_DAC_BIAS_CURRENT 0x218
440#define REG_INT_1_1ST_STAGE_CURRENT 0x219
441#define REG_INT_1_1ST_STAGE_CASCODE_CURRENT 0x21A
442#define REG_INT_1_2ND_STAGE_CURRENT 0x21B
443#define REG_INTEGRATOR_2_1ST_STAGE_CURRENT 0x21C
444#define REG_INT_2_1ST_STAGE_CASCODE_CURRENT 0x21D
445#define REG_INT_2_2ND_STAGE_CURRENT 0x21E
446#define REG_INT_3_1ST_STAGE_CURRENT 0x21F
447#define REG_INT_3_1ST_STAGE_CASCODE_CURRENT 0x220
448#define REG_INT_3_2ND_STAGE_CURRENT 0x221
449#define REG_FLASH_BIAS_CURRENT 0x222
450#define REG_FLASH_LADDER_BIAS 0x223
451#define REG_FLASH_LADDER_CASCODE_CURRENT 0x224
452#define REG_FLASH_LADDER_BIAS2 0x225
453#define REG_RESET 0x226
454#define REG_RX_PFD_CONFIG 0x230
455#define REG_RX_INTEGER_BYTE_0 0x231
456#define REG_RX_INTEGER_BYTE_1 0x232
457#define REG_RX_FRACT_BYTE_0 0x233
458#define REG_RX_FRACT_BYTE_1 0x234
459#define REG_RX_FRACT_BYTE_2 0x235
460#define REG_RX_FORCE_ALC 0x236
461#define REG_RX_FORCE_VCO_TUNE_0 0x237
462#define REG_RX_FORCE_VCO_TUNE_1 0x238
463#define REG_RX_ALC_VARACTOR 0x239
464#define REG_RX_VCO_OUTPUT 0x23A
465#define REG_RX_CP_CURRENT 0x23B
466#define REG_RX_CP_OFFSET 0x23C
467#define REG_RX_CP_CONFIG 0x23D
468#define REG_RX_LOOP_FILTER_1 0x23E
469#define REG_RX_LOOP_FILTER_2 0x23F
470#define REG_RX_LOOP_FILTER_3 0x240
471#define REG_RX_DITHERCP_CAL 0x241
472#define REG_RX_VCO_BIAS_1 0x242
473#define REG_RX_CAL_STATUS 0x244
474#define REG_RX_VCO_CAL_REF 0x245
475#define REG_RX_VCO_PD_OVERRIDES 0x246
476#define REG_RX_CP_OVERRANGE_VCO_LOCK 0x247
477#define REG_RX_VCO_LDO 0x248
478#define REG_RX_VCO_CAL 0x249
479#define REG_RX_LOCK_DETECT_CONFIG 0x24A
480#define REG_RX_CP_LEVEL_DETECT 0x24B
481#define REG_RX_DSM_SETUP_0 0x24C
482#define REG_RX_DSM_SETUP_1 0x24D
483#define REG_RX_CORRECTION_WORD0 0x24E
484#define REG_RX_CORRECTION_WORD1 0x24F
485#define REG_RX_VCO_VARACTOR_CTRL_0 0x250
486#define REG_RX_VCO_VARACTOR_CTRL_1 0x251
487#define REG_RX_FAST_LOCK_SETUP 0x25A
488#define REG_RX_FAST_LOCK_SETUP_INIT_DELAY 0x25B
489#define REG_RX_FAST_LOCK_PROGRAM_ADDR 0x25C
490#define REG_RX_FAST_LOCK_PROGRAM_DATA 0x25D
491#define REG_RX_FAST_LOCK_PROGRAM_READ 0x25E
492#define REG_RX_FAST_LOCK_PROGRAM_CTRL 0x25F
493#define REG_RX_LO_GEN_POWER_MODE 0x261
494#define REG_TX_PFD_CONFIG 0x270
495#define REG_TX_INTEGER_BYTE_0 0x271
496#define REG_TX_INTEGER_BYTE_1 0x272
497#define REG_TX_FRACT_BYTE_0 0x273
498#define REG_TX_FRACT_BYTE_1 0x274
499#define REG_TX_FRACT_BYTE_2 0x275
500#define REG_TX_FORCE_ALC 0x276
501#define REG_TX_FORCE_VCO_TUNE_0 0x277
502#define REG_TX_FORCE_VCO_TUNE_1 0x278
503#define REG_TX_ALCVARACT_OR 0x279
504#define REG_TX_VCO_OUTPUT 0x27A
505#define REG_TX_CP_CURRENT 0x27B
506#define REG_TX_CP_OFFSET 0x27C
507#define REG_TX_CP_CONFIG 0x27D
508#define REG_TX_LOOP_FILTER_1 0x27E
509#define REG_TX_LOOP_FILTER_2 0x27F
510#define REG_TX_LOOP_FILTER_3 0x280
511#define REG_TX_DITHERCP_CAL 0x281
512#define REG_TX_VCO_BIAS_1 0x282
513#define REG_TX_VCO_BIAS_2 0x283
514#define REG_TX_CAL_STATUS 0x284
515#define REG_TX_VCO_CAL_REF 0x285
516#define REG_TX_VCO_PD_OVERRIDES 0x286
517#define REG_TX_CP_OVERRANGE_VCO_LOCK 0x287
518#define REG_TX_VCO_LDO 0x288
519#define REG_TX_VCO_CAL 0x289
520#define REG_TX_LOCK_DETECT_CONFIG 0x28A
521#define REG_TX_CP_LEVEL_DETECT 0x28B
522#define REG_TX_DSM_SETUP_0 0x28C
523#define REG_TX_DSM_SETUP_1 0x28D
524#define REG_TX_CORRECTION_WORD0 0x28E
525#define REG_TX_CORRECTION_WORD1 0x28F
526#define REG_TX_VCO_VARACTOR_CTRL_0 0x290
527#define REG_TX_VCO_VARACTOR_CTRL_1 0x291
528#define REG_DCXO_COARSE_TUNE 0x292
529#define REG_DCXO_FINE_TUNE_HIGH 0x293
530#define REG_DCXO_FINE_TUNE_LOW 0x294
531#define REG_DCXO_CONFIG 0x295
532#define REG_DCXO_TEMPCO_WRITE 0x296
533#define REG_DCXO_TEMPCO_READ 0x297
534#define REG_DCXO_TEMPCO_ADDR 0x298
535#define REG_DELTA_T_READ 0x299
536#define REG_TX_FAST_LOCK_SETUP 0x29A
537#define REG_TX_FAST_LOCK_SETUP_INIT_DELAY 0x29B
538#define REG_TX_FAST_LOCK_PROGRAM_ADDR 0x29C
539#define REG_TX_FAST_LOCK_PROGRAM_DATA 0x29D
540#define REG_TX_FAST_LOCK_PROGRAM_READ 0x29E
541#define REG_TX_FAST_LOCK_PROGRAM_CTRL 0x29F
542#define REG_TX_LO_GEN_POWER_MODE 0x2A1
543#define REG_BANDGAP_CONFIG0 0x2A6
544#define REG_BANDGAP_CONFIG1 0x2A8
545#define REG_REF_DIVIDE_CONFIG_1 0x2AB
546#define REG_REF_DIVIDE_CONFIG_2 0x2AC
547#define REG_GAIN_RX1 0x2B0
548#define REG_LPF_GAIN_RX1 0x2B1
549#define REG_DIG_GAIN_RX1 0x2B2
550#define REG_FAST_ATTACK_STATE 0x2B3
551#define REG_SLOW_LOOP_STATE 0x2B4
552#define REG_GAIN_RX2 0x2B5
553#define REG_LPF_GAIN_RX2 0x2B6
554#define REG_DIG_GAIN_RX2 0x2B7
555#define REG_OVRG_SIGS_RX1 0x2B8
556#define REG_OVRG_SIGS_RX2 0x2B9
557#define REG_CTRL 0x3DF
558#define REG_BIST_CONFIG 0x3F4
559#define REG_OBSERVE_CONFIG 0x3F5
560#define REG_BIST_AND_DATA_PORT_TEST_CONFIG 0x3F6
561#define REG_DAC_TEST_0 0x3FC
562#define REG_DAC_TEST_1 0x3FD
563#define REG_DAC_TEST_2 0x3FE
568#define SOFT_RESET (1 << 7)
569#define WIRE3_SPI (1 << 6)
570#define LSB_FIRST (1 << 5)
571#define _LSB_FIRST (1 << 2)
572#define _WIRE3_SPI (1 << 1)
573#define _SOFT_RESET (1 << 0)
578#define TX2_MONITOR_ENABLE (1 << 6)
579#define TX1_MONITOR_ENABLE (1 << 5)
580#define MCS_RF_ENABLE (1 << 3)
581#define MCS_BBPLL_ENABLE (1 << 2)
582#define MCS_DIGITAL_CLK_ENABLE (1 << 1)
583#define MCS_BB_ENABLE (1 << 0)
588#define THB2_EN (1 << 3)
589#define THB1_EN (1 << 2)
590#define TX_CHANNEL_ENABLE(x) (((x) & 0x3) << 6)
591#define THB3_ENABLE_INTERP(x) (((x) & 0x3) << 4)
592#define TX_FIR_ENABLE_INTERPOLATION(x) (((x) & 0x3) << 0)
601#define RHB2_EN (1 << 3)
602#define RHB1_EN (1 << 2)
603#define RX_CHANNEL_ENABLE(x) (((x) & 0x3) << 6)
604#define DEC3_ENABLE_DECIMATION(x) (((x) & 0x3) << 4)
605#define RX_FIR_ENABLE_DECIMATION(x) (((x) & 0x3) << 0)
614#define TX_OUTPUT (1 << 6)
615#define RX_INPUT(x) (((x) & 0x3F) << 0)
620#define TX_VCO_DIVIDER(x) (((x) & 0xF) << 4)
621#define RX_VCO_DIVIDER(x) (((x) & 0xF) << 0)
626#define DATA_CLK_DELAY(x) (((x) & 0xF) << 4)
627#define RX_DATA_DELAY(x) (((x) & 0xF) << 0)
632#define FB_CLK_DELAY(x) (((x) & 0xF) << 4)
633#define TX_DATA_DELAY(x) (((x) & 0xF) << 0)
638#define XO_BYPASS (1 << 4)
639#define DIGITAL_POWER_UP (1 << 2)
640#define CLOCK_ENABLE_DFLT (1 << 1)
641#define BBPLL_ENABLE (1 << 0)
646#define CLKOUT_ENABLE (1 << 4)
647#define DAC_CLK_DIV2 (1 << 3)
648#define CLKOUT_SELECT(x) (((x) & 0x7) << 5)
649#define BBPLL_DIVIDER(x) (((x) & 0x7) << 0)
654#define START_TEMP_READING (1 << 0)
659#define TEMP_SENSE_PERIODIC_ENABLE (1 << 0)
660#define MEASUREMENT_TIME_INTERVAL(x) (((x) & 0x7F) << 1)
665#define TEMP_SENSOR_DECIMATION(x) (((x) & 0x7) << 0)
670#define PP_TX_SWAP_IQ (1 << 7)
671#define PP_RX_SWAP_IQ (1 << 6)
672#define TX_CHANNEL_SWAP (1 << 5)
673#define RX_CHANNEL_SWAP (1 << 4)
674#define RX_FRAME_PULSE_MODE (1 << 3)
675#define R2T2_TIMING (1 << 2)
676#define INVERT_DATA_BUS (1 << 1)
677#define INVERT_DATA_CLK (1 << 0)
682#define FDD_ALT_WORD_ORDER (1 << 7)
683#define INVERT_RX1 (1 << 6)
684#define INVERT_RX2 (1 << 5)
685#define INVERT_TX1 (1 << 4)
686#define INVERT_TX2 (1 << 3)
687#define INVERT_RX_FRAME (1 << 2)
688#define DELAY_RX_DATA(x) (((x) & 0x3) << 0)
693#define FDD_RX_RATE_2TX_RATE (1 << 7)
694#define SWAP_PORTS (1 << 6)
695#define SINGLE_DATA_RATE (1 << 5)
696#define LVDS_MODE (1 << 4)
697#define HALF_DUPLEX_MODE (1 << 3)
698#define SINGLE_PORT_MODE (1 << 2)
699#define FULL_PORT (1 << 1)
700#define FULL_DUPLEX_SWAP_BITS (1 << 0)
705#define FDD_MODE (1 << 0)
710#define ENABLE_RX_DATA_PORT_FOR_CAL (1 << 7)
711#define FORCE_RX_ON (1 << 6)
712#define FORCE_TX_ON (1 << 5)
713#define ENABLE_ENSM_PIN_CTRL (1 << 4)
714#define LEVEL_MODE (1 << 3)
715#define FORCE_ALERT_STATE (1 << 2)
716#define AUTO_GAIN_LOCK (1 << 1)
717#define TO_ALERT (1 << 0)
722#define FDD_EXTERNAL_CTRL_ENABLE (1 << 7)
723#define POWER_DOWN_RX_SYNTH (1 << 6)
724#define POWER_DOWN_TX_SYNTH (1 << 5)
725#define TXNRX_SPI_CTRL (1 << 4)
726#define SYNTH_ENABLE_PIN_CTRL_MODE (1 << 3)
727#define DUAL_SYNTH_MODE (1 << 2)
728#define RX_SYNTH_READY_MASK (1 << 1)
729#define TX_SYNTH_READY_MASK (1 << 0)
734#define RX_BB_TUNE_CAL (1 << 7)
735#define TX_BB_TUNE_CAL (1 << 6)
736#define RX_QUAD_CAL (1 << 5)
737#define TX_QUAD_CAL (1 << 4)
738#define RX_GAIN_STEP_CAL (1 << 3)
739#define TXMON_CAL (1 << 2)
740#define RFDC_CAL (1 << 1)
741#define BBDC_CAL (1 << 0)
747#define CALIBRATION_SEQUENCE_STATE(x) (((x) & 0xF) << 4)
748#define ENSM_STATE(x) (((x) & 0xF) << 0)
749#define ENSM_STATE_SLEEP_WAIT 0x0
750#define ENSM_STATE_ALERT 0x5
751#define ENSM_STATE_TX 0x6
752#define ENSM_STATE_TX_FLUSH 0x7
753#define ENSM_STATE_RX 0x8
754#define ENSM_STATE_RX_FLUSH 0x9
755#define ENSM_STATE_FDD 0xA
756#define ENSM_STATE_FDD_FLUSH 0xB
757#define ENSM_STATE_INVALID 0xFF
758#define ENSM_STATE_SLEEP 0x80
763#define AUXDAC_2_WORD_MSB(x) (((x) & 0x3F) << 2)
764#define AUXDAC_1_WORD(x) (((x) & 0x3) << 0)
769#define COMP_CTRL_1 (1 << 5)
770#define AUXDAC1_STP_FACTOR (1 << 4)
771#define AUXDAC_1_VREF(x) (((x) & 0x3) << 2)
772#define AUXDAC_1_WORD_LSB(x) (((x) & 0x3) << 0)
777#define COMP_CTRL_2 (1 << 5)
778#define AUXDAC2_STP_FACTOR (1 << 4)
779#define AUXDAC_2_VREF(x) (((x) & 0xF) << 2)
780#define AUXDAC_2_WORD_LSB(x) (((x) & 0x3) << 0)
785#define AUXADC_CLOCK_DIVIDER(x) (((x) & 0x3F) << 0)
790#define AUXADC_POWER_DOWN (1 << 0)
791#define AUX_ADC_DECIMATION(x) (((x) & 0x7) << 1)
796#define AUXADC_WORD_LSB(x) (((x) & 0xF) << 0)
801#define GPO_ENABLE_AUTO_RX(x) (((x) & 0xF) << 4)
802#define GPO_ENABLE_AUTO_TX(x) (((x) & 0xF) << 0)
807#define INVERT_BYPASSED_LNA_POLARITY (1 << 6)
808#define AGC_ATTACK_DELAY(x) (((x) & 0x3F) << 0)
813#define AUXDAC_MANUAL_BAR(x) (((x) & 0x3) << 6)
814#define AUXDAC_AUTO_TX_BAR(x) (((x) & 0x3) << 4)
815#define AUXDAC_AUTO_RX_BAR(x) (((x) & 0x3) << 2)
816#define AUXDAC_INIT_BAR(x) (((x) & 0x3) << 0)
821#define AUXDAC_MANUAL_SELECT (1 << 7)
822#define EXTERNAL_LNA2_CTRL (1 << 6)
823#define EXTERNAL_LNA1_CTRL (1 << 5)
824#define GPO_MANUAL_SELECT (1 << 4)
825#define OPEN(x) (((x) & 0xF) << 0)
830#define GPO_MANUAL_CTRL(x) (((x) & 0xF) << 4)
831#define GPO_INIT_STATE(x) (((x) & 0xF) << 0)
836#define EN_CTRL7 (1 << 7)
837#define EN_CTRL6 (1 << 6)
838#define EN_CTRL5 (1 << 5)
839#define EN_CTRL4 (1 << 4)
840#define EN_CTRL3 (1 << 3)
841#define EN_CTRL2 (1 << 2)
842#define EN_CTRL1 (1 << 1)
843#define EN_CTRL0 (1 << 0)
848#define PRODUCT_ID_MASK 0xF8
849#define PRODUCT_ID_9361 0x08
855#define REFERENCE_CLOCK_CYCLES_PER_US(x) (((x) & 0x7F) << 0)
860#define CLK_OUT_DRIVE (1 << 7)
861#define DATACLK_DRIVE (1 << 6)
862#define DATA_PORT_DRIVE (1 << 2)
863#define DATACLK_SLEW(x) (((x) & 0x3) << 4)
864#define DATA_PORT_SLEW(x) (((x) & 0x3) << 0)
869#define RX_ON_CHIP_TERM (1 << 5)
870#define LVDS_BYPASS_BIAS_R (1 << 4)
871#define LVDS_TX_LO_VCM (1 << 3)
872#define CLK_OUT_SLEW(x) (((x) & 0x3) << 6)
873#define LVDS_BIAS(x) (((x) & 0x7) << 0)
878#define INIT_BB_FO_CAL (1 << 2)
879#define BBPLL_RESET_BAR (1 << 0)
884#define REF_FREQ_SCALER(x) (((x) & 0x3) << 0)
889#define CHARGE_PUMP_CURRENT(x) (((x) & 0x3F) << 0)
894#define MCS_REFCLK_SCALE_EN (1 << 7)
899#define C1_WORD(x) (((x) & 0x7) << 5)
900#define R1_WORD(x) (((x) & 0x1F) << 0)
905#define R2_WORD (1 << 7)
906#define C2_WORD(x) (((x) & 0x1F) << 2)
907#define C1_WORD_LSB(x) (((x) & 0x3) << 0)
912#define BYPASS_C3 (1 << 7)
913#define BYPASS_R2 (1 << 6)
914#define C3_WORD(x) (((x) & 0xF) << 2)
915#define R2_WORD_LSB(x) (((x) & 0x3) << 0)
920#define FREQ_CAL_ENABLE (1 << 7)
921#define FREQ_CAL_RESET (1 << 4)
922#define FREQ_CAL_COUNT_LENGTH(x) (((x) & 0x3) << 5)
927#define CAL_CLOCK_DIV_4 (1 << 4)
932#define RX_LO_POWER_DOWN (1 << 4)
933#define RX_SYNTH_VCO_ALC_POWER_DOWN (1 << 3)
934#define RX_SYNTH_PTAT_POWER_DOWN (1 << 2)
935#define RX_SYNTH_VCO_POWER_DOWN (1 << 1)
936#define RX_SYNTH_VCO_LDO_POWER_DOWN (1 << 0)
941#define TX_LO_POWER_DOWN (1 << 4)
942#define TX_SYNTH_VCO_ALC_POWER_DOWN (1 << 3)
943#define TX_SYNTH_PTAT_POWER_DOWN (1 << 2)
944#define TX_SYNTH_VCO_POWER_DOWN (1 << 1)
945#define TX_SYNTH_VCO_LDO_POWER_DOWN (1 << 0)
950#define RX_OFFSET_DAC_CGIN_POWER_DOWN(x) (((x) & 0x3) << 6)
951#define RX_LMT_OVERLOAD_POWER_DOWN(x) (((x) & 0x3) << 4)
952#define RX_MIXER_GM_POWER_DOWN(x) (((x) & 0x3) << 2)
953#define RX_CGB_POWER_DOWN(x) (((x) & 0x3) << 0)
958#define RX_BBF_POWER_DOWN(x) (((x) & 0x3) << 6)
959#define RX_TIA_POWER_DOWN(x) (((x) & 0x3) << 4)
960#define RX_MIXER_POWER_DOWN(x) (((x) & 0x3) << 2)
961#define RX_OFFSET_DAC_CGOUT_POWER_DOWN(x) (((x) & 0x3) << 0)
966#define TX_SECONDARY_FILTER_POWER_DOWN(x) (((x) & 0x3) << 6)
967#define TX_BBF_POWER_DOWN(x) (((x) & 0x3) << 4)
968#define TX_DAC_POWER_DOWN(x) (((x) & 0x3) << 2)
969#define TX_DAC_BIAS_POWER_DOWN(x) (((x) & 0x3) << 0)
974#define RX_EXT_VCO_BUFFER_POWER_DOWN (1 << 5)
975#define TX_EXT_VCO_BUFFER_POWER_DOWN (1 << 4)
976#define TX_MONITOR_POWER_DOWN(x) (((x) & 0x3) << 2)
977#define TX_UPCONVERTER_POWER_DOWN(x) (((x) & 0x3) << 0)
982#define RX_LNA_POWER_DOWN (1 << 6)
983#define DCXO_POWER_DOWN (1 << 1)
984#define MASTER_BIAS_POWER_DOWN (1 << 0)
985#define RX_CALIBRATION_POWER_DOWN(x) (((x) & 0x3) << 2)
990#define BBPLL_LOCK (1 << 7)
991#define CH_1_INT3 (1 << 6)
992#define CH1_HB3 (1 << 5)
993#define CH1_HB2 (1 << 4)
994#define CH1_QEC (1 << 3)
995#define CH1_HB1 (1 << 2)
996#define CH1_TFIR (1 << 1)
997#define CH1_RFIR (1 << 0)
1002#define CH2_INT3 (1 << 6)
1003#define CH2_HB3 (1 << 5)
1004#define CH2_HB2 (1 << 4)
1005#define CH2_QEC (1 << 3)
1006#define CH2_HB1 (1 << 2)
1007#define CH2_TFIR (1 << 1)
1008#define CH2_RFIR (1 << 0)
1013#define TX_FIR_GAIN_6DB (1 << 0)
1014#define FIR_START_CLK (1 << 1)
1015#define FIR_WRITE (1 << 2)
1016#define FIR_SELECT(x) (((x) & 0x3) << 3)
1017#define FIR_NUM_TAPS(x) (((x) & 0x7) << 5)
1022#define TX_MON_TRACK (1 << 5)
1023#define TX_MON_LOW_GAIN(x) (((x) & 0x1F) << 0)
1028#define TX_MON_HIGH_GAIN(x) (((x) & 0x1F) << 0)
1033#define TX_LEVEL_THRESH(x) (((x) & 0x3F) << 2)
1034#define TX_MON_DELAY_COUNTER(x) (((x) & 0x3) << 0)
1039#define TX_RSSI_2 (1 << 1)
1040#define TX_RSSI_1 (1 << 0)
1045#define TX2_MON_ENABLE (1 << 7)
1046#define TX1_MON_ENABLE (1 << 5)
1047#define ONE_SHOT_MODE (1 << 6)
1048#define TX_MON_DURATION(x) (((x) & 0xF) << 0)
1053#define TX_MON_1_LO_CM(x) (((x) & 0x3F) << 2)
1054#define TX_MON_1_GAIN(x) (((x) & 0x3) << 0)
1059#define TX_MON_2_LO_CM(x) (((x) & 0x3F) << 2)
1060#define TX_MON_2_GAIN(x) (((x) & 0x3) << 0)
1065#define TX_1_ATTEN (1 << 0)
1070#define TX_2_ATTEN (1 << 0)
1075#define MASK_CLR_ATTEN_UPDATE (1 << 6)
1076#define TX_ATTEN_OFFSET(x) (((x) & 0x3F) << 0)
1081#define SEL_TX1_TX2 (1 << 6)
1086#define IMMEDIATELY_UPDATE_TPC_ATTEN (1 << 6)
1091#define TX_1_SYMBOL_ATTEN(x) (((x) & 0x7F) << 0)
1096#define TX_2_SYMBOL_ATTEN(x) (((x) & 0x7F) << 0)
1101#define USE_TX1_PIN_SYMBOL_ATTEN (1 << 3)
1102#define USE_CTRL_IN_FOR_SYMBOL_ATTEN (1 << 1)
1103#define ENABLE_SYMBOL_ATTEN (1 << 0)
1108#define FORCE_OUT_2_TX2_OFFSET (1 << 7)
1109#define FORCE_OUT_2_TX1_OFFSET (1 << 6)
1110#define FORCE_OUT_2_TX2_PHASE_GAIN (1 << 5)
1111#define FORCE_OUT_2_TX1_PHASE_GAIN (1 << 4)
1112#define FORCE_OUT_1_TX2_OFFSET (1 << 3)
1113#define FORCE_OUT_1_TX1_OFFSET (1 << 2)
1114#define FORCE_OUT_1_TX2_PHASE_GAIN (1 << 1)
1115#define FORCE_OUT_1_TX1_PHASE_GAIN (1 << 0)
1120#define RX_NCO_FREQ(x) (((x) & 0x3) << 5)
1121#define RX_NCO_PHASE_OFFSET(x) (((x) & 0x1F) << 0)
1126#define FREE_RUN_ENABLE (1 << 7)
1127#define SETTLE_MAIN_ENABLE (1 << 6)
1128#define DC_OFFSET_ENABLE (1 << 5)
1129#define GAIN_ENABLE (1 << 4)
1130#define PHASE_ENABLE (1 << 3)
1131#define QUAD_CAL_SOFT_RESET (1 << 2)
1132#define M_DECIM(x) (((x) & 0x3) << 0)
1137#define KEXP_TX(x) (((x) & 0x3) << 6)
1138#define KEXP_TX_COMP(x) (((x) & 0x3) << 4)
1139#define KEXP_DC_I(x) (((x) & 0x3) << 2)
1140#define KEXP_DC_Q(x) (((x) & 0x3) << 0)
1145#define INVERT_I_DATA (1 << 5)
1146#define INVERT_Q_DATA (1 << 4)
1147#define TX_NCO_FREQ(x) (((x) & 0x3) << 6)
1148#define KEXP_PHASE(x) (((x) & 0x3) << 2)
1149#define KEXP_AMP(x) (((x) & 0x3) << 0)
1154#define TX1_LO_CONV (1 << 1)
1155#define TX1_SSB_CONV (1 << 0)
1156#define TX1_CONVERGENCE_COUNT(x) (((x) & 0x3F) << 2)
1161#define TX2_LO_CONV (1 << 1)
1162#define TX2_SSB_CONV (1 << 0)
1163#define TX2_CONVERGENCE_COUNT(x) (((x) & 0x3F) << 2)
1168#define RX_FULL_TABLELMT_TABLE_GAIN(x) (((x) & 0x7F) << 0)
1173#define GM_STAGE_TIME_CON_OVERRIDE (1 << 5)
1174#define GM_STAGE_MV_HP_POLE (1 << 4)
1175#define GM_STAGE_LOWER_CM (1 << 3)
1176#define BYPASS_BIAS_R (1 << 0)
1177#define VBIAS_CTRL(x) (((x) & 0x3) << 1)
1182#define THRESH_ACCUMULATOR(x) (((x) & 0xF) << 0)
1187#define RX_LPF_GAIN(x) (((x) & 0x1F) << 0)
1192#define TXDAC_VDS_I(x) (((x) & 0x3F) << 0)
1197#define TXDAC_VDS_Q(x) (((x) & 0x3F) << 0)
1202#define TXDAC_GN_I(x) (((x) & 0x3F) << 0)
1207#define TXDAC_GN_Q(x) (((x) & 0x3F) << 0)
1212#define OPAMPA_OUTPUT_BIAS(x) (((x) & 0x3) << 5)
1213#define OPAMPA_RZ(x) (((x) & 0x3) << 3)
1214#define OPAMP_A_CC(x) (((x) & 0x7) << 0)
1219#define OPAMPB_OUTPUT_BIAS(x) (((x) & 0x3) << 5)
1220#define OPAMPB_RZ(x) (((x) & 0x3) << 3)
1221#define OPAMP_B_CC(x) (((x) & 0x7) << 0)
1226#define OVERRIDE_ENABLE (1 << 7)
1227#define R1(x) (((x) & 0x1F) << 0)
1232#define R2(x) (((x) & 0x1F) << 0)
1237#define R3(x) (((x) & 0x1F) << 0)
1242#define R4(x) (((x) & 0x1F) << 0)
1247#define RP(x) (((x) & 0x1F) << 0)
1252#define C1(x) (((x) & 0x3F) << 0)
1257#define C2(x) (((x) & 0x3F) << 0)
1262#define CP(x) (((x) & 0x3F) << 0)
1267#define PD_TUNE (1 << 2)
1268#define TUNER_RESAMPLE (1 << 1)
1269#define TUNER_RESAMPLE_PHASE (1 << 0)
1270#define TUNE_CTRL(x) (((x) & 0x3) << 5)
1275#define TX_BBF_BYPASS_BIAS_R (1 << 7)
1276#define R2B_OVR (1 << 5)
1277#define R2B(x) (((x) & 0x1F) << 0)
1282#define BBF1_COMP_I (1 << 3)
1283#define BBF1_COMP_Q (1 << 2)
1284#define BBF2_COMP_I (1 << 1)
1285#define BBF2_COMP_Q (1 << 0)
1290#define BIAS(x) (((x) & 0x3) << 6)
1291#define RGM(x) (((x) & 0x3) << 4)
1292#define CC(x) (((x) & 0x3) << 2)
1293#define AMPBIAS(x) (((x) & 0x3) << 0)
1298#define RESISTOR(x) (((x) & 0xF) << 0)
1303#define CAPACITOR(x) (((x) & 0x3F) << 0)
1308#define LO_COMMON_MODE(x) (((x) & 0x3) << 5)
1313#define EVALTIME (1 << 4)
1314#define TX_BBF_TUNE_DIVIDER (1 << 0)
1315#define TUNE_COMP_MASK(x) (((x) & 0x3) << 5)
1316#define TUNER_MODE(x) (((x) & 0x7) << 1)
1321#define WRITE_RX (1 << 2)
1322#define START_RX_CLOCK (1 << 1)
1323#define NUMBER_OF_TAPS(x) (((x) & 0x7) << 5)
1324#define SELECT_RX_CH(x) (((x) & 0x3) << 3)
1329#define FILTER_GAIN(x) (((x) & 0x3) << 0)
1334#define DEC_PWR_FOR_LOW_PWR (1 << 7)
1335#define DEC_PWR_FOR_LOCK_LEVEL (1 << 6)
1336#define DEC_PWR_FOR_GAIN_LOCK_EXIT (1 << 5)
1337#define SLOW_ATTACK_HYBRID_MODE (1 << 4)
1338#define RX2_GAIN_CTRL_SETUP(x) (((x) & 0x3) << 2)
1339#define RX1_GAIN_CTRL_SETUP(x) (((x) & 0x3) << 0)
1340#define RX_GAIN_CTL_MASK 0x03
1341#define RX2_GAIN_CTRL_SHIFT 2
1342#define RX1_GAIN_CTRL_SHIFT 0
1343#define RX_GAIN_CTL_MGC 0x00
1344#define RX_GAIN_CTL_AGC_FAST_ATK 0x01
1345#define RX_GAIN_CTL_AGC_SLOW_ATK 0x02
1346#define RX_GAIN_CTL_AGC_SLOW_ATK_HYBD 0x03
1351#define AGC_SOFT_RESET (1 << 7)
1352#define AGC_GAIN_UNLOCK_CTRL (1 << 6)
1353#define AGC_USE_FULL_GAIN_TABLE (1 << 3)
1354#define DIG_GAIN_EN (1 << 2)
1355#define MAN_GAIN_CTRL_RX2 (1 << 1)
1356#define MAN_GAIN_CTRL_RX1 (1 << 0)
1361#define INCDEC_LMT_GAIN (1 << 4)
1362#define USE_AGC_FOR_LMTLPF_GAIN (1 << 3)
1363#define MANUAL_INCR_STEP_SIZE(x) (((x) & 0x7) << 5)
1364#define ADC_OVERRANGE_SAMPLE_SIZE(x) (((x) & 0x7) << 0)
1369#define MAXIMUM_FULL_TABLELMT_TABLE_INDEX(x) (((x) & 0x7F) << 0)
1374#define MANUAL_CTRL_IN_DECR_GAIN_STP_SIZE(x) (((x) & 0x7) << 5)
1375#define PEAK_OVERLOAD_WAIT_TIME(x) (((x) & 0x1F) << 0)
1380#define DIG_GAIN_STP_SIZE(x) (((x) & 0x7) << 5)
1381#define MAXIMUM_DIGITAL_GAIN(x) (((x) & 0x1F) << 0)
1386#define ENABLE_DIG_SAT_OVRG (1 << 7)
1387#define AGC_LOCK_LEVEL_FAST_AGC_INNER_HIGH_THRESH_SLOW(x) (((x) & 0x7F) << 0)
1392#define LMT_DETECTOR_SETTLING_TIME(x) (((x) & 0x7) << 5)
1393#define DEC_STP_SIZE_FOR_LARGE_LMT_OVERLOAD(x) (((x) & 0x7) << 2)
1394#define ADC_NOISE_CORRECTION_FACTOR(x) (((x) & 0x3) << 0)
1399#define DECREMENT_STP_SIZE_FOR_SMALL_LPF_GAIN_CHANGE(x) (((x) & 0x7) << 4)
1400#define LARGE_LPF_GAIN_STEP(x) (((x) & 0xF) << 0)
1405#define FORCE_PD_RESET_RX2 (1 << 7)
1406#define FORCE_PD_RESET_RX1 (1 << 6)
1407#define SMALL_LMT_OVERLOAD_THRESH(x) (((x) & 0x3F) << 0)
1412#define LARGE_LMT_OVERLOAD_THRESH(x) (((x) & 0x3F) << 0)
1417#define POWER_MEAS_IN_STATE_5_MSB (1 << 7)
1418#define RX1_MANUAL_FULL_TABLE_LMT_TABLE_GAIN_INDEX(x) (((x) & 0x7F) << 0)
1419#define RX_FULL_TBL_IDX_MASK RX1_MANUAL_FULL_TABLE_LMT_TABLE_GAIN_INDEX(~0)
1424#define POWER_MEAS_IN_STATE_5(x) (((x) & 0x7) << 5)
1425#define RX1_MANUAL_LPF_GAIN(x) (((x) & 0x1F) << 0)
1426#define RX_LPF_IDX_MASK RX1_MANUAL_LPF_GAIN(~0)
1431#define FORCE_RX1_DIGITAL_GAIN (1 << 5)
1432#define RX1_MANUALFORCED_DIGITAL_GAIN(x) (((x) & 0x1F) << 0)
1433#define RX_DIGITAL_IDX_MASK RX1_MANUALFORCED_DIGITAL_GAIN(~0)
1437#define RX2_MANUAL_FULL_TABLE_LMT_TABLE_GAIN_INDEX(x) (((x) & 0x7F) << 0)
1442#define RX2_MANUAL_LPF_GAIN(x) (((x) & 0x1F) << 0)
1447#define FORCE_RX2_DIGITAL_GAIN (1 << 5)
1448#define RX2_MANUALFORCED_DIGITAL_GAIN(x) (((x) & 0x1F) << 0)
1453#define ENABLE_GAIN_INC_AFTER_GAIN_LOCK (1 << 7)
1454#define GOTO_OPT_GAIN_IF_ENERGY_LOST_OR_EN_AGC_HIGH (1 << 6)
1455#define GOTO_SET_GAIN_IF_EN_AGC_HIGH (1 << 5)
1456#define GOTO_SET_GAIN_IF_EXIT_RX_STATE (1 << 4)
1457#define DONT_UNLOCK_GAIN_IF_ENERGY_LOST (1 << 3)
1458#define GOTO_OPTIMIZED_GAIN_IF_EXIT_RX_STATE (1 << 2)
1459#define DONT_UNLOCK_GAIN_IF_LG_ADC_OR_LMT_OVRG (1 << 1)
1460#define ENABLE_INCR_GAIN (1 << 0)
1465#define USE_LAST_LOCK_LEVEL_FOR_SET_GAIN (1 << 7)
1466#define ENABLE_LMT_GAIN_INC_FOR_LOCK_LEVEL (1 << 6)
1467#define GOTO_MAX_GAIN_OR_OPT_GAIN_IF_EN_AGC_HIGH (1 << 5)
1468#define SETTLING_DELAY(x) (((x) & 0x1F) << 0)
1473#define POST_LOCK_LEVEL_STP_SIZE_FOR_LPF_TABLE_FULL_TABLE(x) (((x) & 0x3) << 6)
1474#define ENERGY_LOST_THRESH(x) (((x) & 0x3F) << 0)
1479#define POST_LOCK_LEVEL_STP_FOR_LMT_TABLE(x) (((x) & 0x3) << 6)
1480#define STRONGER_SIGNAL_THRESH(x) (((x) & 0x3F) << 0)
1485#define DONT_UNLOCK_GAIN_IF_ADC_OVRG (1 << 7)
1486#define LOW_POWER_THRESH(x) (((x) & 0x7F) << 0)
1491#define DONT_UNLOCK_GAIN_IF_STRONGER_SIGNAL (1 << 7)
1496#define FINAL_OVER_RANGE_COUNT(x) (((x) & 0x7) << 5)
1497#define OPTIMIZE_GAIN_OFFSET(x) (((x) & 0xF) << 0)
1502#define INCREMENT_GAIN_STP_LPFLMT(x) (((x) & 0x7) << 5)
1503#define ENERGY_DETECT_COUNT(x) (((x) & 0x1F) << 0)
1508#define AGCLL_MAX_INCREASE(x) (((x) & 0x3F) << 0)
1513#define GAIN_LOCK_EXIT_COUNT(x) (((x) & 0x3F) << 0)
1518#define INITIAL_LMT_GAIN_LIMIT(x) (((x) & 0x7F) << 0)
1523#define PREVENT_GAIN_INC (1 << 7)
1524#define AGC_INNER_LOW_THRESH(x) (((x) & 0x7F) << 0)
1529#define LARGE_LMT_OVERLOAD_EXED_COUNTER(x) (((x) & 0xF) << 4)
1530#define SMALL_LMT_OVERLOAD_EXED_COUNTER(x) (((x) & 0xF) << 0)
1535#define LARGE_ADC_OVERLOAD_EXED_COUNTER(x) (((x) & 0xF) << 4)
1536#define SMALL_ADC_OVERLOAD_EXED_COUNTER(x) (((x) & 0xF) << 0)
1541#define IMMED_GAIN_CHANGE_IF_LG_LMT_OVERLOAD (1 << 7)
1542#define IMMED_GAIN_CHANGE_IF_LG_ADC_OVERLOAD (1 << 3)
1543#define AGC_INNER_HIGH_THRESH_EXED_STP_SIZE(x) (((x) & 0x7) << 4)
1544#define AGC_INNER_LOW_THRESH_EXED_STP_SIZE(x) (((x) & 0x7) << 0)
1549#define DOUBLE_GAIN_COUNTER (1 << 5)
1550#define ENABLE_SYNC_FOR_GAIN_COUNTER (1 << 4)
1551#define DIG_SATURATION_EXED_COUNTER(x) (((x) & 0xF) << 0)
1556#define AGC_OUTER_HIGH_THRESH(x) (((x) & 0xF) << 4)
1557#define AGC_OUTER_LOW_THRESH(x) (((x) & 0xF) << 0)
1562#define AGC_OUTER_HIGH_THRESH_EXED_STP_SIZE(x) (((x) & 0xF) << 4)
1563#define AGC_OUTER_LOW_THRESH_EXED_STP_SIZE(x) (((x) & 0xF) << 0)
1568#define EXT_LNA_HIGH_GAIN(x) (((x) & 0x3F) << 0)
1573#define EXT_LNA_LOW_GAIN(x) (((x) & 0x3F) << 0)
1578#define GAIN_TABLE_ADDRESS(x) (((x) & 0x7F) << 0)
1583#define EXT_LNA_CTRL (1 << 7)
1584#define LNA_GAIN(x) (((x) & 0x3) << 5)
1585#define MIXER_GM_GAIN(x) (((x) & 0x1F) << 0)
1590#define TIA_GAIN (1 << 5)
1591#define LPF_GAIN(x) (((x) & 0x1F) << 0)
1596#define RF_DC_CAL (1 << 5)
1597#define DIGITAL_GAIN(x) (((x) & 0x1F) << 0)
1602#define TO_LNA_GAIN(x) (((x) >> 5) & 0x3)
1603#define TO_MIXER_GM_GAIN(x) (((x) >> 0) & 0x1F)
1608#define TO_LPF_GAIN(x) (((x) >> 0) & 0x1F)
1613#define TO_DIGITAL_GAIN(x) (((x) >> 0) & 0x1F)
1618#define WRITE_GAIN_TABLE (1 << 2)
1619#define START_GAIN_TABLE_CLOCK (1 << 1)
1620#define RECEIVER_SELECT(x) (((x) & 0x3) << 3)
1628#define GM_SUB_TABLE_GAIN_WRITE(x) (((x) & 0x7F) << 0)
1633#define GM_SUB_TABLE_BIAS_WRITE(x) (((x) & 0x1F) << 0)
1638#define GM_SUB_TABLE_CTRL_WRITE(x) (((x) & 0x3F) << 0)
1643#define GM_SUB_TABLE_GAIN_READ(x) (((x) & 0x7F) << 0)
1648#define GM_SUB_TABLE_BIAS_READ(x) (((x) & 0x1F) << 0)
1653#define GM_SUB_TABLE_CTRL_READ(x) (((x) & 0x3F) << 0)
1658#define WRITE_GM_SUB_TABLE (1 << 2)
1659#define START_GM_SUB_TABLE_CLOCK (1 << 1)
1664#define CALIB_TABLE_GAIN_DIFFERROR_WORD(x) (((x) & 0x3F) << 0)
1669#define CALIB_TABLE_GAIN_ERROR(x) (((x) & 0x1F) << 0)
1674#define READ_SELECT (1 << 4)
1675#define WRITE_MIXER_ERROR_TABLE (1 << 3)
1676#define WRITE_LNA_ERROR_TABLE (1 << 2)
1677#define WRITE_LNA_GAIN_DIFF (1 << 1)
1678#define START_CALIB_TABLE_CLOCK (1 << 0)
1679#define CALIB_TABLE_SELECT(x) (((x) & 0x3) << 5)
1684#define LNA_CALIB_TABLE_GAIN_DIFFERENCE_WORD(x) (((x) & 0x3F) << 0)
1689#define MAX_MIXER_CALIBRATION_GAIN_INDEX(x) (((x) & 0x1F) << 0)
1694#define ENABLE_DIG_GAIN_CORR (1 << 7)
1695#define FORCE_TEMP_SENSOR_FOR_CAL (1 << 6)
1696#define SETTLE_TIME(x) (((x) & 0x3F) << 0)
1701#define GAIN_CAL_MEAS_DURATION(x) (((x) & 0xF) << 0)
1706#define MEASUREMENT_DURATION_1(x) (((x) & 0xF) << 4)
1707#define MEASUREMENT_DURATION_0(x) (((x) & 0xF) << 0)
1712#define MEASUREMENT_DURATION_3(x) (((x) & 0xF) << 4)
1713#define MEASUREMENT_DURATION_2(x) (((x) & 0xF) << 0)
1718#define START_RSSI_MEAS (1 << 5)
1719#define ENABLE_ADC_POWER_MEAS (1 << 1)
1720#define DEFAULT_RSSI_MEAS_MODE (1 << 0)
1721#define RFIR_FOR_RSSI_MEASUREMENT(x) (((x) & 0x3) << 6)
1722#define RSSI_MODE_SELECT(x) (((x) & 0x7) << 2)
1727#define ADC_POWER_MEASUREMENT_DURATION_1(x) (((x) & 0xF) << 4)
1728#define ADC_POWER_MEASUREMENT_DURATION_0(x) (((x) & 0xF) << 0)
1733#define USE_HB3_OUT_FOR_ADC_PWR_MEAS (1 << 7)
1734#define USE_HB1_OUT_FOR_DEC_PWR_MEAS (1 << 6)
1735#define ENABLE_DEC_PWR_MEAS (1 << 5)
1736#define DEFAULT_MODE_ADC_POWER (1 << 4)
1737#define DEC_POWER_MEASUREMENT_DURATION(x) (((x) & 0xF) << 0)
1742#define DB_GAIN_READBACK_CHANNEL (1 << 0)
1743#define MAX_LNA_GAIN(x) (((x) & 0x7F) << 1)
1748#define RX_QUAD_CAL_LEVEL(x) (((x) & 0xF) << 0)
1753#define ENABLE_PHASE_CORR (1 << 7)
1754#define ENABLE_GAIN_CORR (1 << 6)
1755#define USE_SETTLE_COUNT_FOR_DC_CAL_WAIT (1 << 5)
1756#define FIXED_DC_CAL_WAIT_TIME (1 << 4)
1757#define FREE_RUN_MODE (1 << 3)
1758#define ENABLE_CORR_WORD_DECIMATION (1 << 2)
1759#define ENABLE_TRACKING_MODE_CH2 (1 << 1)
1760#define ENABLE_TRACKING_MODE_CH1 (1 << 0)
1765#define SOFT_RESET (1 << 7)
1766#define CALIBRATION_CONFIG2_DFLT (0x3 << 5)
1767#define K_EXP_PHASE(x) (((x) & 0x1F) << 0)
1772#define PREVENT_POS_LOOP_GAIN (1 << 7)
1773#define K_EXP_AMPLITUDE(x) (((x) & 0x1F) << 0)
1778#define RX_FULL_TABLELMT_TABLE_GAIN(x) (((x) & 0x7F) << 0)
1783#define CORRECTION_WORD_DECIMATION_M(x) (((x) & 0x7) << 5)
1784#define RX_LPF_GAIN(x) (((x) & 0x1F) << 0)
1789#define RX1_INPUT_A_I_DC_OFFSET_LSB(x) (((x) & 0x3F) << 2)
1790#define RX1_INPUT_A_Q_DC_OFFSET(x) (((x) & 0x3) << 0)
1795#define RX2_INPUT_A_Q_DC_OFFSET_LSB(x) (((x) & 0xF) << 4)
1796#define RX1_INPUT_A_I_DC_OFFSET_MSB(x) (((x) & 0xF) << 0)
1801#define RX2_INPUT_A_I_DC_OFFSET(x) (((x) & 0x3) << 6)
1802#define RX2_INPUT_A_Q_DC_OFFSET_MSB(x) (((x) & 0x3F) << 0)
1807#define RX1_INPUT_BC_I_DC_OFFSET_LSB(x) (((x) & 0x3F) << 2)
1808#define RX1_INPUT_BC_Q_DC_OFFSET(x) (((x) & 0x3) << 0)
1813#define RX2_INPUT_BC_Q_DC_OFFSET_LSB(x) (((x) & 0xF) << 4)
1814#define RX1_INPUT_BC_I_DC_OFFSET_MSB(x) (((x) & 0xF) << 0)
1819#define RX2_INPUT_BC_I_DC_OFFSET(x) (((x) & 0x3) << 6)
1820#define RX2_INPUT_BC_Q_DC_OFFSET_MSB(x) (((x) & 0x3F) << 0)
1825#define RX2_INPUT_BC_FORCE_OFFSET (1 << 7)
1826#define RX1_INPUT_BC_FORCE_OFFSET (1 << 6)
1827#define RX2_INPUT_BC_FORCE_PHGAIN (1 << 5)
1828#define RX1_INPUT_BC_FORCE_PHGAIN (1 << 4)
1829#define RX2_INPUT_A_FORCE_OFFSET (1 << 3)
1830#define RX1_INPUT_A_FORCE_OFFSET (1 << 2)
1831#define RX2_INPUT_A_FORCE_PHGAIN (1 << 1)
1832#define RX1_INPUT_A_FORCE_PHGAIN (1 << 0)
1837#define DAC_FS(x) (((x) & 0x3) << 4)
1838#define RF_DC_CALIBRATION_COUNT(x) (((x) & 0xF) << 0)
1843#define RF_DC_OFFSET_TABLE_UPDATE_COUNT(x) (((x) & 0x7) << 5)
1844#define RF_DC_OFFSET_ATTEN(x) (((x) & 0x1F) << 0)
1849#define INVERT_RX2_RF_DC_CGIN_WORD (1 << 7)
1850#define INVERT_RX1_RF_DC_CGIN_WORD (1 << 6)
1851#define INVERT_RX2_RF_DC_CGOUT_WORD (1 << 5)
1852#define INVERT_RX1_RF_DC_CGOUT_WORD (1 << 4)
1857#define USE_WAIT_COUNTER_FOR_RF_DC_INIT_CAL (1 << 7)
1858#define ENABLE_FAST_SETTLE_MODE (1 << 6)
1859#define ENABLE_BB_DC_OFFSET_TRACKING (1 << 5)
1860#define RESET_ACC_ON_GAIN_CHANGE (1 << 4)
1861#define ENABLE_RF_OFFSET_TRACKING (1 << 3)
1862#define DC_OFFSET_UPDATE(x) (((x) & 0x7) << 0)
1867#define RF_MINIMUM_CALIBRATION_GAIN_INDEX(x) (((x) & 0x7F) << 0)
1872#define RF_SOI_THRESH(x) (((x) & 0x7F) << 0)
1877#define INCREASE_COUNT_DURATION (1 << 7)
1878#define BB_TRACKING_DECIMATE(x) (((x) & 0x3) << 5)
1879#define BB_DC_M_SHIFT(x) (((x) & 0x1F) << 0)
1884#define READ_BACK_CH_SEL (1 << 7)
1885#define UPDATE_TRACKING_WORD (1 << 6)
1886#define FORCE_RX_NULL (1 << 5)
1887#define BB_DC_TRACKING_FAST_SETTLE_M_SHIFT(x) (((x) & 0x1F) << 0)
1892#define BB_DC_OFFSET_ATTEN(x) (((x) & 0xF) << 0)
1897#define RX1_BB_DC_OFFSET_CORRECTION_WORD_I(x) (((x) & 0x7F) << 0)
1902#define RX1_BB_DC_OFFSET_CORRECTION_WORD_Q(x) (((x) & 0x7F) << 0)
1907#define RX2_BB_DC_OFFSET_CORRECTION_WORD_I(x) (((x) & 0x7F) << 0)
1912#define RX2_BB_DC_OFFSET_CORRECTION_WORD_Q(x) (((x) & 0x7F) << 0)
1917#define RX1RX2_BB_DC_OFFSET_TRACKING_CORRECTION_WORD_I(x) (((x) & 0x7F) << 0)
1922#define RX1RX2_BB_DC_OFFSET_TRACKING_CORRECTION_WORD_Q(x) (((x) & 0x7F) << 0)
1927#define RX2_RSSI_SYMBOL (1 << 1)
1928#define RX1_RSSI_SYMBOL (1 << 0)
1933#define RX2_RSSI_PREAMBLE (1 << 1)
1934#define RX1_RSSI_PREAMBLE (1 << 0)
1940#define RSSI_LSB_SHIFT 1
1941#define RSSI_LSB_MASK1 0x01
1942#define RSSI_LSB_MASK2 0x02
1947#define RX_PATH_GAIN (1 << 0)
1952#define FORCE_RX2_LNA_GAIN (1 << 7)
1953#define RX2_LNA_BYPASS (1 << 6)
1954#define FORCE_RX1_LNA_GAIN (1 << 3)
1955#define RX1_LNA_BYPASS (1 << 2)
1956#define RX2_LNA_GAIN(x) (((x) & 0x3) << 4)
1957#define RX1_LNA_GAIN(x) (((x) & 0x3) << 0)
1962#define RX_LNA_BIAS_COARSE(x) (((x) & 0xF) << 0)
1967#define RX_LNA_PCASCODE_BIAS(x) (((x) & 0x7) << 5)
1968#define RX_LNA_BIAS(x) (((x) & 0x1F) << 0)
1973#define RX_LNA_P_CASCODE_BIAS_FINE(x) (((x) & 0x3) << 0)
1978#define RX_MIX_GM_CM_OUT(x) (((x) & 0x7) << 5)
1979#define RX_MIX_GM_PLOAD(x) (((x) & 0x3) << 0)
1984#define FORCE_RX1_MIX_GM (1 << 6)
1985#define RX1_MIX_GM_GAIN(x) (((x) & 0x3F) << 0)
1990#define RX1_MIX_GM_BIAS(x) (((x) & 0x1F) << 0)
1995#define FORCE_RX2_MIX_GM (1 << 6)
1996#define RX2_MIX_GM_GAIN(x) (((x) & 0x3F) << 0)
2001#define RX2_MIX_GM_BIAS(x) (((x) & 0x1F) << 0)
2006#define INPUT_A_RX1_Q(x) (((x) & 0x3) << 6)
2007#define INPUT_A_RX1_I(x) (((x) & 0x3) << 4)
2008#define INPUT_A_RX2_I(x) (((x) & 0x3) << 2)
2009#define INPUT_A_RX2_Q(x) (((x) & 0x3) << 0)
2014#define INPUTS_BC_RX1_Q(x) (((x) & 0x3) << 6)
2015#define INPUTS_BC_RX1_I(x) (((x) & 0x3) << 4)
2016#define INPUTS_BC_RX2_I(x) (((x) & 0x3) << 2)
2017#define INPUTS_BC_RX2_Q(x) (((x) & 0x3) << 0)
2022#define FORCE_CGIN_DAC (1 << 2)
2027#define RX_MIX_LO_CM(x) (((x) & 0x3F) << 0)
2032#define RX_CGB_SEG_ENABLE(x) (((x) & 0x3F) << 0)
2037#define RX_CGB_INPUT_CM_SEL(x) (((x) & 0x3) << 4)
2038#define RX_CGB_BIAS(x) (((x) & 0xF) << 0)
2043#define TIA2_OVERRIDE_C (1 << 3)
2044#define TIA2_OVERRIDE_R (1 << 2)
2045#define TIA1_OVERRIDE_C (1 << 1)
2046#define TIA1_OVERRIDE_R (1 << 0)
2047#define TIA_SEL_CC(x) (((x) & 0x7) << 5)
2052#define TIA1_RF(x) (((x) & 0x3) << 6)
2053#define TIA1_C_LSB(x) (((x) & 0x3F) << 0)
2058#define TIA1_C_MSB(x) (((x) & 0x7F) << 0)
2063#define TIA2_RF(x) (((x) & 0x3) << 6)
2064#define TIA2_C_LSB(x) (((x) & 0x3F) << 0)
2069#define TIA2_C_MSB(x) (((x) & 0x7F) << 0)
2074#define FORCE_RX1_RESISTORS (1 << 7)
2075#define RX1_BBF_R1A(x) (((x) & 0x3F) << 0)
2080#define FORCE_RX2_RESISTORS (1 << 7)
2081#define RX2_BBF_R1A(x) (((x) & 0x3F) << 0)
2086#define RX1_TUNE_RESAMPLE_PHASE (1 << 2)
2087#define RX1_TUNE_RESAMPLE (1 << 1)
2088#define RX1_PD_TUNE (1 << 0)
2093#define RX2_TUNE_RESAMPLE_PHASE (1 << 2)
2094#define RX2_TUNE_RESAMPLE (1 << 1)
2095#define RX2_PD_TUNE (1 << 0)
2100#define TUNE_OVERRIDE (1 << 7)
2101#define RX_BBF_R2346(x) (((x) & 0x7) << 0)
2106#define RX_BBF_C1_MSB(x) (((x) & 0x3F) << 0)
2111#define RX_BBF_C1_LSB(x) (((x) & 0x7F) << 0)
2116#define RX_BBF_C2_MSB(x) (((x) & 0x3F) << 0)
2121#define RX_BBF_C2_LSB(x) (((x) & 0x7F) << 0)
2126#define RX_BBF_C3_MSB(x) (((x) & 0x3F) << 0)
2131#define RX_BBF_C3_LSB(x) (((x) & 0x7F) << 0)
2136#define RX_BBF_CC1_CTR(x) (((x) & 0x7F) << 0)
2141#define MUST_BE_ZERO (1 << 7)
2142#define RX1_BBF_POW_CTR(x) (((x) & 0x3) << 5)
2143#define RX_BBF_RZ1_CTR(x) (((x) & 0x3) << 3)
2148#define RX_BBF_CC2_CTR(x) (((x) & 0x7F) << 0)
2153#define RX_BBF_POW3_CTR(x) (((x) & 0x3) << 6)
2154#define RX_BBF_RZ3_CTR(x) (((x) & 0x3) << 4)
2155#define RX_BBF_POW2_CTR(x) (((x) & 0x3) << 2)
2156#define RX_BBF_RZ2_CTR(x) (((x) & 0x3) << 0)
2161#define RX_BBF_CC3_CTR(x) (((x) & 0x7F) << 0)
2166#define RXBBF_BYPASS_BIAS_R (1 << 7)
2167#define RX_BBF_R5_TUNE (1 << 4)
2168#define RX1_BBF_TUNE_COMP_I (1 << 3)
2169#define RX1_BBF_TUNE_COMP_Q (1 << 2)
2170#define RX2_BBF_TUNE_COMP_I (1 << 1)
2171#define RX2_BBF_TUNE_COMP_Q (1 << 0)
2172#define RX_BBF_TUNE_CTR(x) (((x) & 0x3) << 5)
2177#define RX1_BBF_FORCE_GAIN (1 << 5)
2178#define RX1_BBF_BQ_GAIN(x) (((x) & 0x3) << 3)
2179#define RX1_BBF_POLE_GAIN(x) (((x) & 0x7) << 0)
2184#define RX2_BBF_FORCE_GAIN (1 << 5)
2185#define RX2_BBF_BQ_GAIN(x) (((x) & 0x3) << 3)
2186#define RX2_BBF_POLE_GAIN(x) (((x) & 0x7) << 0)
2191#define RX_TUNE_EVALTIME (1 << 4)
2192#define RX_BBF_TUNE_DIVIDE (1 << 0)
2193#define TUNE_COMP_MASK(x) (((x) & 0x3) << 5)
2194#define RX_TUNE_MODE(x) (((x) & 0x7) << 1)
2199#define POLE_GAIN_TUNE(x) (((x) & 0x3) << 0)
2204#define RX_TUNE_BBBW_MHZ(x) (((x) & 0x1F) << 0)
2209#define RX_TUNE_BBBW_KHZ(x) (((x) & 0x7F) << 0)
2214#define BYPASS_LD_SYNTH (1 << 0)
2219#define SYNTH_INTEGER_WORD(x) (((x) & 0x7) << 0)
2224#define SYNTH_FRACT_WORD(x) (((x) & 0x7F) << 0)
2229#define VCO_CAL_OFFSET(x) (((x) & 0xF) << 3)
2234#define INIT_ALC_VALUE(x) (((x) & 0xF) << 4)
2235#define VCO_VARACTOR(x) (((x) & 0xF) << 0)
2240#define PORB_VCO_LOGIC (1 << 6)
2241#define VCO_OUTPUT_LEVEL(x) (((x) & 0xF) << 0)
2246#define CHARGE_PUMP_CURRENT(x) (((x) & 0x3F) << 0)
2251#define SYNTH_RECAL (1 << 7)
2256#define HALF_VCO_CAL_CLK (1 << 7)
2257#define CP_OFFSET_OFF (1 << 4)
2258#define F_CPCAL (1 << 3)
2259#define CP_CAL_ENABLE (1 << 2)
2264#define LOOP_FILTER_C2(x) (((x) & 0xF) << 4)
2265#define LOOP_FILTER_C1(x) (((x) & 0xF) << 0)
2270#define LOOP_FILTER_R1(x) (((x) & 0xF) << 4)
2271#define LOOP_FILTER_C3(x) (((x) & 0xF) << 0)
2276#define LOOP_FILTER_BYPASS_R3 (1 << 7)
2277#define LOOP_FILTER_BYPASS_R1 (1 << 6)
2278#define LOOP_FILTER_BYPASS_C2 (1 << 5)
2279#define LOOP_FILTER_BYPASS_C1 (1 << 4)
2280#define LOOP_FILTER_R3(x) (((x) & 0xF) << 0)
2285#define FORCED_CP_CAL_WORD(x) (((x) & 0xF) << 0)
2290#define VCO_BIAS_TCF(x) (((x) & 0x3) << 3)
2291#define VCO_BIAS_REF(x) (((x) & 0x7) << 0)
2296#define CP_CAL_VALID (1 << 7)
2297#define CP_CAL_DONE (1 << 5)
2298#define VCO_CAL_BUSY (1 << 4)
2299#define CP_CAL_WORD(x) (((x) & 0xF) << 0)
2304#define VCO_CAL_REF_TCF(x) (((x) & 0x7) << 0)
2309#define POWER_DOWN_VARACTOR_REF (1 << 3)
2310#define PWR_DOWN_VARACT_REF_TCF (1 << 2)
2311#define POWER_DOWN_CAL_TCF (1 << 1)
2312#define POWER_DOWN_VCO_BUFFFER (1 << 0)
2317#define CP_OVRG_HIGH (1 << 7)
2318#define CP_OVRG_LOW (1 << 6)
2319#define VCO_LOCK (1 << 1)
2324#define VCO_LDO_BYPASS (1 << 7)
2325#define VCO_LDO_INRUSH(x) (((x) & 0x3) << 5)
2326#define VCO_LDO_SEL(x) (((x) & 0x7) << 2)
2327#define VCO_LDO_VDROP_SEL(x) (((x) & 0x3) << 0)
2332#define VCO_CAL_EN (1 << 7)
2333#define VCO_CAL_ALC_WAIT(x) (((x) & 0x7) << 4)
2334#define VCO_CAL_COUNT(x) (((x) & 0x3) << 2)
2339#define LOCK_DETECT_COUNT(x) (((x) & 0x3) << 2)
2340#define LOCK_DETECT_MODE(x) (((x) & 0x3) << 0)
2345#define CP_LEVEL_DETECT_POWER_DOWN (1 << 6)
2346#define CP_LEVEL_THRESH_LOW(x) (((x) & 0x7) << 3)
2347#define CP_LEVEL_THRESH_HIGH(x) (((x) & 0x7) << 0)
2352#define DSM_PROG(x) (((x) & 0xF) << 0)
2357#define SIF_CLOCK (1 << 6)
2358#define SIF_RESET_BAR (1 << 5)
2359#define SIF_ADDR(x) (((x) & 0x1F) << 0)
2364#define UPDATE_FREQ_WORD (1 << 7)
2365#define READ_EFFECTIVE_TUNING_WORD (1 << 5)
2366#define FREQ_CORRECTION_WORD_MSB(x) (((x) & 0x1F) << 0)
2371#define UPDATE_FREQ_WORD (1 << 7)
2372#define FREQ_CORRECTION_WORD_LSB(x) (((x) & 0x7F) << 0)
2377#define VCO_VARACTOR_REFERENCE_TCF(x) (((x) & 0x7) << 4)
2378#define VCO_VARACTOR_OFFSET(x) (((x) & 0xF) << 0)
2383#define VCO_VARACTOR_REFERENCE(x) (((x) & 0xF) << 0)
2388#define RX_FAST_LOCK_LOAD_SYNTH (1 << 3)
2389#define RX_FAST_LOCK_PROFILE_INIT (1 << 2)
2390#define RX_FAST_LOCK_PROFILE_PIN_SELECT (1 << 1)
2391#define RX_FAST_LOCK_MODE_ENABLE (1 << 0)
2392#define RX_FAST_LOCK_PROFILE(x) (((x) & 0x7) << 5)
2397#define RX_FAST_LOCK_PROFILE_ADDR(x) (((x) & 0x7) << 4)
2398#define RX_FAST_LOCK_PROFILE_WORD(x) (((x) & 0xF) << 0)
2404#define RX_FAST_LOCK_PROGRAM_WRITE (1 << 1)
2405#define RX_FAST_LOCK_PROGRAM_CLOCK_ENABLE (1 << 0)
2407#define RX_FAST_LOCK_CONFIG_WORD_NUM 16
2412#define RX_LO_GEN_POWER_MODE(x) (((x) & 0x3) << 4)
2417#define DIV_TEST_EN (1 << 5)
2418#define PFD_CLK_EDGE (1 << 1)
2419#define BYPASS_LD_SYNTH (1 << 0)
2420#define PFD_WIDTH(x) (((x) & 0x3) << 2)
2425#define SDM_BYPASS (1 << 7)
2426#define SDM_POWER_DOWN (1 << 6)
2427#define SYNTH_INTEGER_WORD(x) (((x) & 0x7) << 0)
2432#define SYNTH_FRACT_WORD(x) (((x) & 0x7F) << 0)
2437#define FORCE_ALC_ENABLE (1 << 7)
2438#define FORCE_ALC_WORD(x) (((x) & 0x7F) << 0)
2443#define BYPASS_LOAD_DELAY (1 << 7)
2444#define FORCE_VCO_TUNE_ENABLE (1 << 1)
2445#define FORCE_VCO_TUNE (1 << 0)
2446#define VCO_CAL_OFFSET(x) (((x) & 0xF) << 3)
2451#define INIT_ALC_VALUE(x) (((x) & 0xF) << 4)
2452#define VCO_VARACTOR(x) (((x) & 0xF) << 0)
2457#define PORB_VCO_LOGIC (1 << 6)
2458#define VCO_OUTPUT_LEVEL(x) (((x) & 0xF) << 0)
2463#define TX_CP_CURRENT_DFLT (1 << 7)
2464#define VTUNE_FORCE (1 << 6)
2465#define CHARGE_PUMP_CURRENT(x) (((x) & 0x3F) << 0)
2470#define SYNTH_RECAL (1 << 7)
2471#define CHARGE_PUMP_OFFSET(x) (((x) & 0x3F) << 0)
2476#define HALF_VCO_CAL_CLK (1 << 7)
2477#define DITHER_MODE (1 << 6)
2478#define CP_OFFSET_OFF (1 << 4)
2479#define F_CPCAL (1 << 3)
2480#define CP_CAL_ENABLE (1 << 2)
2481#define CP_TEST(x) (((x) & 0x3) << 0)
2486#define LOOP_FILTER_C2(x) (((x) & 0xF) << 4)
2487#define LOOP_FILTER_C1(x) (((x) & 0xF) << 0)
2492#define LOOP_FILTER_R1(x) (((x) & 0xF) << 4)
2493#define LOOP_FILTER_C3(x) (((x) & 0xF) << 0)
2498#define LOOP_FILTER_BYPASS_R3 (1 << 7)
2499#define LOOP_FILTER_BYPASS_R1 (1 << 6)
2500#define LOOP_FILTER_BYPASS_C2 (1 << 5)
2501#define LOOP_FILTER_BYPASS_C1 (1 << 4)
2502#define LOOP_FILTER_R3(x) (((x) & 0xF) << 0)
2507#define NUMBER_SDM_DITHER_BITS(x) (((x) & 0xF) << 4)
2508#define FORCED_CP_CAL_WORD(x) (((x) & 0xF) << 0)
2513#define MUST_BE_ZEROS(x) (((x) & 0x3) << 5)
2514#define VCO_BIAS_TCF(x) (((x) & 0x3) << 3)
2515#define VCO_BIAS_REF(x) (((x) & 0x7) << 0)
2520#define VCO_BYPASS_BIAS_DAC_R (1 << 7)
2521#define VCO_COMP_BYPASS_BIAS_R (1 << 4)
2522#define BYPASS_PRESCALE_R (1 << 3)
2523#define LAST_ALC_ENABLE (1 << 2)
2524#define PRESCALE_BIAS(x) (((x) & 0x3) << 0)
2529#define CP_CAL_VALID (1 << 7)
2530#define COMP_OUT (1 << 6)
2531#define CP_CAL_DONE (1 << 5)
2532#define VCO_CAL_BUSY (1 << 4)
2533#define CP_CAL_WORD(x) (((x) & 0xF) << 0)
2538#define VCO_CAL_REF_MONITOR (1 << 3)
2539#define VCO_CAL_REF_TCF(x) (((x) & 0x7) << 0)
2544#define POWER_DOWN_VARACTOR_REF (1 << 3)
2545#define POWER_DOWN_VARACT_REF_TCF (1 << 2)
2546#define POWER_DOWN_CAL_TCF (1 << 1)
2547#define POWER_DOWN_VCO_BUFFFER (1 << 0)
2552#define CP_OVRG_HIGH (1 << 7)
2553#define CP_OVRG_LOW (1 << 6)
2554#define VCO_LOCK (1 << 1)
2559#define VCO_LDO_BYPASS (1 << 7)
2560#define VCO_LDO_INRUSH(x) (((x) & 0x3) << 5)
2561#define VCO_LDO_VOUT_SEL(x) (((x) & 0x7) << 2)
2562#define VCO_LDO_VDROP_SEL(x) (((x) & 0x3) << 0)
2567#define VCO_CAL_EN (1 << 7)
2568#define VCO_CAL_ALC_WAIT(x) (((x) & 0x7) << 4)
2569#define VCO_CAL_COUNT(x) (((x) & 0x3) << 2)
2570#define FB_CLOCK_ADV(x) (((x) & 0x3) << 0)
2575#define LOCK_DETECT_COUNT(x) (((x) & 0x3) << 2)
2576#define LOCK_DETECT_MODE(x) (((x) & 0x3) << 0)
2581#define CP_LEVEL_DETECT_POWER_DOWN (1 << 6)
2582#define CP_LEVEL_DETECT_THRESH_LOW(x) (((x) & 0x7) << 3)
2583#define CP_LEVEL_DETECT_THRESH_HIGH(x) (((x) & 0x7) << 0)
2588#define DSM_PROG(x) (((x) & 0xF) << 0)
2593#define SIF_CLOCK (1 << 6)
2594#define SIF_RESET_BAR (1 << 5)
2595#define SIF_ADDR(x) (((x) & 0x1F) << 0)
2600#define UPDATE_FREQ_WORD (1 << 7)
2601#define READ_EFFECTIVE_TUNING_WORD (1 << 5)
2602#define FREQ_CORRECTION_WORD_MSB(x) (((x) & 0x1F) << 0)
2607#define UPDATE_FREQ_WORD (1 << 7)
2608#define FREQ_CORRECTION_WORD_LSB(x) (((x) & 0x7F) << 0)
2613#define VCO_VARACTOR_REFERENCE_TCF(x) (((x) & 0x7) << 4)
2614#define VCO_VARACTOR_OFFSET(x) (((x) & 0xF) << 0)
2619#define VCO_VARACTOR_REFERENCE(x) (((x) & 0xF) << 0)
2624#define DCXO_TUNE_COARSE(x) (((x) & 0x3F) << 0)
2629#define DCXO_TUNE_FINE_LOW(x) (((x) & 0x1F) << 3)
2634#define DCXO_TUNE_FINE_HIGH(x) ((x) >> 5)
2639#define MUST_BE_ZERO (1 << 7)
2640#define DCXO_RTAIL(x) (((x) & 0x7) << 4)
2641#define DCXO_RD(x) (((x) & 0x3) << 2)
2646#define DCXO_TEMPCO_EN (1 << 7)
2647#define DCXO_TEMPCO_CLK (1 << 6)
2648#define DCXO_TEMPERATURE_COEF_ADDRESS(x) (((x) & 0x3F) << 0)
2653#define TX_FAST_LOCK_LOAD_SYNTH (1 << 3)
2654#define TX_FAST_LOCK_PROFILE_INIT (1 << 2)
2655#define TX_FAST_LOCK_PROFILE_PIN_SELECT (1 << 1)
2656#define TX_FAST_LOCK_MODE_ENABLE (1 << 0)
2657#define TX_FAST_LOCK_PROFILE(x) (((x) & 0x7) << 5)
2662#define TX_FAST_LOCK_PROGRAM_WRITE (1 << 1)
2663#define TX_FAST_LOCK_PROGRAM_CLOCK_ENABLE (1 << 0)
2668#define TX_LO_GEN_POWER_MODE(x) (((x) & 0xF) << 4)
2673#define POWER_DOWN_BANDGAP_REF (1 << 7)
2674#define MASTER_BIAS_FILTER_BYPASS (1 << 6)
2675#define MASTER_BIAS_REF_SEL (1 << 5)
2676#define MASTER_BIAS_TRIM(x) (((x) & 0x1F) << 0)
2681#define VCO_LDO_FILTER_BYPASS (1 << 7)
2682#define VCO_LDO_REF_SEL (1 << 6)
2683#define BANDGAP_REF_RESET (1 << 5)
2684#define BANDGAP_TEMP_TRIM(x) (((x) & 0x1F) << 0)
2689#define REF_DIVIDE_CONFIG_1_DFLT (1 << 2)
2690#define RX_REF_RESET_BAR (1 << 1)
2691#define RX_REF_DIVIDER_MSB (1 << 0)
2696#define RX_REF_DIVIDER_LSB (1 << 7)
2697#define TX_REF_RESET_BAR (1 << 4)
2698#define RX_REF_DOUBLER_FB_DELAY(x) (((x) & 0x3) << 5)
2699#define TX_REF_DIVIDER(x) (((x) & 0x3) << 2)
2700#define TX_REF_DOUBLER_FB_DELAY(x) (((x) & 0x3) << 0)
2705#define FULL_TABLE_GAIN_INDEX(x) (((x) & 0x7F) << 0)
2710#define LPF_GAIN_RX(x) (((x) & 0x1F) << 0)
2715#define DIGITAL_GAIN_RX(x) (((x) & 0x1F) << 0)
2720#define FAST_ATTACK_STATE_RX2(x) (((x) & 0x7) << 4)
2721#define FAST_ATTACK_STATE_RX1(x) (((x) & 0x7) << 0)
2722#define FAST_ATK_MASK 0x7
2723#define RX1_FAST_ATK_SHIFT 0
2724#define RX2_FAST_ATK_SHIFT 4
2725#define FAST_ATK_RESET 0
2726#define FAST_ATK_PEAK_DETECT 1
2727#define FAST_ATK_PWR_MEASURE 2
2728#define FAST_ATK_FINAL_SETTELING 3
2729#define FAST_ATK_FINAL_OVER 4
2730#define FAST_ATK_GAIN_LOCKED 5
2735#define SLOW_LOOP_STATE_RX2(x) (((x) & 0x7) << 4)
2736#define SLOW_LOOP_STATE_RX1(x) (((x) & 0x7) << 0)
2742#define GAIN_LOCK_1 (1 << 6)
2743#define LOW_POWER_1 (1 << 5)
2744#define LARGE_LMT_OL (1 << 4)
2745#define SMALL_LMT_OL (1 << 3)
2746#define LARGE_ADC_OL (1 << 2)
2747#define SMALL_ADC_OL (1 << 1)
2748#define DIG_SAT (1 << 0)
2752#define CTRL_ENABLE (1 << 0)
2757#define TONE_PRBS (1 << 1)
2758#define BIST_ENABLE (1 << 0)
2759#define TONE_FREQ(x) (((x) & 0x3) << 6)
2760#define TONE_LEVEL(x) (((x) & 0x3) << 4)
2761#define BIST_CTRL_POINT(x) (((x) & 0x3) << 2)
2766#define DATA_PORT_SP_HD_LOOP_TEST_OE (1 << 7)
2767#define RX_MASK (1 << 6)
2768#define CHANNEL (1 << 5)
2769#define DATA_PORT_LOOP_TEST_ENABLE (1 << 0)
2770#define OBSERVATION_POINT(x) (((x) & 0xF) << 1)
2775#define BIST_MASK_CHANNEL_2_Q_DATA (1 << 5)
2776#define BIST_MASK_CHANNEL_2_I_DATA (1 << 4)
2777#define BIST_MASK_CHANNEL_1_Q_DATA (1 << 3)
2778#define BIST_MASK_CHANNEL_1_I_DATA (1 << 2)
2779#define DATA_PORT_HILOW (1 << 1)
2780#define USE_DATA_PORT (1 << 0)
2781#define TEMP_SENSE_VBE_TEST(x) (((x) & 0x3) << 6)
2786#define DAC_TEST_ENABLE (1 << 7)
2787#define DAC_TEST_WORD(x) (((x) & 0x7F) << 0)
2792#define AD_READ (0 << 15)
2793#define AD_WRITE (1 << 15)
2794#define AD_CNT(x) ((((x) - 1) & 0x7) << 12)
2795#define AD_ADDR(x) ((x) & 0x3FF)
2802#define RSSI_MULTIPLIER 100
2803#define RSSI_RESOLUTION ((int) (0.25 * RSSI_MULTIPLIER))
2804#define RSSI_MAX_WEIGHT 255
2806#define MAX_LMT_INDEX 40
2807#define MAX_LPF_GAIN 24
2808#define MAX_DIG_GAIN 31
2810#define MAX_BBPLL_FREF 70007000UL
2811#define MIN_BBPLL_FREQ 714928500UL
2812#define MAX_BBPLL_FREQ 1430143000UL
2813#define MAX_BBPLL_DIV 64
2814#define MIN_BBPLL_DIV 2
2822#define MIN_ADC_CLK 25000000U
2824#define MAX_ADC_CLK 640000000U
2825#define MAX_DAC_CLK (MAX_ADC_CLK / 2)
2828#define MAX_RX_HB1 245760000UL
2829#define MAX_RX_HB2 320000000UL
2830#define MAX_RX_HB3 640000000UL
2832#define MAX_TX_HB1 160000000UL
2833#define MAX_TX_HB2 320000000UL
2834#define MAX_TX_HB3 320000000UL
2836#define MAX_BASEBAND_RATE 61440000UL
2838#define MAX_MBYTE_SPI 8
2840#define RFPLL_MODULUS 8388593UL
2841#define BBPLL_MODULUS 2088960UL
2843#define MAX_SYNTH_FREF 80008000UL
2844#define MIN_SYNTH_FREF 9999000UL
2845#define MIN_VCO_FREQ_HZ 6000000000ULL
2846#define MAX_CARRIER_FREQ_HZ 6000000000ULL
2847#define MIN_RX_CARRIER_FREQ_HZ 70000000ULL
2848#define MIN_TX_CARRIER_FREQ_HZ 46875001ULL
2850#define AD9363A_MAX_CARRIER_FREQ_HZ 3800000000ULL
2851#define AD9363A_MIN_CARRIER_FREQ_HZ 325000000ULL
2853#define MAX_TX_ATTENUATION_DB 89750
3289#define FASTLOOK_INIT 1
3335#ifndef AXI_ADC_NOT_PRESENT
3429 uint8_t *rbuf, uint32_t num);
3432 uint32_t reg, uint32_t *val);
3434 uint32_t reg, uint32_t val);
3436 uint32_t reg, uint32_t val);
3452 uint32_t rf_rx_bw, uint32_t rf_tx_bw);
3454 uint32_t tx_sample_rate,
3456 uint32_t *rx_path_clks,
3457 uint32_t *tx_path_clks);
3459 uint32_t *rx_path_clks,
3460 uint32_t *tx_path_clks);
3462 uint32_t *rx_path_clks,
3463 uint32_t *tx_path_clks);
3470 enum fir_dest dest, int32_t gain_dB,
3471 uint32_t ntaps,
short *coef);
3474 bool tx1,
bool tx2,
bool immed);
3477 uint32_t parent_rate);
3482 uint32_t parent_rate);
3484 uint32_t parent_rate);
3488 uint32_t parent_rate);
3490 uint32_t parent_rate);
3495 uint32_t parent_rate);
3504 bool rfdc_track,
bool rxquad_track);
3512 uint32_t level_dB, uint32_t mask);
3515 uint32_t *level_dB, uint32_t *mask);
3517 uint32_t rx_inputs, uint32_t txb);
3526 uint32_t
profile, uint8_t *values);
3528 uint32_t
profile, uint8_t *values);
3535int32_t
ad9361_find_opt(uint8_t *field, uint32_t size, uint32_t *ret_start);
3538 char *buf, int32_t buflen);
3549 uint32_t coarse, uint32_t fine);
@ CLKOUT_DISABLE
Definition ad5758.h:281
int32_t ad9361_fastlock_load(struct ad9361_rf_phy *phy, bool tx, uint32_t profile, uint8_t *values)
Definition ad9361.c:4986
ad9361_bist_mode
Definition ad9361.h:3310
@ BIST_DISABLE
Definition ad9361.h:3311
@ BIST_INJ_TX
Definition ad9361.h:3312
@ BIST_INJ_RX
Definition ad9361.h:3313
int32_t ad9361_rfpll_set_rate(struct refclk_scale *clk_priv, uint32_t rate)
Definition ad9361.c:7081
ad9361_pdata_rx_freq
Definition ad9361.h:3125
@ R2_FREQ
Definition ad9361.h:3128
@ R1_FREQ
Definition ad9361.h:3129
@ RX_SAMPL_FREQ
Definition ad9361.h:3131
@ ADC_FREQ
Definition ad9361.h:3127
@ NUM_RX_CLOCKS
Definition ad9361.h:3132
@ CLKRF_FREQ
Definition ad9361.h:3130
@ BBPLL_FREQ
Definition ad9361.h:3126
void ad9361_get_bist_prbs(struct ad9361_rf_phy *phy, enum ad9361_bist_mode *mode)
Definition ad9361.c:1207
int32_t ad9361_tracking_control(struct ad9361_rf_phy *phy, bool bbdc_track, bool rfdc_track, bool rxquad_track)
Definition ad9361.c:3305
int32_t ad9361_read_rssi(struct ad9361_rf_phy *phy, struct rf_rssi *rssi)
Definition ad9361.c:2441
uint8_t ad9361_ensm_get_state(struct ad9361_rf_phy *phy)
Definition ad9361.c:1967
int32_t ad9361_reset(struct ad9361_rf_phy *phy)
Definition ad9361.c:1036
int32_t ad9361_set_tx_atten(struct ad9361_rf_phy *phy, uint32_t atten_mdb, bool tx1, bool tx2, bool immed)
Definition ad9361.c:1633
int32_t ad9361_rfpll_dummy_set_rate(struct refclk_scale *clk_priv, uint32_t rate)
Definition ad9361.c:6982
uint64_t ad9361_from_clk(uint32_t freq)
Definition ad9361.c:1394
int32_t ad9361_rssi_gain_step_calib(struct ad9361_rf_phy *phy)
Definition ad9361.c:7410
uint32_t ad9361_rfpll_int_recalc_rate(struct refclk_scale *clk_priv, uint32_t parent_rate)
Definition ad9361.c:6765
int32_t ad9361_bbpll_round_rate(struct refclk_scale *clk_priv, uint32_t rate, uint32_t *prate)
Definition ad9361.c:6586
int32_t ad9361_dig_tune(struct ad9361_rf_phy *phy, uint32_t max_freq, enum dig_tune_flags flags)
Definition ad9361_conv.c:512
int32_t ad9361_reg_read(struct ad9361_rf_phy *phy, uint32_t reg, uint32_t *val)
Definition ad9361.c:748
int32_t ad9361_bist_prbs(struct ad9361_rf_phy *phy, enum ad9361_bist_mode mode)
Definition ad9361.c:1177
int32_t ad9361_reg_write(struct ad9361_rf_phy *phy, uint32_t reg, uint32_t val)
Definition ad9361.c:837
int32_t ad9361_spi_readm(struct no_os_spi_desc *spi, uint32_t reg, uint8_t *rbuf, uint32_t num)
Definition ad9361.c:688
dig_tune_flags
Definition ad9361.h:3301
@ RESTORE_DEFAULT
Definition ad9361.h:3307
@ DO_ODELAY
Definition ad9361.h:3305
@ BE_VERBOSE
Definition ad9361.h:3302
@ SKIP_STORE_RESULT
Definition ad9361.h:3306
@ BE_MOREVERBOSE
Definition ad9361.h:3303
@ DO_IDELAY
Definition ad9361.h:3304
void ad9361_ensm_restore_state(struct ad9361_rf_phy *phy, uint8_t ensm_state)
Definition ad9361.c:2058
ad9361_pdata_tx_freq
Definition ad9361.h:3135
@ DAC_FREQ
Definition ad9361.h:3137
@ T1_FREQ
Definition ad9361.h:3139
@ IGNORE
Definition ad9361.h:3136
@ CLKTF_FREQ
Definition ad9361.h:3140
@ T2_FREQ
Definition ad9361.h:3138
@ TX_SAMPL_FREQ
Definition ad9361.h:3141
@ NUM_TX_CLOCKS
Definition ad9361.h:3142
int32_t ad9361_do_calib_run(struct ad9361_rf_phy *phy, uint32_t cal, int32_t arg)
Definition ad9361.c:5664
rf_gain_ctrl_mode
Definition ad9361.h:2895
@ RF_GAIN_MGC
Definition ad9361.h:2896
@ RF_GAIN_SLOWATTACK_AGC
Definition ad9361.h:2898
@ RF_GAIN_HYBRID_AGC
Definition ad9361.h:2899
@ RF_GAIN_FASTATTACK_AGC
Definition ad9361.h:2897
int32_t ad9361_calculate_rf_clock_chain(struct ad9361_rf_phy *phy, uint32_t tx_sample_rate, uint32_t rate_gov, uint32_t *rx_path_clks, uint32_t *tx_path_clks)
Definition ad9361.c:4754
ad9361_clkout
Definition ad9361.h:3145
@ ADC_CLK_DIV_3
Definition ad9361.h:3149
@ ADC_CLK_DIV_16
Definition ad9361.h:3152
@ ADC_CLK_DIV_8
Definition ad9361.h:3151
@ ADC_CLK_DIV_2
Definition ad9361.h:3148
@ BUFFERED_XTALN_DCXO
Definition ad9361.h:3147
@ ADC_CLK_DIV_4
Definition ad9361.h:3150
int32_t ad9361_unregister_clocks(struct ad9361_rf_phy *phy)
Definition ad9361.c:7390
int32_t ad9361_set_trx_clock_chain_freq(struct ad9361_rf_phy *phy, uint32_t freq)
Definition ad9361.c:4876
int32_t ad9361_rfpll_int_round_rate(struct refclk_scale *clk_priv, uint32_t rate, uint32_t *prate)
Definition ad9361.c:6821
int32_t ad9361_rfpll_int_set_rate(struct refclk_scale *clk_priv, uint32_t rate, uint32_t parent_rate)
Definition ad9361.c:6850
int32_t ad9361_ensm_set_state(struct ad9361_rf_phy *phy, uint8_t ensm_state, bool pinctrl)
Definition ad9361.c:4422
uint32_t ad9361_rfpll_dummy_recalc_rate(struct refclk_scale *clk_priv)
Definition ad9361.c:6969
int32_t ad9361_tx_mute(struct ad9361_rf_phy *phy, uint32_t state)
Definition ad9361.c:1697
int32_t ad9361_spi_write(struct no_os_spi_desc *spi, uint32_t reg, uint32_t val)
Definition ad9361.c:805
int32_t ad9361_find_opt(uint8_t *field, uint32_t size, uint32_t *ret_start)
Definition ad9361.c:976
int32_t ad9361_register_clocks(struct ad9361_rf_phy *phy)
Definition ad9361.c:7275
uint32_t ad9361_gt(struct ad9361_rf_phy *phy)
Definition ad9361.c:1367
int32_t ad9361_mcs(struct ad9361_rf_phy *phy, int32_t step)
Definition ad9361.c:5237
int32_t ad9361_get_rx_gain(struct ad9361_rf_phy *phy, uint32_t rx_id, struct rf_rx_gain *rx_gain)
Definition ad9361.c:1901
void ad9361_clear_state(struct ad9361_rf_phy *phy)
Definition ad9361.c:5291
int32_t ad9361_get_temp(struct ad9361_rf_phy *phy)
Definition ad9361.c:4202
int32_t ad9361_hdl_loopback(struct ad9361_rf_phy *phy, bool enable)
Definition ad9361_conv.c:101
uint32_t ad9361_rfpll_recalc_rate(struct refclk_scale *clk_priv)
Definition ad9361.c:6997
int32_t ad9361_post_setup(struct ad9361_rf_phy *phy)
Definition ad9361_conv.c:592
int32_t ad9361_get_tx_atten(struct ad9361_rf_phy *phy, uint32_t tx_num)
Definition ad9361.c:1672
int32_t ad9361_get_trx_clock_chain(struct ad9361_rf_phy *phy, uint32_t *rx_path_clks, uint32_t *tx_path_clks)
Definition ad9361.c:4716
void ad9361_get_bist_tone(struct ad9361_rf_phy *phy, enum ad9361_bist_mode *mode, uint32_t *freq_Hz, uint32_t *level_dB, uint32_t *mask)
Definition ad9361.c:1279
int32_t ad9361_update_rf_bandwidth(struct ad9361_rf_phy *phy, uint32_t rf_rx_bw, uint32_t rf_tx_bw)
Definition ad9361.c:5705
f_agc_target_gain_index_type
Definition ad9361.h:2902
@ SET_GAIN
Definition ad9361.h:2904
@ NO_GAIN_CHANGE
Definition ad9361.h:2906
@ OPTIMIZED_GAIN
Definition ad9361.h:2905
@ MAX_GAIN
Definition ad9361.h:2903
uint32_t ad9361_clk_factor_recalc_rate(struct refclk_scale *clk_priv, uint32_t parent_rate)
Definition ad9361.c:6476
int32_t ad9361_fastlock_save(struct ad9361_rf_phy *phy, bool tx, uint32_t profile, uint8_t *values)
Definition ad9361.c:5217
int32_t ad9361_set_rx_gain(struct ad9361_rf_phy *phy, uint32_t rx_id, struct rf_rx_gain *rx_gain)
Definition ad9361.c:2213
int32_t ad9361_bbpll_set_rate(struct refclk_scale *clk_priv, uint32_t rate, uint32_t parent_rate)
Definition ad9361.c:6626
uint32_t ad9361_validate_rf_bw(struct ad9361_rf_phy *phy, uint32_t bw)
Definition ad9361.c:934
void ad9361_get_bist_loopback(struct ad9361_rf_phy *phy, int32_t *mode)
Definition ad9361.c:1166
rssi_restart_mode
Definition ad9361.h:3028
@ AGC_IN_FAST_ATTACK_MODE_LOCKS_THE_GAIN
Definition ad9361.h:3029
@ ENTERS_RX_MODE
Definition ad9361.h:3031
@ SPI_WRITE_TO_REGISTER
Definition ad9361.h:3033
@ GAIN_CHANGE_OCCURS_OR_EN_AGC_PIN_PULLED_HIGH
Definition ad9361.h:3034
@ EN_AGC_PIN_IS_PULLED_HIGH
Definition ad9361.h:3030
@ GAIN_CHANGE_OCCURS
Definition ad9361.h:3032
@ LUT_FTDD_40
Definition ad9361.h:3248
@ LUT_FTDD_60
Definition ad9361.h:3249
@ LUT_FTDD_80
Definition ad9361.h:3250
@ LUT_FTDD_ENT
Definition ad9361.h:3251
ad9361_clocks
Definition ad9361.h:3254
@ RX_RFPLL
Definition ad9361.h:3273
@ CLKTF_CLK
Definition ad9361.h:3267
@ T2_CLK
Definition ad9361.h:3265
@ R1_CLK
Definition ad9361.h:3261
@ RX_RFPLL_DUMMY
Definition ad9361.h:3271
@ DAC_CLK
Definition ad9361.h:3264
@ TX_RFPLL_INT
Definition ad9361.h:3270
@ TX_RFPLL
Definition ad9361.h:3274
@ TX_REFCLK
Definition ad9361.h:3257
@ NUM_AD9361_CLKS
Definition ad9361.h:3275
@ R2_CLK
Definition ad9361.h:3260
@ BB_REFCLK
Definition ad9361.h:3255
@ RX_RFPLL_INT
Definition ad9361.h:3269
@ CLKRF_CLK
Definition ad9361.h:3262
@ T1_CLK
Definition ad9361.h:3266
@ RX_SAMPL_CLK
Definition ad9361.h:3263
@ EXT_REF_CLK
Definition ad9361.h:3276
@ ADC_CLK
Definition ad9361.h:3259
@ BBPLL_CLK
Definition ad9361.h:3258
@ TX_SAMPL_CLK
Definition ad9361.h:3268
@ TX_RFPLL_DUMMY
Definition ad9361.h:3272
@ RX_REFCLK
Definition ad9361.h:3256
uint32_t ad9361_bbpll_recalc_rate(struct refclk_scale *clk_priv, uint32_t parent_rate)
Definition ad9361.c:6559
int32_t ad9361_clk_factor_round_rate(struct refclk_scale *clk_priv, uint32_t rate, uint32_t *prate)
Definition ad9361.c:6494
int32_t ad9361_load_fir_filter_coef(struct ad9361_rf_phy *phy, enum fir_dest dest, int32_t gain_dB, uint32_t ntaps, short *coef)
uint32_t ad9361_to_clk(uint64_t freq)
Definition ad9361.c:1383
int32_t ad9361_setup(struct ad9361_rf_phy *phy)
Definition ad9361.c:5350
rx_gain_table_type
Definition ad9361.h:2859
@ RXGAIN_SPLIT_TBL
Definition ad9361.h:2861
@ RXGAIN_FULL_TBL
Definition ad9361.h:2860
int32_t ad9361_rfpll_round_rate(struct refclk_scale *clk_priv, uint32_t rate)
Definition ad9361.c:7039
int32_t ad9361_1rx1tx_channel_map(struct ad9361_rf_phy *phy, bool tx, int32_t channel)
Definition ad9361.c:1012
int ad9361_synth_lo_powerdown(struct ad9361_rf_phy *phy, enum synth_pd_ctrl rx, enum synth_pd_ctrl tx)
Definition ad9361.c:3456
void ad9361_ensm_restore_prev_state(struct ad9361_rf_phy *phy)
Definition ad9361.c:2112
int32_t ad9361_clk_mux_set_parent(struct refclk_scale *clk_priv, uint8_t index)
Definition ad9361.c:7138
int32_t ad9361_clk_factor_set_rate(struct refclk_scale *clk_priv, uint32_t rate, uint32_t parent_rate)
Definition ad9361.c:6528
int32_t ad9361_set_dcxo_tune(struct ad9361_rf_phy *phy, uint32_t coarse, uint32_t fine)
Definition ad9361.c:3511
fir_dest
Definition ad9361.h:2880
@ FIR_IS_RX
Definition ad9361.h:2887
@ FIR_TX1
Definition ad9361.h:2881
@ FIR_TX2
Definition ad9361.h:2882
@ FIR_RX1_RX2
Definition ad9361.h:2886
@ FIR_TX1_TX2
Definition ad9361.h:2883
@ FIR_RX2
Definition ad9361.h:2885
@ FIR_RX1
Definition ad9361.h:2884
int32_t ad9361_fastlock_recall(struct ad9361_rf_phy *phy, bool tx, uint32_t profile)
Definition ad9361.c:5161
int32_t ad9361_dig_interface_timing_analysis(struct ad9361_rf_phy *phy, char *buf, int32_t buflen)
Definition ad9361_conv.c:275
int32_t ad9361_en_dis_tx(struct ad9361_rf_phy *phy, uint32_t tx_if, uint32_t enable)
Definition ad9361.c:1067
int32_t ad9361_set_ensm_mode(struct ad9361_rf_phy *phy, bool fdd, bool pinctrl)
Definition ad9361.c:4896
dev_id
Definition ad9361.h:3322
@ ID_AD9364
Definition ad9361.h:3324
@ ID_AD9363A
Definition ad9361.h:3325
@ ID_AD9361
Definition ad9361.h:3323
int32_t ad9361_set_gain_ctrl_mode(struct ad9361_rf_phy *phy, struct rf_gain_ctrl *gain_ctrl)
Definition ad9361.c:2366
int32_t ad9361_bist_loopback(struct ad9361_rf_phy *phy, int32_t mode)
Definition ad9361.c:1119
rx_gain_table_name
Definition ad9361.h:2864
@ TBL_1300_4000_MHZ
Definition ad9361.h:2866
@ TBL_4000_6000_MHZ
Definition ad9361.h:2867
@ RXGAIN_TBLS_END
Definition ad9361.h:2868
@ TBL_200_1300_MHZ
Definition ad9361.h:2865
int32_t ad9361_en_dis_rx(struct ad9361_rf_phy *phy, uint32_t rx_if, uint32_t enable)
Definition ad9361.c:1084
int32_t ad9361_spi_read(struct no_os_spi_desc *spi, uint32_t reg)
Definition ad9361.c:729
int32_t ad9361_init_gain_tables(struct ad9361_rf_phy *phy)
int32_t ad9361_set_trx_clock_chain(struct ad9361_rf_phy *phy, uint32_t *rx_path_clks, uint32_t *tx_path_clks)
Definition ad9361.c:4628
int32_t ad9361_rf_port_setup(struct ad9361_rf_phy *phy, bool is_out, uint32_t rx_inputs, uint32_t txb)
Definition ad9361.c:3625
debugfs_cmd
Definition ad9361.h:3417
@ DBGFS_BIST_PRBS
Definition ad9361.h:3421
@ DBGFS_BIST_TONE
Definition ad9361.h:3422
@ DBGFS_BIST_DT_ANALYSIS
Definition ad9361.h:3423
@ DBGFS_RXGAIN_1
Definition ad9361.h:3424
@ DBGFS_LOOPBACK
Definition ad9361.h:3420
@ DBGFS_RXGAIN_2
Definition ad9361.h:3425
@ DBGFS_NONE
Definition ad9361.h:3418
@ DBGFS_INIT
Definition ad9361.h:3419
void ad9361_ensm_force_state(struct ad9361_rf_phy *phy, uint8_t ensm_state)
Definition ad9361.c:1979
int32_t ad9361_validate_enable_fir(struct ad9361_rf_phy *phy)
Definition ad9361.c:6072
int32_t ad9361_fastlock_store(struct ad9361_rf_phy *phy, bool tx, uint32_t profile)
Definition ad9361.c:5029
synth_pd_ctrl
Definition ad9361.h:3316
@ LO_ON
Definition ad9361.h:3319
@ LO_DONTCARE
Definition ad9361.h:3317
@ LO_OFF
Definition ad9361.h:3318
int32_t ad9361_bist_tone(struct ad9361_rf_phy *phy, enum ad9361_bist_mode mode, uint32_t freq_Hz, uint32_t level_dB, uint32_t mask)
Definition ad9361.c:1222
struct no_os_spi_desc * spi
Definition main.c:72
Header file of Common Driver.
Header file of GPIO Interface.
uint8_t VCO_Output_Level
Definition ad9361.h:3233
uint8_t LF_R1
Definition ad9361.h:3242
uint8_t VCO_Cal_Offset
Definition ad9361.h:3237
uint8_t VCO_Bias_Ref
Definition ad9361.h:3235
uint8_t LF_C3
Definition ad9361.h:3243
uint8_t VCO_Bias_Tcf
Definition ad9361.h:3236
uint16_t VCO_MHz
Definition ad9361.h:3232
uint8_t VCO_Varactor
Definition ad9361.h:3234
uint8_t LF_C2
Definition ad9361.h:3240
uint8_t Charge_Pump_Current
Definition ad9361.h:3239
uint8_t LF_R3
Definition ad9361.h:3244
uint8_t VCO_Varactor_Reference
Definition ad9361.h:3238
uint8_t LF_C1
Definition ad9361.h:3241
const char * propname
Definition ad9361.h:3281
uint8_t cmd
Definition ad9361.h:3285
uint8_t size
Definition ad9361.h:3284
uint32_t val
Definition ad9361.h:3283
void * out_value
Definition ad9361.h:3282
struct ad9361_rf_phy * phy
Definition ad9361.h:3280
uint8_t flags
Definition ad9361.h:3290
uint8_t alc_written
Definition ad9361.h:3292
uint8_t alc_orig
Definition ad9361.h:3291
uint8_t save_profile
Definition ad9361.h:3296
struct ad9361_fastlock_entry entry[2][8]
Definition ad9361.h:3298
uint8_t current_profile[2]
Definition ad9361.h:3297
bool rfdc_track_en
Definition ad9361.h:3387
uint8_t agc_mode[2]
Definition ad9361.h:3386
uint32_t tx1_atten_cached
Definition ad9361.h:3393
uint32_t current_tx_bw_Hz
Definition ad9361.h:3371
uint32_t bist_tone_freq_Hz
Definition ad9361.h:3402
bool bypass_tx_fir
Definition ad9361.h:3375
enum dev_id dev_sel
Definition ad9361.h:3329
struct no_os_gpio_desc * gpio_desc_sync
Definition ad9361.h:3332
bool auto_cal_en
Definition ad9361.h:3358
struct axiadc_state * adc_state
Definition ad9361.h:3397
int32_t bist_loopback_mode
Definition ad9361.h:3398
struct ad9361_phy_platform_data * pdata
Definition ad9361.h:3347
struct no_os_spi_desc * spi
Definition ad9361.h:3330
uint32_t rxbbf_div
Definition ad9361.h:3372
struct axi_adc * rx_adc
Definition ad9361.h:3336
struct refclk_scale * ref_clk_scale[NUM_AD9361_CLKS]
Definition ad9361.h:3341
struct gain_table_info * gt_info
Definition ad9361.h:3355
uint32_t rate_governor
Definition ad9361.h:3373
enum ad9361_bist_mode bist_prbs_mode
Definition ad9361.h:3400
int32_t(* ad9361_rfpll_ext_set_rate)(struct refclk_scale *clk_priv, uint32_t rate)
Definition ad9361.h:3345
struct no_os_gpio_desc * gpio_desc_cal_sw1
Definition ad9361.h:3333
uint32_t current_rx_path_clks[NUM_RX_CLOCKS]
Definition ad9361.h:3366
uint8_t cached_tx_rfpll_div
Definition ad9361.h:3351
enum ad9361_bist_mode bist_tone_mode
Definition ad9361.h:3401
uint16_t auxdac2_value
Definition ad9361.h:3392
uint32_t bist_tone_level_dB
Definition ad9361.h:3403
struct axi_dac * tx_dac
Definition ad9361.h:3337
uint32_t current_table
Definition ad9361.h:3354
struct no_os_clk * clk_refin
Definition ad9361.h:3339
struct axiadc_converter * adc_conv
Definition ad9361.h:3396
uint8_t tx_fir_ntaps
Definition ad9361.h:3383
uint32_t current_rx_bw_Hz
Definition ad9361.h:3370
uint8_t cached_rx_rfpll_div
Definition ad9361.h:3350
bool current_rx_use_tdd_table
Definition ad9361.h:3365
bool bypass_rx_fir
Definition ad9361.h:3374
int32_t tx_quad_lpf_tia_match
Definition ad9361.h:3353
uint32_t filt_tx_bw_Hz
Definition ad9361.h:3381
uint32_t flags
Definition ad9361.h:3368
uint64_t current_rx_lo_freq
Definition ad9361.h:3363
uint8_t cached_synth_pd[2]
Definition ad9361.h:3352
bool current_tx_use_tdd_table
Definition ad9361.h:3364
uint32_t bist_tone_mask
Definition ad9361.h:3404
bool txmon_tdd_en
Definition ad9361.h:3390
uint64_t last_tx_quad_cal_freq
Definition ad9361.h:3360
uint32_t filt_tx_path_clks[NUM_TX_CLOCKS]
Definition ad9361.h:3379
uint32_t cal_threshold_freq
Definition ad9361.h:3369
uint8_t rx_fir_ntaps
Definition ad9361.h:3385
bool ensm_pin_ctl_en
Definition ad9361.h:3356
bool manual_tx_quad_cal_en
Definition ad9361.h:3359
struct ad9361_fastlock fastlock
Definition ad9361.h:3395
bool rx_eq_2tx
Definition ad9361.h:3376
uint32_t(* ad9361_rfpll_ext_recalc_rate)(struct refclk_scale *clk_priv)
Definition ad9361.h:3342
uint32_t filt_rx_path_clks[NUM_RX_CLOCKS]
Definition ad9361.h:3378
uint32_t filt_rx_bw_Hz
Definition ad9361.h:3380
uint16_t auxdac1_value
Definition ad9361.h:3391
struct no_os_gpio_desc * gpio_desc_resetb
Definition ad9361.h:3331
uint32_t last_tx_quad_cal_phase
Definition ad9361.h:3361
uint8_t tx_fir_int
Definition ad9361.h:3382
bool quad_track_en
Definition ad9361.h:3389
uint8_t prev_ensm_state
Definition ad9361.h:3348
int32_t bist_config
Definition ad9361.h:3399
bool bbdc_track_en
Definition ad9361.h:3388
bool filt_valid
Definition ad9361.h:3377
uint32_t tx2_atten_cached
Definition ad9361.h:3394
struct no_os_gpio_desc * gpio_desc_cal_sw2
Definition ad9361.h:3334
struct no_os_clk * clks[NUM_AD9361_CLKS]
Definition ad9361.h:3340
uint32_t current_tx_path_clks[NUM_TX_CLOCKS]
Definition ad9361.h:3367
uint8_t rx_fir_dec
Definition ad9361.h:3384
uint8_t curr_ensm_state
Definition ad9361.h:3349
bool bbpll_initialized
Definition ad9361.h:3405
uint64_t current_tx_lo_freq
Definition ad9361.h:3362
int32_t(* ad9361_rfpll_ext_round_rate)(struct refclk_scale *clk_priv, uint32_t rate)
Definition ad9361.h:3343
int8_t offset
Definition ad9361.h:3078
uint32_t auxadc_decimation
Definition ad9361.h:3083
uint32_t temp_sensor_decimation
Definition ad9361.h:3080
uint32_t auxadc_clock_rate
Definition ad9361.h:3082
uint32_t temp_time_inteval_ms
Definition ad9361.h:3079
bool periodic_temp_measuremnt
Definition ad9361.h:3081
bool dac2_in_alert_en
Definition ad9361.h:3020
uint8_t dac2_rx_delay_us
Definition ad9361.h:3024
uint8_t dac1_tx_delay_us
Definition ad9361.h:3023
bool dac1_in_rx_en
Definition ad9361.h:3014
bool dac2_in_tx_en
Definition ad9361.h:3019
bool dac1_in_tx_en
Definition ad9361.h:3015
uint16_t dac2_default_value
Definition ad9361.h:3010
bool dac2_in_rx_en
Definition ad9361.h:3018
uint16_t dac1_default_value
Definition ad9361.h:3009
bool dac1_in_alert_en
Definition ad9361.h:3016
uint8_t dac2_tx_delay_us
Definition ad9361.h:3025
bool auxdac_manual_mode_en
Definition ad9361.h:3012
uint8_t dac1_rx_delay_us
Definition ad9361.h:3022
AXI ADC Device Descriptor.
Definition axi_adc_core.h:123
AXI DAC Device Descriptor.
Definition axi_dac_core.h:53
Definition ad9361_util.h:81
Definition ad9361_util.h:71
uint8_t index
Definition ad9361.h:3064
uint8_t en_mask
Definition ad9361.h:3065
uint16_t bypass_loss_mdB
Definition ad9361.h:3070
bool elna_2_control_en
Definition ad9361.h:3073
bool elna_in_gaintable_all_index_en
Definition ad9361.h:3074
bool elna_1_control_en
Definition ad9361.h:3072
uint32_t settling_delay_ns
Definition ad9361.h:3071
uint16_t gain_mdB
Definition ad9361.h:3069
uint8_t f_agc_final_overrange_count
Definition ad9361.h:2982
uint8_t agc_attack_delay_extra_margin_us
Definition ad9361.h:2936
uint8_t agc_inner_thresh_low_inc_steps
Definition ad9361.h:2943
uint8_t f_agc_lock_level_gain_increase_upper_limit
Definition ad9361.h:2978
bool dig_gain_en
Definition ad9361.h:2924
uint8_t lmt_overload_small_exceed_counter
Definition ad9361.h:2954
bool immed_gain_change_if_large_adc_overload
Definition ad9361.h:2962
uint8_t agc_outer_thresh_high
Definition ad9361.h:2938
uint8_t adc_small_overload_exceed_counter
Definition ad9361.h:2947
uint8_t adc_ovr_sample_size
Definition ad9361.h:2914
bool sync_for_gain_counter_en
Definition ad9361.h:2959
uint8_t adc_large_overload_inc_steps
Definition ad9361.h:2949
uint8_t adc_large_overload_thresh
Definition ad9361.h:2916
uint8_t mgc_dec_gain_step
Definition ad9361.h:2932
bool f_agc_gain_increase_after_gain_lock_en
Definition ad9361.h:2984
uint8_t f_agc_lp_thresh_increment_steps
Definition ad9361.h:2973
uint8_t f_agc_optimized_gain_offset
Definition ad9361.h:2990
uint8_t f_agc_large_overload_inc_steps
Definition ad9361.h:3005
uint8_t low_power_thresh
Definition ad9361.h:2921
enum f_agc_target_gain_index_type f_agc_gain_index_type_after_exit_rx_mode
Definition ad9361.h:2987
enum f_agc_target_gain_index_type f_agc_rst_gla_if_en_agc_pulled_high_mode
Definition ad9361.h:3002
uint8_t f_agc_lmt_final_settling_steps
Definition ad9361.h:2981
bool mgc_rx2_ctrl_inp_en
Definition ad9361.h:2929
uint8_t f_agc_lp_thresh_increment_time
Definition ad9361.h:2972
uint8_t f_agc_lock_level
Definition ad9361.h:2976
uint8_t adc_small_overload_thresh
Definition ad9361.h:2915
enum rf_gain_ctrl_mode rx2_mode
Definition ad9361.h:2911
uint8_t agc_inner_thresh_high
Definition ad9361.h:2940
uint8_t f_agc_lpf_final_settling_steps
Definition ad9361.h:2980
uint8_t agc_outer_thresh_low
Definition ad9361.h:2944
uint8_t f_agc_power_measurement_duration_in_state5
Definition ad9361.h:3004
uint8_t mgc_split_table_ctrl_inp_gain_mode
Definition ad9361.h:2933
bool f_agc_rst_gla_stronger_sig_thresh_exceeded_en
Definition ad9361.h:2991
uint32_t f_agc_state_wait_time_ns
Definition ad9361.h:2969
bool mgc_rx1_ctrl_inp_en
Definition ad9361.h:2928
bool use_rx_fir_out_for_dec_pwr_meas
Definition ad9361.h:2922
bool f_agc_rst_gla_engergy_lost_sig_thresh_exceeded_en
Definition ad9361.h:2993
uint8_t dig_gain_step_size
Definition ad9361.h:2958
bool f_agc_lock_level_lmt_gain_increase_en
Definition ad9361.h:2977
uint8_t f_agc_rst_gla_engergy_lost_sig_thresh_below_ll
Definition ad9361.h:2995
uint32_t f_agc_dec_pow_measuremnt_duration
Definition ad9361.h:2968
uint8_t dig_saturation_exceed_counter
Definition ad9361.h:2957
bool f_agc_rst_gla_large_lmt_overload_en
Definition ad9361.h:2998
uint16_t lmt_overload_low_thresh
Definition ad9361.h:2919
uint8_t mgc_inc_gain_step
Definition ad9361.h:2931
uint8_t f_agc_energy_lost_stronger_sig_gain_lock_exit_cnt
Definition ad9361.h:2996
uint8_t agc_outer_thresh_low_inc_steps
Definition ad9361.h:2945
uint8_t adc_large_overload_exceed_counter
Definition ad9361.h:2948
bool f_agc_rst_gla_en_agc_pulled_high_en
Definition ad9361.h:2999
uint8_t lmt_overload_large_exceed_counter
Definition ad9361.h:2953
uint8_t f_agc_rst_gla_stronger_sig_thresh_above_ll
Definition ad9361.h:2992
uint16_t dec_pow_measuremnt_duration
Definition ad9361.h:2920
bool f_agc_rst_gla_large_adc_overload_en
Definition ad9361.h:2997
bool adc_lmt_small_overload_prevent_gain_inc
Definition ad9361.h:2951
bool f_agc_use_last_lock_level_for_set_gain_en
Definition ad9361.h:2989
bool immed_gain_change_if_large_lmt_overload
Definition ad9361.h:2963
bool f_agc_allow_agc_gain_increase
Definition ad9361.h:2971
uint32_t gain_update_interval_us
Definition ad9361.h:2961
uint8_t agc_inner_thresh_high_dec_steps
Definition ad9361.h:2941
enum rf_gain_ctrl_mode rx1_mode
Definition ad9361.h:2910
uint8_t agc_outer_thresh_high_dec_steps
Definition ad9361.h:2939
uint8_t max_dig_gain
Definition ad9361.h:2925
uint8_t agc_inner_thresh_low
Definition ad9361.h:2942
uint16_t lmt_overload_high_thresh
Definition ad9361.h:2918
bool f_agc_rst_gla_engergy_lost_goto_optim_gain_en
Definition ad9361.h:2994
uint8_t lmt_overload_large_inc_steps
Definition ad9361.h:2955
uint64_t start
Definition ad9361.h:2872
uint64_t end
Definition ad9361.h:2873
uint8_t max_index
Definition ad9361.h:2874
uint8_t split_table
Definition ad9361.h:2875
int8_t * abs_gain_tbl
Definition ad9361.h:2876
uint8_t(* tab)[3]
Definition ad9361.h:2877
bool gpo3_slave_rx_en
Definition ad9361.h:3099
uint8_t gpo3_tx_delay_us
Definition ad9361.h:3108
bool gpo1_inactive_state_high_en
Definition ad9361.h:3090
bool gpo3_slave_tx_en
Definition ad9361.h:3100
uint8_t gpo2_rx_delay_us
Definition ad9361.h:3105
bool gpo2_slave_rx_en
Definition ad9361.h:3097
uint8_t gpo3_rx_delay_us
Definition ad9361.h:3107
bool gpo0_slave_rx_en
Definition ad9361.h:3093
bool gpo1_slave_rx_en
Definition ad9361.h:3095
bool gpo1_slave_tx_en
Definition ad9361.h:3096
bool gpo2_inactive_state_high_en
Definition ad9361.h:3091
uint8_t gpo0_tx_delay_us
Definition ad9361.h:3102
uint32_t gpo_manual_mode_enable_mask
Definition ad9361.h:3087
bool gpo2_slave_tx_en
Definition ad9361.h:3098
uint8_t gpo0_rx_delay_us
Definition ad9361.h:3101
uint8_t gpo2_tx_delay_us
Definition ad9361.h:3106
bool gpo0_slave_tx_en
Definition ad9361.h:3094
uint8_t gpo1_tx_delay_us
Definition ad9361.h:3104
uint8_t gpo1_rx_delay_us
Definition ad9361.h:3103
bool gpo3_inactive_state_high_en
Definition ad9361.h:3092
bool gpo_manual_mode_en
Definition ad9361.h:3088
bool gpo0_inactive_state_high_en
Definition ad9361.h:3089
Definition no_os_clk.h:58
Structure holding the GPIO descriptor.
Definition no_os_gpio.h:84
Structure holding SPI descriptor.
Definition no_os_spi.h:180
uint8_t lvds_invert[2]
Definition ad9361.h:3060
uint8_t rx_clk_data_delay
Definition ad9361.h:3056
uint8_t tx_clk_data_delay
Definition ad9361.h:3057
uint8_t lvds_bias_ctrl
Definition ad9361.h:3059
uint8_t pp_conf[3]
Definition ad9361.h:3055
uint8_t digital_io_ctrl
Definition ad9361.h:3058
struct ad9361_rf_phy * phy
Definition ad9361.h:3410
uint32_t mult
Definition ad9361.h:3411
struct no_os_spi_desc * spi
Definition ad9361.h:3409
enum ad9361_clocks parent_source
Definition ad9361.h:3414
uint32_t div
Definition ad9361.h:3412
enum ad9361_clocks source
Definition ad9361.h:3413
uint32_t ant
Definition ad9361.h:2891
uint8_t mode
Definition ad9361.h:2892
uint32_t lna_index
Definition ad9361.h:3218
uint32_t ant
Definition ad9361.h:3211
uint32_t mixer_index
Definition ad9361.h:3220
uint32_t tia_index
Definition ad9361.h:3219
uint32_t fgt_lmt_index
Definition ad9361.h:3213
int32_t gain_db
Definition ad9361.h:3212
uint32_t lpf_gain
Definition ad9361.h:3215
uint32_t digital_gain
Definition ad9361.h:3216
uint32_t lmt_gain
Definition ad9361.h:3214
int32_t idx_step_offset
Definition ad9361.h:3051
int32_t starting_gain_db
Definition ad9361.h:3047
int32_t max_gain_db
Definition ad9361.h:3048
enum rx_gain_table_type tbl_type
Definition ad9361.h:3046
int32_t max_idx
Definition ad9361.h:3050
int32_t gain_step_db
Definition ad9361.h:3049
uint8_t low_gain_dB
Definition ad9361.h:3115
uint8_t high_gain_dB
Definition ad9361.h:3116
uint32_t low_high_gain_threshold_mdB
Definition ad9361.h:3114
uint8_t tx1_mon_lo_cm
Definition ad9361.h:3121
uint8_t tx2_mon_front_end_gain
Definition ad9361.h:3120
uint16_t tx_mon_delay
Definition ad9361.h:3117
uint16_t tx_mon_duration
Definition ad9361.h:3118
bool tx_mon_track_en
Definition ad9361.h:3112
uint8_t tx1_mon_front_end_gain
Definition ad9361.h:3119
bool one_shot_mode_en
Definition ad9361.h:3113
uint8_t tx2_mon_lo_cm
Definition ad9361.h:3122