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
55#define ADF4382_SDO_ACTIVE_SPI_3W 0x0
56#define ADF4382_SDO_ACTIVE_SPI_4W 0x1
58#define ADF4382_ADDR_ASC_AUTO_DECR 0x0
59#define ADF4382_ADDR_ASC_AUTO_INCR 0x1
61#define ADF4382_LSB_FIRST_MSB 0x0
62#define ADF4382_LSB_FIRST_LSB 0x1
64#define ADF4382_SOFT_RESET_N_OP 0x0
65#define ADF4382_SOFT_RESET_EN 0x1
68#define ADF4382_SINGLE_INSTR_MSK NO_OS_BIT(7)
69#define ADF4382_MASTER_RB_CTRL_MSK NO_OS_BIT(5)
72#define ADF4382_SPI_STREAM_EN 0x0
73#define ADF4382_SPI_STREAM_DIS 0x1
75#define ADF4382_RB_SLAVE_REG 0x0
76#define ADF4382_RB_MASTER_REG 0x1
79#define ADF4382_CHIP_TYPE 0x06
82#define ADF4382_PRODUCT_ID_LSB 0x0005
85#define ADF4382_PRODUCT_ID_MSB 0x0005
88#define ADF4382_SCRATCHPAD_MSK NO_OS_GENMASK(7, 0)
91#define ADF4382_VENDOR_ID_LSB 0x56
94#define ADF4382_VENDOR_ID_MSB 0x04
97#define ADF4382_M_S_TRANSF_NO_OS_BIT_MSK NO_OS_BIT(0)
100#define ADF4382_N_INT_LSB_MSK NO_OS_GENMASK(7, 0)
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)
108#define ADF4382_FRAC1WORD_LSB_MSK NO_OS_GENMASK(7, 0)
111#define ADF4382_FRAC1WORD_MID_MSK NO_OS_GENMASK(7, 0)
114#define ADF4382_FRAC1WORD_MSB_MSK NO_OS_GENMASK(7, 0)
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)
125#define ADF4382_M_VCO_BAND_MSB_MSK NO_OS_GENMASK(7, 0)
128#define ADF4382_FRAC2WORD_LSB_MSK NO_OS_GENMASK(7, 0)
131#define ADF4382_FRAC2WORD_MID_MSK NO_OS_GENMASK(7, 0)
134#define ADF4382_FRAC2WORD_MSB_MSK NO_OS_GENMASK(7, 0)
137#define ADF4382_MOD2WORD_LSB_MSK NO_OS_GENMASK(7, 0)
140#define ADF4382_MOD2WORD_MID_MSK NO_OS_GENMASK(7, 0)
143#define ADF4382_MOD2WORD_MSB_MSK NO_OS_GENMASK(7, 0)
146#define ADF4382_FINE_BLEED_LSB_MSK NO_OS_GENMASK(7, 0)
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)
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)
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)
168#define ADF4382_PHASE_WORD_LSB_MSK NO_OS_GENMASK(7, 0)
171#define ADF4382_PHASE_WORD_MID_MSK NO_OS_GENMASK(7, 0)
174#define ADF4382_PHASE_WORD_MSB_MSK NO_OS_GENMASK(7, 0)
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)
183#define ADF4382_RESYNC_WAIT_LSB_MSK NO_OS_GENMASK(7, 0)
186#define ADF4382_RESYNC_WAIT_MSB_MSK NO_OS_GENMASK(7, 0)
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)
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)
201#define ADF4382_CLK2_OPWR_MSK NO_OS_GENMASK(7, 4)
202#define ADF4382_CLK1_OPWR_MSK NO_OS_GENMASK(3, 0)
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)
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)
225#define ADF4382_LDWIN_PW_MSK NO_OS_GENMASK(7, 5)
226#define ADF4382_LD_COUNT_OPWR_MSK NO_OS_GENMASK(4, 0)
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)
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)
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)
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)
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)
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)
273#define ADF4382_PHASE_ADJUST_MSK NO_OS_GENMASK(7, 0)
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)
282#define ADF4382_SPARE_35_MSK NO_OS_GENMASK(7, 6)
283#define ADF4382_M_VCO_BIAS_MSK NO_OS_GENMASK(5, 0)
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)
293#define ADF4382_CAL_COUNT_TO_MSK NO_OS_GENMASK(7, 0)
296#define ADF4382_CAL_VTUNE_TO_LSB_MSK NO_OS_GENMASK(7, 0)
299#define ADF4382_O_VCO_DB_MSK NO_OS_BIT(7)
300#define ADF4382_CAL_VTUNE_TO_MSB_MSK NO_OS_GENMASK(6, 0)
303#define ADF4382_CAL_VCO_TO_LSB_MSK NO_OS_GENMASK(7, 0)
306#define ADF4382_DEL_CTRL_DB_MSK NO_OS_BIT(7)
307#define ADF4382_CAL_VCO_TO_MSB_MSK NO_OS_GENMASK(6, 0)
310#define ADF4382_CNTR_DIV_WORD_MSK NO_OS_GENMASK(7, 0)
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)
320#define ADF4382_ADC_CLK_DIV_MSK NO_OS_GENMASK(7, 0)
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)
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)
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)
347#define ADF4382_NDIV_PWRUP_TIMEOUT_MSK NO_OS_GENMASK(7, 0)
350#define ADF4382_CAL_BLEED_FINE_MAX_MSK NO_OS_GENMASK(7, 0)
353#define ADF4382_VCAL_ZERO_MSK NO_OS_BIT(7)
354#define ADF4382_VPTAT_CALGEN_MSK NO_OS_GENMASK(6, 0)
357#define ADF4382_SPARE_45_MSK NO_OS_BIT(7)
358#define ADF4382_VCTAT_CALGEN_MSK NO_OS_GENMASK(6, 0)
361#define ADF4382_NVMDIN_MSK NO_OS_GENMASK(7, 0)
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)
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)
378#define ADF4382_NVMDOUT_MSK NO_OS_GENMASK(7, 0)
381#define ADF4382_SCAN_MODE_CODE_MSK NO_OS_GENMASK(7, 0)
384#define ADF4382_TEMP_OFFSET_MSK NO_OS_GENMASK(7, 0)
387#define ADF4382_SPARE_4C_MSK NO_OS_GENMASK(7, 6)
388#define ADF4382_TEMP_SLOPE_MSK NO_OS_GENMASK(5, 0)
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)
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)
403#define ADF4382_LUT_SCALE_MSK NO_OS_GENMASK(7, 0)
406#define ADF4382_SPARE0_MSK NO_OS_GENMASK(7, 0)
409#define ADF4382_SPARE1_MSK NO_OS_GENMASK(7, 0)
412#define ADF4382_SYNC_REF_SPARE_MSK NO_OS_GENMASK(7, 4)
413#define ADF4382_SYNC_MON_DEL_MSK NO_OS_GENMASK(3, 0)
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)
423#define ADF4382_ADC_ST_CNV_MSK NO_OS_BIT(0)
426#define ADF4382_FSM_BUSY_MSK NO_OS_BIT(1)
427#define ADF4382_LOCKED_MSK NO_OS_BIT(0)
430#define ADF4382_VCO_BAND_LSB_MSK NO_OS_GENMASK(7, 0)
433#define ADF4382_VCO_CORE_MSK NO_OS_BIT(1)
434#define ADF4382_VCO_BAND_MSB_MSK NO_OS_BIT(0)
437#define ADF4382_LUT_WR_ADDR_MSK NO_OS_GENMASK(5, 1)
438#define ADF4382_O_VCO_LUT_MSK NO_OS_BIT(0)
441#define ADF4382_M_LUT_BAND_LSB_MSK NO_OS_GENMASK(7, 0)
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)
449#define ADF4382_M_LUT_N_MSB_MSK NO_OS_GENMASK(5, 0)
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))
454#define ADF4382_BLEED_MSB_MSK (ADF4382_COARSE_BLEED_MSK | \
455 ADF4382_FINE_BLEED_MSB_MSK)
457#define ADF4382_SPI_SCRATCHPAD_TEST 0x5A
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
465#define ADF4382_VCO_FREQ_MAX 22000000000U
466#define ADF4383_VCO_FREQ_MIN 10000000000U
467#define ADF4383_VCO_FREQ_MAX 20000000000U
468#define ADF4382A_VCO_FREQ_MIN 11500000000U
469#define ADF4382A_VCO_FREQ_MAX 21000000000U
470#define ADF4382_MOD1WORD 0x2000000U
471#define ADF4382_MOD2WORD_MAX 0xFFFFFFU
472#define ADF4382_PHASE_RESYNC_MOD2WORD_MAX 0x1FFFFU
473#define ADF4382_CHANNEL_SPACING_MAX 78125U
474#define ADF4382_PFD_FREQ_MAX 625000000U
475#define ADF4382_PFD_FREQ_FRAC_MAX 250000000U
476#define ADF4382_PFD_FREQ_MIN 5400000U
477#define ADF4382_DCLK_DIV1_0_MAX 160000000U
478#define ADF4382_DCLK_DIV1_1_MAX 320000000U
479#define ADF4382_CLKOUT_DIV_REG_VAL_MAX 4
480#define ADF4382A_CLKOUT_DIV_REG_VAL_MAX 2
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
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
506#define ADF4382_FINE_BLEED_CONST_1 512U
507#define ADF4382_FINE_BLEED_CONST_2 250U
508#define ADF4382_CAL_VTUNE_TO 124U
509#define ADF4382_FSM_BUSY_LOOP_CNT 100U
514#define NS_TO_PS KHZ_PER_MHZ
695 uint8_t mask, uint8_t data);
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 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