no-OS
Loading...
Searching...
No Matches
adf4382.h
Go to the documentation of this file.
1/***************************************************************************/
34#ifndef _ADF4382_H_
35#define _ADF4382_H_
36
37#include <stdint.h>
38#include <string.h>
39#include "no_os_units.h"
40#include "no_os_util.h"
41#include "no_os_spi.h"
42
43/* ADF4382 REG0000 Map */
44#define ADF4382_SOFT_RESET_R_MSK NO_OS_BIT(7)
45#define ADF4382_LSB_FIRST_R_MSK NO_OS_BIT(6)
46#define ADF4382_ADDRESS_ASC_R_MSK NO_OS_BIT(5)
47#define ADF4382_SDO_ACTIVE_R_MSK NO_OS_BIT(4)
48#define ADF4382_SDO_ACTIVE_MSK NO_OS_BIT(3)
49#define ADF4382_ADDRESS_ASC_MSK NO_OS_BIT(2)
50#define ADF4382_LSB_FIRST_MSK NO_OS_BIT(1)
51#define ADF4382_SOFT_RESET_MSK NO_OS_BIT(0)
52#define ADF4382_RESET_CMD 0x81
53
54/* ADF4382 REG0000 NO_OS_BIT Definition */
55#define ADF4382_SDO_ACTIVE_SPI_3W 0x0
56#define ADF4382_SDO_ACTIVE_SPI_4W 0x1
57
58#define ADF4382_ADDR_ASC_AUTO_DECR 0x0
59#define ADF4382_ADDR_ASC_AUTO_INCR 0x1
60
61#define ADF4382_LSB_FIRST_MSB 0x0
62#define ADF4382_LSB_FIRST_LSB 0x1
63
64#define ADF4382_SOFT_RESET_N_OP 0x0
65#define ADF4382_SOFT_RESET_EN 0x1
66
67/* ADF4382 REG0001 Map */
68#define ADF4382_SINGLE_INSTR_MSK NO_OS_BIT(7)
69#define ADF4382_MASTER_RB_CTRL_MSK NO_OS_BIT(5)
70
71/* ADF4382 REG0001 NO_OS_BIT Definition */
72#define ADF4382_SPI_STREAM_EN 0x0
73#define ADF4382_SPI_STREAM_DIS 0x1
74
75#define ADF4382_RB_SLAVE_REG 0x0
76#define ADF4382_RB_MASTER_REG 0x1
77
78/* ADF4382 REG0003 NO_OS_BIT Definition */
79#define ADF4382_CHIP_TYPE 0x06
80
81/* ADF4382 REG0004 NO_OS_BIT Definition */
82#define ADF4382_PRODUCT_ID_LSB 0x0005
83
84/* ADF4382 REG0005 NO_OS_BIT Definition */
85#define ADF4382_PRODUCT_ID_MSB 0x0005
86
87/* ADF4382 REG000A Map */
88#define ADF4382_SCRATCHPAD_MSK NO_OS_GENMASK(7, 0)
89
90/* ADF4382 REG000C NO_OS_BIT Definition */
91#define ADF4382_VENDOR_ID_LSB 0x56
92
93/* ADF4382 REG000D NO_OS_BIT Definition */
94#define ADF4382_VENDOR_ID_MSB 0x04
95
96/* ADF4382 REG000F NO_OS_BIT Definition */
97#define ADF4382_M_S_TRANSF_NO_OS_BIT_MSK NO_OS_BIT(0)
98
99/* ADF4382 REG0010 Map*/
100#define ADF4382_N_INT_LSB_MSK NO_OS_GENMASK(7, 0)
101
102/* ADF4382 REG0011 Map*/
103#define ADF4382_CLKOUT_DIV_MSK NO_OS_GENMASK(7, 5)
104#define ADF4382_INV_CLK_OUT_MSK NO_OS_BIT(4)
105#define ADF4382_N_INT_MSB_MSK NO_OS_GENMASK(3, 0)
106
107/* ADF4382 REG0012 Map */
108#define ADF4382_FRAC1WORD_LSB_MSK NO_OS_GENMASK(7, 0)
109
110/* ADF4382 REG0013 Map */
111#define ADF4382_FRAC1WORD_MID_MSK NO_OS_GENMASK(7, 0)
112
113/* ADF4382 REG0014 Map */
114#define ADF4382_FRAC1WORD_MSB_MSK NO_OS_GENMASK(7, 0)
115
116/* ADF4382 REG0015 Map */
117#define ADF4382_M_VCO_BAND_LSB_MSK NO_OS_BIT(7)
118#define ADF4382_M_VCO_CORE_MSK NO_OS_BIT(6)
119#define ADF4382_BIAS_DEC_MODE_MSK NO_OS_GENMASK(5, 3)
120#define ADF4382_INT_MODE_MSK NO_OS_BIT(2)
121#define ADF4382_PFD_POL_MSK NO_OS_BIT(1)
122#define ADF4382_FRAC1WORD_MSB NO_OS_BIT(0)
123
124/* ADF4382 REG0016 Map */
125#define ADF4382_M_VCO_BAND_MSB_MSK NO_OS_GENMASK(7, 0)
126
127/* ADF4382 REG0017 Map */
128#define ADF4382_FRAC2WORD_LSB_MSK NO_OS_GENMASK(7, 0)
129
130/* ADF4382 REG0018 Map */
131#define ADF4382_FRAC2WORD_MID_MSK NO_OS_GENMASK(7, 0)
132
133/* ADF4382 REG0019 Map */
134#define ADF4382_FRAC2WORD_MSB_MSK NO_OS_GENMASK(7, 0)
135
136/* ADF4382 REG001A Map */
137#define ADF4382_MOD2WORD_LSB_MSK NO_OS_GENMASK(7, 0)
138
139/* ADF4382 REG001B Map */
140#define ADF4382_MOD2WORD_MID_MSK NO_OS_GENMASK(7, 0)
141
142/* ADF4382 REG001C Map */
143#define ADF4382_MOD2WORD_MSB_MSK NO_OS_GENMASK(7, 0)
144
145/* ADF4382 REG001D Map */
146#define ADF4382_FINE_BLEED_LSB_MSK NO_OS_GENMASK(7, 0)
147
148/* ADF4382 REG001E Map */
149#define ADF4382_EN_PHASE_RESYNC_MSK NO_OS_BIT(7)
150#define ADF4382_EN_REF_RST_MSK NO_OS_BIT(6)
151#define ADF4382_TIMED_SYNC_MSK NO_OS_BIT(5)
152#define ADF4382_COARSE_BLEED_MSK NO_OS_GENMASK(4, 1)
153#define ADF4382_FINE_BLEED_MSB_MSK NO_OS_BIT(0)
154
155/* ADF4382 REG001F Map */
156#define ADF4382_SW_SYNC_MSK NO_OS_BIT(7)
157#define ADF4382_SPARE_1F_MSK NO_OS_BIT(6)
158#define ADF4382_BLEED_POL_MSK NO_OS_BIT(5)
159#define ADF4382_EN_BLEED_MSK NO_OS_BIT(4)
160#define ADF4382_CP_I_MSK NO_OS_GENMASK(3, 0)
161
162/* ADF4382 REG0020 Map */
163#define ADF4382_EN_AUTOCAL_MSK NO_OS_BIT(7)
164#define ADF4382_EN_RDBLR_MSK NO_OS_BIT(6)
165#define ADF4382_R_DIV_MSK NO_OS_GENMASK(5, 0)
166
167/* ADF4382 REG0021 Map */
168#define ADF4382_PHASE_WORD_LSB_MSK NO_OS_GENMASK(7, 0)
169
170/* ADF4382 REG0022 Map */
171#define ADF4382_PHASE_WORD_MID_MSK NO_OS_GENMASK(7, 0)
172
173/* ADF4382 REG0023 Map */
174#define ADF4382_PHASE_WORD_MSB_MSK NO_OS_GENMASK(7, 0)
175
176/* ADF4382 REG0024 Map */
177#define ADF4382_SPARE_24_MSK NO_OS_GENMASK(7, 5)
178#define ADF4382_DCLK_DIV_SEL_MSK NO_OS_BIT(4)
179#define ADF4382_DNCLK_DIV1_MSK NO_OS_GENMASK(3, 2)
180#define ADF4382_DCLK_DIV1_MSK NO_OS_GENMASK(1, 0)
181
182/* ADF4382 REG0025 Map */
183#define ADF4382_RESYNC_WAIT_LSB_MSK NO_OS_GENMASK(7, 0)
184
185/* ADF4382 REG0026 Map */
186#define ADF4382_RESYNC_WAIT_MSB_MSK NO_OS_GENMASK(7, 0)
187
188/* ADF4382 REG0027 Map */
189#define ADF4382_CAL_BLEED_FINE_MIN_MSK NO_OS_GENMASK(7, 4)
190#define ADF4382_BLEED_ADJ_SCALE_MSK NO_OS_GENMASK(3, 0)
191
192/* ADF4382 REG0028 Map */
193#define ADF4382_PH_RESYNC_RB_SEL_MSK NO_OS_BIT(7)
194#define ADF4382_LSB_P1_MSK NO_OS_BIT(6)
195#define ADF4382_VAR_MOD_EN_MSK NO_OS_BIT(5)
196#define ADF4382_DITHER1_SCALE_MSK NO_OS_GENMASK(4, 2)
197#define ADF4382_EN_DITHER2_MSK NO_OS_BIT(1)
198#define ADF4382_EN_DITHER1_MSK NO_OS_BIT(0)
199
200/* ADF4382 REG0029 Map */
201#define ADF4382_CLK2_OPWR_MSK NO_OS_GENMASK(7, 4)
202#define ADF4382_CLK1_OPWR_MSK NO_OS_GENMASK(3, 0)
203
204/* ADF4382 REG002A Map */
205#define ADF4382_FN_DBL_MSK NO_OS_BIT(7)
206#define ADF4382_PD_NDIV_TL_MSK NO_OS_BIT(6)
207#define ADF4382_CLKOUT_BST_MSK NO_OS_BIT(5)
208#define ADF4382_PD_SYNC_MSK NO_OS_BIT(4)
209#define ADF4382_PD_CLK_MSK NO_OS_BIT(3)
210#define ADF4382_PD_RDET_MSK NO_OS_BIT(2)
211#define ADF4382_PD_ADC_MSK NO_OS_BIT(1)
212#define ADF4382_PD_CALGEN_MSK NO_OS_BIT(0)
213
214/* ADF4382 REG002B Map */
215#define ADF4382_PD_ALL_MSK NO_OS_BIT(7)
216#define ADF4382_PD_RDIV_TL_MSK NO_OS_BIT(6)
217#define ADF4382_PD_NDIV_MSK NO_OS_BIT(5)
218#define ADF4382_PD_VCO_MSK NO_OS_BIT(4)
219#define ADF4382_PD_LD_MSK NO_OS_BIT(3)
220#define ADF4382_PD_PFDCP_MSK NO_OS_BIT(2)
221#define ADF4382_PD_CLKOUT1_MSK NO_OS_BIT(1)
222#define ADF4382_PD_CLKOUT2_MSK NO_OS_BIT(0)
223
224/* ADF4382 REG002C Map */
225#define ADF4382_LDWIN_PW_MSK NO_OS_GENMASK(7, 5)
226#define ADF4382_LD_COUNT_OPWR_MSK NO_OS_GENMASK(4, 0)
227
228/* ADF4382 REG002D Map */
229#define ADF4382_EN_DNCLK_MSK NO_OS_BIT(7)
230#define ADF4382_EN_DRCLK_MSK NO_OS_BIT(6)
231#define ADF4382_EN_LOL_MSK NO_OS_BIT(5)
232#define ADF4382_EN_LDWIN_MSK NO_OS_BIT(4)
233#define ADF4382_PDET_POL_MSK NO_OS_BIT(3)
234#define ADF4382_RST_LD_MSK NO_OS_BIT(2)
235#define ADF4382_LD_O_CTRL_MSK NO_OS_GENMASK(1, 0)
236
237/* ADF4382 REG002E Map */
238#define ADF4382_MUXOUT_MSK NO_OS_GENMASK(7, 4)
239#define ADF4382_ABPW_WD_MSK NO_OS_BIT(3)
240#define ADF4382_EN_CPTEST_MSK NO_OS_BIT(2)
241#define ADF4382_CP_DOWN_MSK NO_OS_BIT(1)
242#define ADF4382_CP_UP_MSK NO_OS_BIT(0)
243
244/* ADF4382 REG002F Map*/
245#define ADF4382_BST_REF_MSK NO_OS_BIT(7)
246#define ADF4382_FILT_REF_MSK NO_OS_BIT(6)
247#define ADF4382_RDBLR_DC_MSK NO_OS_GENMASK(5, 0)
248
249/* ADF4382 REG0030 Map */
250#define ADF4382_MUTE_NCLK_MSK NO_OS_BIT(7)
251#define ADF4382_MUTE_RCLK_MSK NO_OS_BIT(6)
252#define ADF4382_REF_SEL_MSK NO_OS_BIT(5)
253#define ADF4382_INV_RDBLR_MSK NO_OS_BIT(4)
254#define ADF4382_RDBLR_DEL_SEL_MSK NO_OS_GENMASK(3, 0)
255
256/* ADF4382 REG0031 Map */
257#define ADF4382_SYNC_DEL_MSK NO_OS_GENMASK(7, 5)
258#define ADF4382_RST_SYS_MSK NO_OS_BIT(4)
259#define ADF4382_EN_ADC_CLK_MSK NO_OS_BIT(3)
260#define ADF4382_EN_VCAL_MSK NO_OS_BIT(2)
261#define ADF4382_CAL_CT_SEL_MSK NO_OS_BIT(1)
262#define ADF4382_DCLK_MODE_MSK NO_OS_BIT(0)
263
264/* ADF4382 REG0032 Map */
265#define ADF4382_SPARE_32_MSK NO_OS_BIT(7)
266#define ADF4382_BLEED_ADJ_CAL_MSK NO_OS_BIT(6)
267#define ADF4382_DEL_MODE_MSK NO_OS_BIT(5)
268#define ADF4382_EN_AUTO_ALIGN_MSK NO_OS_BIT(4)
269#define ADF4382_PHASE_ADJ_POL_MSK NO_OS_BIT(3)
270#define ADF4382_EFM3_MODE_MSK NO_OS_GENMASK(2, 0)
271
272/* ADF4382 REG0033 Map */
273#define ADF4382_PHASE_ADJUST_MSK NO_OS_GENMASK(7, 0)
274
275/* ADF4382 REG0034 Map */
276#define ADF4382_PHASE_ADJ_MSK NO_OS_BIT(7)
277#define ADF4382_DRCLK_DEL_MSK NO_OS_GENMASK(6, 4)
278#define ADF4382_DNCLK_DEL_MSK NO_OS_GENMASK(3, 1)
279#define ADF4382_RST_CNTR_MSK NO_OS_BIT(0)
280
281/* ADF4382 REG0035 Map */
282#define ADF4382_SPARE_35_MSK NO_OS_GENMASK(7, 6)
283#define ADF4382_M_VCO_BIAS_MSK NO_OS_GENMASK(5, 0)
284
285/* ADF4382 REG0036 Map */
286#define ADF4382_CLKODIV_DB_MSK NO_OS_BIT(7)
287#define ADF4382_DCLK_DIV_DB_MSK NO_OS_BIT(6)
288#define ADF4382_SPARE_36_MSK NO_OS_GENMASK(5, 2)
289#define ADF4382_EN_LUT_GEN_MSK NO_OS_BIT(1)
290#define ADF4382_EN_LUT_CAL_MSK NO_OS_BIT(0)
291
292/* ADF4382 REG0037 Map */
293#define ADF4382_CAL_COUNT_TO_MSK NO_OS_GENMASK(7, 0)
294
295/* ADF4382 REG0038 Map */
296#define ADF4382_CAL_VTUNE_TO_LSB_MSK NO_OS_GENMASK(7, 0)
297
298/* ADF4382 REG0039 Map */
299#define ADF4382_O_VCO_DB_MSK NO_OS_BIT(7)
300#define ADF4382_CAL_VTUNE_TO_MSB_MSK NO_OS_GENMASK(6, 0)
301
302/* ADF4382 REG003A Map */
303#define ADF4382_CAL_VCO_TO_LSB_MSK NO_OS_GENMASK(7, 0)
304
305/* ADF4382 REG003B Map */
306#define ADF4382_DEL_CTRL_DB_MSK NO_OS_BIT(7)
307#define ADF4382_CAL_VCO_TO_MSB_MSK NO_OS_GENMASK(6, 0)
308
309/* ADF4382 REG003C Map */
310#define ADF4382_CNTR_DIV_WORD_MSK NO_OS_GENMASK(7, 0)
311
312/* ADF4382 REG003D Map */
313#define ADF4382_SPARE_3D_MSK NO_OS_BIT(7)
314#define ADF4382_SYNC_SP_DB_MSK NO_OS_BIT(6)
315#define ADF4382_CMOS_OV_MSK NO_OS_BIT(5)
316#define ADF4382_READ_MODE_MSK NO_OS_BIT(4)
317#define ADF4382_CNTR_DIV_WORD_MSB_MSK NO_OS_GENMASK(3, 0)
318
319/* ADF4382 REG003E Map */
320#define ADF4382_ADC_CLK_DIV_MSK NO_OS_GENMASK(7, 0)
321
322/* ADF4382 REG003F Map */
323#define ADF4382_EN_ADC_CNV_MSK NO_OS_BIT(7)
324#define ADF4382_EN_ADC_VTEST_MSK NO_OS_BIT(6)
325#define ADF4382_ADC_VTEST_SEL_MSK NO_OS_BIT(5)
326#define ADF4382_ADC_MUX_SEL_MSK NO_OS_BIT(4)
327#define ADF4382_ADC_F_CONV_MSK NO_OS_BIT(3)
328#define ADF4382_ADC_C_CONV_MSK NO_OS_BIT(2)
329#define ADF4382_EN_ADC_MSK NO_OS_BIT(1)
330#define ADF4382_SPARE_3F_MSK NO_OS_BIT(0)
331
332/* ADF4382 REG0040 Map */
333#define ADF4382_EXT_DIV_DEC_SEL_MSK NO_OS_BIT(7)
334#define ADF4382_ADC_CLK_TEST_SEL_MSK NO_OS_BIT(6)
335#define ADF4382_MUTE_CLKOUT2_MSK NO_OS_GENMASK(5, 3)
336#define ADF4382_MUTE_CLKOUT1_MSK NO_OS_GENMASK(2, 0)
337
338/* ADF4382 REG0041 Map */
339#define ADF4382_EXT_DIV_MSK NO_OS_GENMASK(7, 5)
340#define ADF4382_EN_VCO_CAP_TEST_MSK NO_OS_BIT(4)
341#define ADF4382_EN_CALGEN_CAP_TEST_MSK NO_OS_BIT(3)
342#define ADF4382_EN_CP_CAP_TEST_MSK NO_OS_BIT(2)
343#define ADF4382_CAP_TEST_STATE_MSK NO_OS_BIT(1)
344#define ADF4382_TRANS_LOOP_SEL_MSK NO_OS_BIT(0)
345
346/* ADF4382 REG0042 Map */
347#define ADF4382_NDIV_PWRUP_TIMEOUT_MSK NO_OS_GENMASK(7, 0)
348
349/* ADF4382 REG0043 Map */
350#define ADF4382_CAL_BLEED_FINE_MAX_MSK NO_OS_GENMASK(7, 0)
351
352/* ADF4382 REG0044 Map */
353#define ADF4382_VCAL_ZERO_MSK NO_OS_BIT(7)
354#define ADF4382_VPTAT_CALGEN_MSK NO_OS_GENMASK(6, 0)
355
356/* ADF4382 REG0045 Map */
357#define ADF4382_SPARE_45_MSK NO_OS_BIT(7)
358#define ADF4382_VCTAT_CALGEN_MSK NO_OS_GENMASK(6, 0)
359
360/* ADF4382 REG0046 Map */
361#define ADF4382_NVMDIN_MSK NO_OS_GENMASK(7, 0)
362
363/* ADF4382 REG0047 Map */
364#define ADF4382_SPARE_47_MSK NO_OS_BIT(7)
365#define ADF4382_NVMADDR_MSK NO_OS_GENMASK(6, 3)
366#define ADF4382_NVMNO_OS_BIT_SEL NO_OS_GENMASK(2, 0)
367
368/* ADF4382 REG0048 Map */
369#define ADF4382_TRIM_LATCH_MSK NO_OS_BIT(7)
370#define ADF4382_NVMTEST_MSK NO_OS_BIT(6)
371#define ADF4382_NVMPROG_MSK NO_OS_BIT(5)
372#define ADF4382_NVMRD_MSK NO_OS_BIT(4)
373#define ADF4382_NVMSTART_MSK NO_OS_BIT(3)
374#define ADF4382_NVMON_MSK NO_OS_BIT(2)
375#define ADF4382_MARGIN_MSK NO_OS_GENMASK(1, 0)
376
377/* ADF4382 REG0049 Map */
378#define ADF4382_NVMDOUT_MSK NO_OS_GENMASK(7, 0)
379
380/* ADF4382 REG004A Map */
381#define ADF4382_SCAN_MODE_CODE_MSK NO_OS_GENMASK(7, 0)
382
383/* ADF4382 REG004B Map */
384#define ADF4382_TEMP_OFFSET_MSK NO_OS_GENMASK(7, 0)
385
386/* ADF4382 REG004C Map */
387#define ADF4382_SPARE_4C_MSK NO_OS_GENMASK(7, 6)
388#define ADF4382_TEMP_SLOPE_MSK NO_OS_GENMASK(5, 0)
389
390/* ADF4382 REG004D Map */
391#define ADF4382_VCO_FSM_TEST_MUX_MSK NO_OS_GENMASK(7, 5)
392#define ADF4382_SPARE_4D_MSK NO_OS_GENMASK(4, 3)
393#define ADF4382_O_VCO_BIAS_MSK NO_OS_BIT(2)
394#define ADF4382_O_VCO_BAND_MSK NO_OS_BIT(1)
395#define ADF4382_O_VCO_CORE_MSK NO_OS_BIT(0)
396
397/* ADF4382 REG004E Map */
398#define ADF4382_SPARE_4E_MSK NO_OS_GENMASK(7, 5)
399#define ADF4382_EN_TWO_PASS_CAL_MSK NO_OS_BIT(4)
400#define ADF4382_TWO_PASS_BAND_START_MSK NO_OS_GENMASK(3, 0)
401
402/* ADF4382 REG004F Map */
403#define ADF4382_LUT_SCALE_MSK NO_OS_GENMASK(7, 0)
404
405/* ADF4382 REG0050 Map */
406#define ADF4382_SPARE0_MSK NO_OS_GENMASK(7, 0)
407
408/* ADF4382 REG0051 Map */
409#define ADF4382_SPARE1_MSK NO_OS_GENMASK(7, 0)
410
411/* ADF4382 REG0052 Map */
412#define ADF4382_SYNC_REF_SPARE_MSK NO_OS_GENMASK(7, 4)
413#define ADF4382_SYNC_MON_DEL_MSK NO_OS_GENMASK(3, 0)
414
415/* ADF4382 REG0053 Map */
416#define ADF4382_SPARE_53_MSK NO_OS_BIT(7)
417#define ADF4382_PD_SYNC_MON_MSK NO_OS_BIT(6)
418#define ADF4382_SYNC_SEL_MSK NO_OS_BIT(5)
419#define ADF4382_RST_SYNC_MON_MSK NO_OS_BIT(4)
420#define ADF4382_SYNC_SH_DEL_MSK NO_OS_GENMASK(3, 0)
421
422/* ADF4382 REG0054 Map */
423#define ADF4382_ADC_ST_CNV_MSK NO_OS_BIT(0)
424
425/* ADF4382 REG0058 Map */
426#define ADF4382_FSM_BUSY_MSK NO_OS_BIT(1)
427#define ADF4382_LOCKED_MSK NO_OS_BIT(0)
428
429/* ADF4382 REG005E Map */
430#define ADF4382_VCO_BAND_LSB_MSK NO_OS_GENMASK(7, 0)
431
432/* ADF4382 REG005F Map */
433#define ADF4382_VCO_CORE_MSK NO_OS_BIT(1)
434#define ADF4382_VCO_BAND_MSB_MSK NO_OS_BIT(0)
435
436/* ADF4382 REG0200 Map */
437#define ADF4382_LUT_WR_ADDR_MSK NO_OS_GENMASK(5, 1)
438#define ADF4382_O_VCO_LUT_MSK NO_OS_BIT(0)
439
440/* ADF4382 REG0201 Map */
441#define ADF4382_M_LUT_BAND_LSB_MSK NO_OS_GENMASK(7, 0)
442
443/* ADF4382 REG0202 Map */
444#define ADF4382_M_LUT_N_LSB_MSK NO_OS_GENMASK(7, 2)
445#define ADF4382_M_LUT_CORE_MSK NO_OS_BIT(1)
446#define ADF4382_M_LUT_BAND_MSB_MSK NO_OS_BIT(0)
447
448/* ADF4382 REG0203 Map */
449#define ADF4382_M_LUT_N_MSB_MSK NO_OS_GENMASK(5, 0)
450
451#define ADF4382_SPI_3W_CFG(x) (no_os_field_prep(ADF4382_SDO_ACTIVE_MSK, x) | \
452 no_os_field_prep(ADF4382_SDO_ACTIVE_R_MSK, x))
453
454#define ADF4382_BLEED_MSB_MSK (ADF4382_COARSE_BLEED_MSK | \
455 ADF4382_FINE_BLEED_MSB_MSK)
456
457#define ADF4382_SPI_SCRATCHPAD_TEST 0x5A
458
459/* Specifications */
460#define ADF4382_SPI_WRITE_CMD 0x0
461#define ADF4382_SPI_READ_CMD 0x8000
462#define ADF4382_SPI_DUMMY_DATA 0x00
463#define ADF4382_BUFF_SIZE_BYTES 3
464#define ADF4382_VCO_FREQ_MIN 11000000000U // 11GHz
465#define ADF4382_VCO_FREQ_MAX 22000000000U // 22GHz
466#define ADF4383_VCO_FREQ_MIN 10000000000U // 10GHz
467#define ADF4383_VCO_FREQ_MAX 20000000000U // 20GHz
468#define ADF4382A_VCO_FREQ_MIN 11500000000U // 11.5GHz
469#define ADF4382A_VCO_FREQ_MAX 21000000000U // 21GHz
470#define ADF4382_MOD1WORD 0x2000000U // 2^25
471#define ADF4382_MOD2WORD_MAX 0xFFFFFFU // 2^24 - 1
472#define ADF4382_PHASE_RESYNC_MOD2WORD_MAX 0x1FFFFU // 2^17 - 1
473#define ADF4382_CHANNEL_SPACING_MAX 78125U
474#define ADF4382_PFD_FREQ_MAX 625000000U // 625MHz
475#define ADF4382_PFD_FREQ_FRAC_MAX 250000000U // 250MHz
476#define ADF4382_PFD_FREQ_MIN 5400000U // 5.4MHz
477#define ADF4382_DCLK_DIV1_0_MAX 160000000U // 160MHz
478#define ADF4382_DCLK_DIV1_1_MAX 320000000U // 320MHz
479#define ADF4382_CLKOUT_DIV_REG_VAL_MAX 4
480#define ADF4382A_CLKOUT_DIV_REG_VAL_MAX 2
481
482#define ADF4383_RFOUT_MAX 20000000000U
483#define ADF4383_RFOUT_MIN 625000000U
484#define ADF4382_RFOUT_MAX 22000000000U
485#define ADF4382_RFOUT_MIN 687500000U
486#define ADF4382A_RFOUT_MAX 21000000000U
487#define ADF4382A_RFOUT_MIN 2875000000U
488#define ADF4382_REF_CLK_MAX 5000000000U
489#define ADF4382_REF_CLK_MIN 10000000
490#define ADF4382_REF_DIV_MAX 63
491#define ADF4382_OUT_PWR_MAX 15
492#define ADF4382_CPI_VAL_MAX 15
493#define ADF4382_BLEED_WORD_MAX 8191
494
495#define ADF4382_VPTAT_CALGEN 46
496#define ADF4382_VCTAT_CALGEN 82
497#define ADF4382_FASTCAL_VPTAT_CALGEN 7
498#define ADF4382_FASTCAL_VCTAT_CALGEN 21
499#define ADF4382_PHASE_BLEED_CNST 2044000
500#define ADF4382_VCO_CAL_CNT 183
501#define ADF4382_VCO_CAL_VTUNE 640
502#define ADF4382_VCO_CAL_ALC 123
503#define ADF4382_POR_DELAY_US 200
504#define ADF4382_LKD_DELAY_US 1000
505#define ADF4382_COARSE_BLEED_CONST 180U // 180 microseconds
506#define ADF4382_FINE_BLEED_CONST_1 512U // 512 microseconds
507#define ADF4382_FINE_BLEED_CONST_2 250U // 250 microseconds
508#define ADF4382_CAL_VTUNE_TO 124U
509#define ADF4382_FSM_BUSY_LOOP_CNT 100U
510
511#define MHZ MEGA
512#define S_TO_NS NANO
513#define PS_TO_S PICO
514#define NS_TO_PS KHZ_PER_MHZ
515
524
546
556 uint64_t ref_freq_hz;
557 uint64_t freq;
559 uint8_t ref_div;
560 uint8_t cp_i;
561 uint16_t bleed_word;
562 uint8_t ld_count;
563 uint32_t phase_adj;
564 uint8_t en_lut_gen;
565 uint8_t en_lut_cal;
566 uint64_t vco_max;
567 uint64_t vco_min;
568 uint64_t freq_max;
569 uint64_t freq_min;
572 uint32_t cal_vtune_to;
573 // N_INT variable to trigger auto calibration
574 uint16_t n_int;
575};
576
581struct reg_sequence {
582 uint16_t reg;
583 uint8_t val;
584};
585
590static const struct reg_sequence adf4382_reg_defaults[] = {
591 { 0x000, 0x18 },
592 { 0x00a, 0xA5 },
593 { 0x200, 0x00 },
594 { 0x201, 0x00 },
595 { 0x202, 0x00 },
596 { 0x203, 0x00 },
597 { 0x203, 0x00 },
598 { 0x203, 0x00 },
599 { 0x100, 0x25 },
600 { 0x101, 0x3F },
601 { 0x102, 0x3F },
602 { 0x103, 0x3F },
603 { 0x104, 0x3F },
604 { 0x105, 0x3F },
605 { 0x106, 0x3F },
606 { 0x107, 0x3F },
607 { 0x108, 0x3F },
608 { 0x109, 0x25 },
609 { 0x10A, 0x25 },
610 { 0x10B, 0x3F },
611 { 0x10C, 0x3F },
612 { 0x10D, 0x3F },
613 { 0x10E, 0x3F },
614 { 0x10F, 0x3F },
615 { 0x110, 0x3F },
616 { 0x111, 0x3F },
617 { 0x054, 0x00 },
618 { 0x053, 0x45 },
619 { 0x052, 0x00 },
620 { 0x051, 0x00 },
621 { 0x050, 0x00 },
622 { 0x04f, 0x08 },
623 { 0x04e, 0x06 },
624 { 0x04d, 0x00 },
625 { 0x04c, 0x2B },
626 { 0x04b, 0x5D },
627 { 0x04a, 0x00 },
628 { 0x048, 0x00 },
629 { 0x047, 0x00 },
630 { 0x046, 0x00 },
631 { 0x045, 0x52 },
632 { 0x044, 0x2E },
633 { 0x043, 0xB8 },
634 { 0x042, 0x01 },
635 { 0x041, 0x00 },
636 { 0x040, 0x00 },
637 { 0x03f, 0x82 },
638 { 0x03e, 0x4E },
639 { 0x03d, 0x00 },
640 { 0x03c, 0x00 },
641 { 0x03b, 0x00 },
642 { 0x03a, 0xFA },
643 { 0x039, 0x00 },
644 { 0x038, 0x7C },
645 { 0x037, 0xCA },
646 { 0x036, 0xC0 },
647 { 0x035, 0x00 },
648 { 0x034, 0x36 },
649 { 0x033, 0x00 },
650 { 0x032, 0x40 },
651 { 0x031, 0x63 },
652 { 0x030, 0x0F },
653 { 0x02f, 0x3F },
654 { 0x02e, 0x00 },
655 { 0x02d, 0xF1 },
656 { 0x02c, 0x0E },
657 { 0x02b, 0x01 },
658 { 0x02a, 0x30 },
659 { 0x029, 0x09 },
660 { 0x028, 0x00 },
661 { 0x027, 0xF0 },
662 { 0x026, 0x00 },
663 { 0x025, 0x01 },
664 { 0x024, 0x01 },
665 { 0x023, 0x00 },
666 { 0x022, 0x00 },
667 { 0x021, 0x00 },
668 { 0x020, 0xC1 },
669 { 0x01f, 0x0F },
670 { 0x01e, 0x20 },
671 { 0x01d, 0x00 },
672 { 0x01c, 0x00 },
673 { 0x01b, 0x00 },
674 { 0x01a, 0x00 },
675 { 0x019, 0x00 },
676 { 0x018, 0x00 },
677 { 0x017, 0x00 },
678 { 0x016, 0x00 },
679 { 0x015, 0x06 },
680 { 0x014, 0x00 },
681 { 0x013, 0x00 },
682 { 0x012, 0x00 },
683 { 0x011, 0x00 },
684 { 0x010, 0x50 },
685};
686
688int adf4382_spi_write(struct adf4382_dev *dev, uint16_t reg_addr, uint8_t data);
689
691int adf4382_spi_read(struct adf4382_dev *dev, uint16_t reg_addr, uint8_t *data);
692
694int adf4382_spi_update_bits(struct adf4382_dev *dev, uint16_t reg_addr,
695 uint8_t mask, uint8_t data);
696
698int adf4382_reg_dump(struct adf4382_dev *dev);
699
701int adf4382_set_ref_clk(struct adf4382_dev *dev, uint64_t val);
702
704int adf4382_get_ref_clk(struct adf4382_dev *dev, uint64_t *val);
705
707int adf4382_set_en_ref_doubler(struct adf4382_dev *dev, bool en);
708
710int adf4382_get_en_ref_doubler(struct adf4382_dev *dev, bool *en);
711
713int adf4382_set_ref_div(struct adf4382_dev *dev, int32_t div);
714
716int adf4382_get_ref_div(struct adf4382_dev *dev, int32_t *div);
717
719int adf4382_set_cp_i(struct adf4382_dev *dev, int32_t reg_val);
720
722int adf4382_get_cp_i(struct adf4382_dev *dev, int32_t *reg_val);
723
725int adf4382_set_bleed_word(struct adf4382_dev *dev, int32_t word);
726
728int adf4382_get_bleed_word(struct adf4382_dev *dev, int32_t *word);
729
731int adf4382_set_rfout(struct adf4382_dev *dev, uint64_t val);
732
734int adf4382_get_rfout(struct adf4382_dev *dev, uint64_t *val);
735
737int adf4382_set_out_power(struct adf4382_dev *dev, uint8_t ch, int32_t pwr);
738
740int adf4382_get_out_power(struct adf4382_dev *dev, uint8_t ch, int32_t *pwr);
741
743int adf4382_set_en_chan(struct adf4382_dev *dev, uint8_t ch, bool en);
744
746int adf4382_get_en_chan(struct adf4382_dev *dev, uint8_t ch, bool *en);
747
749int adf4382_set_freq(struct adf4382_dev *dev);
750
752int adf4382_set_en_fast_calibration(struct adf4382_dev *dev, bool en_fast_cal);
753
755int adf4382_set_en_lut_calibration(struct adf4382_dev *dev, bool en_lut_cal);
756
758int adf4382_get_en_lut_calibration(struct adf4382_dev *dev, bool *en);
759
761int adf4382_set_change_freq(struct adf4382_dev *dev);
762
764int adf4382_get_change_rfout(struct adf4382_dev *dev, uint64_t *val);
765
767int adf4382_set_change_rfout(struct adf4382_dev *dev, uint64_t val);
768
771
773int adf4382_get_start_calibration(struct adf4382_dev *dev, bool *start_cal);
774
776int adf4382_set_phase_adjust(struct adf4382_dev *dev, uint32_t phase_ps);
777
779int adf4382_set_phase_pol(struct adf4382_dev *dev, bool polarity);
780
782int adf4382_get_phase_pol(struct adf4382_dev *dev, bool *polarity);
783
785int adf4382_set_ezsync_setup(struct adf4382_dev *dev, bool sync);
786
788int adf4382_set_timed_sync_setup(struct adf4382_dev *dev, bool sync);
789
791int adf4382_get_phase_sync_setup(struct adf4382_dev *dev, bool *en);
792
794int adf4382_set_sw_sync(struct adf4382_dev *dev, bool sw_sync);
795
797int adf4382_get_sw_sync(struct adf4382_dev *dev, bool *sw_sync);
798
801
803int adf4382_init(struct adf4382_dev **device,
805
807int adf4382_remove(struct adf4382_dev *dev);
808
809#endif
struct ad7616_init_param init_param
Definition ad7616_sdz.c:107
int adf4382_get_en_chan(struct adf4382_dev *dev, uint8_t ch, bool *en)
Gets the value the output channel if it is enabled or disable.
Definition adf4382.c:505
int adf4382_get_en_ref_doubler(struct adf4382_dev *dev, bool *en)
Gets the value the doubler if it is enabled or disable and stores it it the dev structure.
Definition adf4382.c:270
int adf4382_spi_read(struct adf4382_dev *dev, uint16_t reg_addr, uint8_t *data)
Reads data from ADF4382 over SPI.
Definition adf4382.c:99
int adf4382_set_sw_sync(struct adf4382_dev *dev, bool sw_sync)
Set Software SYNC Request. Setting SW_SYNC resets the RF block. Clearing SW_SYNC makes ready for a ne...
Definition adf4382.c:1842
int adf4382_set_en_lut_calibration(struct adf4382_dev *dev, bool en_lut_cal)
Sets Fast calibration LUT Calibration. Refer to en_fastcal function to first generate fastcal Lookup ...
Definition adf4382.c:1000
int adf4382_set_en_fast_calibration(struct adf4382_dev *dev, bool en_fast_cal)
Fast calibration function. Computes Minimum VCO frequency (fmin), uses the minimum NDIV value to gene...
Definition adf4382.c:774
int adf4382_get_ref_div(struct adf4382_dev *dev, int32_t *div)
Gets the value the reference divider.
Definition adf4382.c:316
int adf4382_set_freq(struct adf4382_dev *dev)
Set the output frequency.
Definition adf4382.c:1343
int adf4382_set_en_ref_doubler(struct adf4382_dev *dev, bool en)
Set the reference doubler to enable or disable based on the passed parameter. If the parameter is dif...
Definition adf4382.c:248
int adf4382_set_ezsync_setup(struct adf4382_dev *dev, bool sync)
Set the EZSYNC features' initial state. Awaits the SW_SYNC toggle.
Definition adf4382.c:1707
int adf4382_get_en_lut_calibration(struct adf4382_dev *dev, bool *en)
Gets Fast calibration LUT Calibration status.
Definition adf4382.c:980
int adf4382_set_timed_sync_setup(struct adf4382_dev *dev, bool sync)
Set Timed SYNC features' initial state. Uses SYNC pin.
Definition adf4382.c:1750
int adf4382_set_rfout(struct adf4382_dev *dev, uint64_t val)
Set the desired output frequency and reset everything over to maximum supported value of 22GHz (21GHz...
Definition adf4382.c:534
int adf4382_spi_update_bits(struct adf4382_dev *dev, uint16_t reg_addr, uint8_t mask, uint8_t data)
Updates the values of the ADF4382 register.
Definition adf4382.c:137
int adf4382_set_change_rfout(struct adf4382_dev *dev, uint64_t val)
Set the desired output frequency and reset everything over to maximum supported value of 22GHz (21GHz...
Definition adf4382.c:1083
int adf4382_set_en_chan(struct adf4382_dev *dev, uint8_t ch, bool en)
Set the output channel to enable or disable based on the passed parameter. If the parameter is differ...
Definition adf4382.c:482
int adf4382_get_cp_i(struct adf4382_dev *dev, int32_t *reg_val)
Gets the charge pump value from the register. The value will be between 0 and 15 on 8 bits....
Definition adf4382.c:360
adf4382_dev_id
Supported device ids.
Definition adf4382.h:519
@ ID_ADF4383
Definition adf4382.h:522
@ ID_ADF4382A
Definition adf4382.h:521
@ ID_ADF4382
Definition adf4382.h:520
int adf4382_set_bleed_word(struct adf4382_dev *dev, int32_t word)
Set the bleed word, which represents the value of the bleed current written to the register space.
Definition adf4382.c:382
int adf4382_set_cp_i(struct adf4382_dev *dev, int32_t reg_val)
Set the charge pump value which will be written to the register. The value will be between 0 and 15 o...
Definition adf4382.c:339
int adf4382_get_out_power(struct adf4382_dev *dev, uint8_t ch, int32_t *pwr)
Gets the output power register value.
Definition adf4382.c:455
int adf4382_get_rfout(struct adf4382_dev *dev, uint64_t *val)
Gets the user proposed output frequency.
Definition adf4382.c:572
int adf4382_spi_write(struct adf4382_dev *dev, uint16_t reg_addr, uint8_t data)
Writes data to ADF4382 over SPI.
Definition adf4382.c:69
int adf4382_get_change_rfout(struct adf4382_dev *dev, uint64_t *val)
Gets the user proposed output frequency from the device tree without reading from the device....
Definition adf4382.c:1068
int adf4382_init(struct adf4382_dev **device, struct adf4382_init_param *init_param)
Initializes the ADF4382.
Definition adf4382.c:1989
int adf4382_get_phase_sync_setup(struct adf4382_dev *dev, bool *en)
Gets the value of the SYNC powerdown bit.
Definition adf4382.c:1822
int adf4382_set_change_freq(struct adf4382_dev *dev)
Set the output frequency. This will set the required registers to device but skip NDIV value,...
Definition adf4382.c:1148
int adf4382_get_sw_sync(struct adf4382_dev *dev, bool *sw_sync)
Gets the value of the SW_SYNC bit.
Definition adf4382.c:1859
int adf4382_set_out_power(struct adf4382_dev *dev, uint8_t ch, int32_t pwr)
Set the output power register value of a channel and reset everything over to maximum supported value...
Definition adf4382.c:431
int adf4382_get_phase_pol(struct adf4382_dev *dev, bool *polarity)
Gets the polarity of the phase adjust.
Definition adf4382.c:1688
int adf4382_set_phase_adjust(struct adf4382_dev *dev, uint32_t phase_ps)
Set the phase adjustment in pico-seconds. The phase adjust will enable the Bleed current option as we...
Definition adf4382.c:1604
int adf4382_set_vco_cal_timeout(struct adf4382_dev *dev)
Computes and sets the VCO Calibration Timeout values.
Definition adf4382.c:1880
int adf4382_get_start_calibration(struct adf4382_dev *dev, bool *start_cal)
Get the status of start calibration. Will always return zero to allow users set it multiple times to ...
Definition adf4382.c:1320
int adf4382_set_ref_clk(struct adf4382_dev *dev, uint64_t val)
Set the desired reference frequency and reset everything over to maximum supported value of 5GHz to t...
Definition adf4382.c:203
int adf4382_remove(struct adf4382_dev *dev)
Free resources allocated for ADF4382.
Definition adf4382.c:2110
int adf4382_get_ref_clk(struct adf4382_dev *dev, uint64_t *val)
Gets the user proposed reference frequency.
Definition adf4382.c:230
int adf4382_set_phase_pol(struct adf4382_dev *dev, bool polarity)
Set the phase polarity. If pol = 0 then it will add the phase value otherwise it will subtract the ph...
Definition adf4382.c:1672
int adf4382_get_bleed_word(struct adf4382_dev *dev, int32_t *word)
Gets the value of the set bleed word.
Definition adf4382.c:401
int adf4382_reg_dump(struct adf4382_dev *dev)
Will output on the terminal the values of all the ADF4382 registers.
Definition adf4382.c:161
int adf4382_set_start_calibration(struct adf4382_dev *dev)
Set REG0010 value in device structure to the device to start autocal.
Definition adf4382.c:1331
int adf4382_set_ref_div(struct adf4382_dev *dev, int32_t div)
Set the reference divider value and reset everything over to maximum supported value of 63 to the max...
Definition adf4382.c:292
Header file of SPI Interface.
Header file of Units.
Header file of utility functions.
ADF4382 Device Descriptor.
Definition adf4382.h:551
uint8_t en_lut_cal
Definition adf4382.h:565
struct no_os_spi_desc * spi_desc
Definition adf4382.h:553
uint8_t en_lut_gen
Definition adf4382.h:564
bool ref_doubler_en
Definition adf4382.h:558
uint8_t cp_i
Definition adf4382.h:560
uint64_t vco_min
Definition adf4382.h:567
uint32_t phase_adj
Definition adf4382.h:563
uint16_t n_int
Definition adf4382.h:574
uint8_t ref_div
Definition adf4382.h:559
uint32_t cal_vtune_to
Definition adf4382.h:572
uint8_t clkout_div_reg_val_max
Definition adf4382.h:570
uint64_t vco_max
Definition adf4382.h:566
uint16_t bleed_word
Definition adf4382.h:561
uint8_t ld_count
Definition adf4382.h:562
uint8_t max_lpf_cap_value_uf
Definition adf4382.h:571
uint64_t ref_freq_hz
Definition adf4382.h:556
uint64_t freq_max
Definition adf4382.h:568
bool spi_3wire_en
Definition adf4382.h:554
bool cmos_3v3
Definition adf4382.h:555
uint64_t freq_min
Definition adf4382.h:569
uint64_t freq
Definition adf4382.h:557
ADF4382 Initialization Parameters structure.
Definition adf4382.h:529
uint16_t bleed_word
Definition adf4382.h:539
uint8_t max_lpf_cap_value_uf
Definition adf4382.h:543
bool ref_doubler_en
Definition adf4382.h:536
struct no_os_spi_init_param * spi_init
Definition adf4382.h:531
bool spi_3wire_en
Definition adf4382.h:532
uint8_t cp_i
Definition adf4382.h:538
uint8_t ld_count
Definition adf4382.h:540
enum adf4382_dev_id id
Definition adf4382.h:544
bool cmos_3v3
Definition adf4382.h:533
uint64_t ref_freq_hz
Definition adf4382.h:534
uint8_t ref_div
Definition adf4382.h:537
uint8_t en_lut_cal
Definition adf4382.h:542
uint8_t en_lut_gen
Definition adf4382.h:541
uint64_t freq
Definition adf4382.h:535
ADF4382 register initialization.
Definition ad9361_util.h:63
Structure holding SPI descriptor.
Definition no_os_spi.h:180
Structure holding the parameters for SPI initialization.
Definition no_os_spi.h:128
ADF4382 register format structure for default values.
Definition adf4371.c:180
uint8_t val
Definition adf4371.c:182
uint16_t reg
Definition adf4371.c:181