44#define AD4080_REG_INTERFACE_CONFIG_A 0x0000
45#define AD4080_REG_INTERFACE_CONFIG_B 0x0001
46#define AD4080_REG_DEVICE_CONFIG 0x0002
47#define AD4080_REG_CHIP_TYPE 0x0003
48#define AD4080_REG_PRODUCT_ID_L 0x0004
49#define AD4080_REG_PRODUCT_ID_H 0x0005
50#define AD4080_REG_CHIP_GRADE 0x0006
51#define AD4080_REG_SCRATCH_PAD 0x000A
52#define AD4080_REG_SPI_REVISION 0x000B
53#define AD4080_REG_VENDOR_L 0x000C
54#define AD4080_REG_VENDOR_H 0x000D
55#define AD4080_REG_STREAM_MODE 0x000E
56#define AD4080_REG_TRANSFER_CONFIG 0x000F
57#define AD4080_REG_INTERFACE_CONFIG_C 0x0010
58#define AD4080_REG_INTERFACE_STATUS_A 0x0011
59#define AD4080_REG_DEVICE_STATUS 0x0014
60#define AD4080_REG_DATA_INTF_CONFIG_A 0x0015
61#define AD4080_REG_DATA_INTF_CONFIG_B 0x0016
62#define AD4080_REG_DATA_INTF_CONFIG_C 0x0017
63#define AD4080_REG_PWR_CTRL 0x0018
64#define AD4080_REG_GPIO_CONFIG_A 0x0019
65#define AD4080_REG_GPIO_CONFIG_B 0x001A
66#define AD4080_REG_GPIO_CONFIG_C 0x001B
67#define AD4080_REG_GENERAL_CONFIG 0x001C
68#define AD4080_REG_FIFO_WATERMARK 0x001D
69#define AD4080_REG_EVENT_HYSTERESIS 0x001F
70#define AD4080_REG_EVENT_DETECTION_HI 0x0021
71#define AD4080_REG_EVENT_DETECTION_LO 0x0023
72#define AD4080_REG_OFFSET 0x0025
73#define AD4080_REG_GAIN 0x0027
74#define AD4080_REG_FILTER_CONFIG 0x0029
77#define AD4080_SW_RESET_MSK NO_OS_BIT(7) | NO_OS_BIT(0)
78#define AD4080_ADDR_ASC_MSK NO_OS_BIT(5)
79#define AD4080_SDO_ENABLE_MSK NO_OS_BIT(4)
82#define AD4080_SINGLE_INST_MSK NO_OS_BIT(7)
83#define AD4080_SHORT_INST_MSK NO_OS_BIT(3)
86#define AD4080_OP_MODE_MSK NO_OS_GENMASK(1, 0)
89#define AD4080_KEEP_STREAM_LEN_VAL_MSK NO_OS_BIT(2)
92#define AD4080_STRICT_REG_ACCESS_MSK NO_OS_BIT(5)
95#define AD4080_INTF_CHK_EN_MSK NO_OS_BIT(4)
96#define AD4080_SPI_LVDS_LANES_MSK NO_OS_BIT(2)
97#define AD4080_DATA_INTF_MODE_MSK NO_OS_BIT(0)
100#define AD4080_LVDS_CNV_CLK_CNT_MSK NO_OS_GENMASK(7, 4)
101#define AD4080_LVDS_SELF_CLK_MODE_MSK NO_OS_BIT(3)
102#define AD4080_LVDS_CNV_EN NO_OS_BIT(0)
105#define AD4080_LVDS_VOD_MSK NO_OS_GENMASK(6, 4)
108#define AD4080_ANA_DIG_LDO_PD_MSK NO_OS_BIT(1)
109#define AD4080_INTF_LDO_PD_MSK NO_OS_BIT(0)
112#define AD4080_GPIO_EN_MSK(x) NO_OS_BIT(x)
113#define AD4080_GPIO_SEL_MSK(x) (NO_OS_GENMASK(3, 0) << (4 * ((x)%2)))
114#define AD4080_GPIO_DATA_MSK(x) (NO_OS_BIT(x) << 4)
117#define AD4080_FIFO_MODE_MSK NO_OS_GENMASK(1, 0)
120#define AD4080_SW_RESET NO_OS_BIT(7) | NO_OS_BIT(0)
121#define AD4080_SPI_READ NO_OS_BIT(7)
122#define BYTE_ADDR_H NO_OS_GENMASK(15, 8)
123#define BYTE_ADDR_L NO_OS_GENMASK(7, 0)
124#define AD4080_CHIP_ID NO_OS_GENMASK(2, 0)
125#define AD4080_FIFO_SIZE NO_OS_BIT(14)
411 uint8_t lvds_cnv_clk_cnt);
415 uint8_t *lvds_cnv_clk_cnt);
467 uint16_t fifo_watermark);
471 uint16_t *fifo_watermark);
int ad4080_set_lvds_vod(struct ad4080_dev *dev, enum ad4080_lvds_vod lvds_vod)
Set AD4080 LVDS Differential Output Voltage.
Definition ad4080.c:680
int ad4080_get_intf_chk_en(struct ad4080_dev *dev, enum ad4080_intf_chk_en *intf_chk_en)
Get AD4080 Output Pattern.
Definition ad4080.c:411
ad4080_op_mode
Definition ad4080.h:146
@ AD4080_OP_NORMAL
Definition ad4080.h:147
@ AD4080_OP_LOW_POWER
Definition ad4080.h:149
@ AD4080_OP_STANDBY
Definition ad4080.h:148
int ad4080_get_op_mode(struct ad4080_dev *dev, enum ad4080_op_mode *op_mode)
Get Operation Mode.
Definition ad4080.c:313
int ad4080_set_op_mode(struct ad4080_dev *dev, enum ad4080_op_mode op_mode)
Set Operation Mode.
Definition ad4080.c:288
int ad4080_remove(struct ad4080_dev *dev)
Remove the device and release resources.
Definition ad4080.c:1221
int ad4080_set_strict_reg_access(struct ad4080_dev *dev, enum ad4080_strict_reg_access strict_reg)
Set Strict Register Access.
Definition ad4080.c:337
ad4080_lvds_self_clk_mode
Definition ad4080.h:177
@ AD4080_ECHO_CLK_MODE
Definition ad4080.h:178
@ AD4080_SELF_CLK_MODE
Definition ad4080.h:179
int ad4080_data_intf_init(struct ad4080_dev *device, struct ad4080_init_param init_param)
Configure the data interface during initialization.
Definition ad4080.c:1092
int ad4080_set_single_instr(struct ad4080_dev *dev, enum ad4080_single_instr single_instr)
Set Single/Streaming Mode.
Definition ad4080.c:190
ad4080_gpio_op_func_sel
Definition ad4080.h:223
@ AD4080_GPIO_LT_DETECT
Definition ad4080.h:229
@ AD4080_GPIO_HT_DETECT
Definition ad4080.h:228
@ AD4080_GPIO_GPO_DATA
Definition ad4080.h:231
@ AD4080_GPIO_EXT_EVENT_TRIGGER_FIFO
Definition ad4080.h:233
@ AD4080_GPIO_FILTER_RESULT_READY
Definition ad4080.h:227
@ AD4080_GPIO_STATUS_ALERT
Definition ad4080.h:230
@ AD4080_GPIO_FILTER_SYNC_INPUT
Definition ad4080.h:232
@ AD4080_GPIO_FIFO_READ_DONE
Definition ad4080.h:226
@ AD4080_GPIO_ADI_NSPI_SDO_DATA
Definition ad4080.h:224
@ AD4080_GPIO_FIFO_FULL
Definition ad4080.h:225
@ AD4080_GPIO_CNV_INHIBIT_INPUT
Definition ad4080.h:234
ad4080_lvds_vod
Definition ad4080.h:189
@ AD4080_185mVPP
Definition ad4080.h:190
@ AD4080_240mVPP
Definition ad4080.h:191
@ AD4080_325mVPP
Definition ad4080.h:192
int ad4080_set_gpio_output_func(struct ad4080_dev *dev, enum ad4080_gpio gpio, enum ad4080_gpio_op_func_sel gpio_func)
Configure the GPIO output for a specific function.
Definition ad4080.c:961
ad4080_cnv_spi_lvds_lanes
Definition ad4080.h:165
@ AD4080_MULTIPLE_LANES
Definition ad4080.h:167
@ AD4080_ONE_LANE
Definition ad4080.h:166
int ad4080_set_short_instr(struct ad4080_dev *dev, enum ad4080_short_instr short_instr)
Set Short Instruction.
Definition ad4080.c:239
int ad4080_set_intf_ldo_pd(struct ad4080_dev *dev, enum ad4080_intf_ldo_pd intf_ldo_pd)
Set AD4080 Interface LDO.
Definition ad4080.c:777
int ad4080_set_fifo_mode(struct ad4080_dev *dev, enum ad4080_fifo_mode fifo_mode)
Set AD4080 Conversion Data FIFO Mode.
Definition ad4080.c:826
int ad4080_configuration_intf_init(struct ad4080_dev *device, struct ad4080_init_param init_param)
Configure the config SPI interface during initialization.
Definition ad4080.c:1062
int ad4080_set_addr_asc(struct ad4080_dev *dev, enum ad4080_addr_asc addr_asc)
Set Address Ascension.
Definition ad4080.c:143
int ad4080_init(struct ad4080_dev **device, struct ad4080_init_param init_param)
Initialize the device.
Definition ad4080.c:1134
int ad4080_set_lvds_self_clk_mode(struct ad4080_dev *dev, enum ad4080_lvds_self_clk_mode lvds_self_clk_mode)
Set AD4080 LVDS Self Clock Mode.
Definition ad4080.c:582
int ad4080_set_lvds_cnv_clk_cnt(struct ad4080_dev *dev, uint8_t lvds_cnv_clk_cnt)
Set AD4080 Interface clock periods from CNV rising edge.
Definition ad4080.c:533
int ad4080_get_lvds_cnv_clk_mode(struct ad4080_dev *dev, enum ad4080_lvds_cnv_clk_mode *cnv_clk_mode)
Get AD4080 LVDS CNV Clock Mode.
Definition ad4080.c:656
int ad4080_update_bits(struct ad4080_dev *dev, uint16_t reg_addr, uint8_t mask, uint8_t reg_val)
Update specific register bits.
Definition ad4080.c:97
int ad4080_gpio_write_data(struct ad4080_dev *dev, enum ad4080_gpio gpio, bool data)
Set the GPIO data.
Definition ad4080.c:993
int ad4080_get_short_instr(struct ad4080_dev *dev, enum ad4080_short_instr *short_instr)
Get Short Instruction.
Definition ad4080.c:264
int ad4080_get_lvds_vod(struct ad4080_dev *dev, enum ad4080_lvds_vod *lvds_vod)
Get AD4080 LVDS Differential Output Voltage.
Definition ad4080.c:705
int ad4080_soft_reset(struct ad4080_dev *dev)
Software reset the device.
Definition ad4080.c:121
ad4080_intf_ldo_pd
Definition ad4080.h:202
@ AD4080_INTF_LDO_EN
Definition ad4080.h:203
@ AD4080_INTF_LDO_DISABLE
Definition ad4080.h:204
int ad4080_get_fifo_watermark(struct ad4080_dev *dev, uint16_t *fifo_watermark)
Get AD4080 FIFO Watermark.
Definition ad4080.c:900
ad4080_ana_dig_ldo_pd
Definition ad4080.h:196
@ AD4080_AD_LDO_DISABLE
Definition ad4080.h:198
@ AD4080_AD_LDO_EN
Definition ad4080.h:197
int ad4080_get_ana_dig_ldo_pd(struct ad4080_dev *dev, enum ad4080_ana_dig_ldo_pd *ana_dig_ldo_pd)
Get AD4080 Analog/Digital LDO.
Definition ad4080.c:753
int ad4080_get_fifo_mode(struct ad4080_dev *dev, enum ad4080_fifo_mode *fifo_mode)
Get Set AD4080 Conversion Data FIFO Mode.
Definition ad4080.c:851
int ad4080_set_ana_dig_ldo_pd(struct ad4080_dev *dev, enum ad4080_ana_dig_ldo_pd ana_dig_ldo_pd)
Set AD4080 Analog/Digital LDO.
Definition ad4080.c:728
ad4080_gpio
Definition ad4080.h:208
@ AD4080_GPIO_2
Definition ad4080.h:211
@ AD4080_GPIO_0
Definition ad4080.h:209
@ AD4080_GPIO_3
Definition ad4080.h:212
@ NUM_AD4080_GPIO
Definition ad4080.h:213
@ AD4080_GPIO_1
Definition ad4080.h:210
int ad4080_set_lvds_cnv_clk_mode(struct ad4080_dev *dev, enum ad4080_lvds_cnv_clk_mode cnv_clk_mode)
Set AD4080 LVDS CNV Clock Mode.
Definition ad4080.c:631
int ad4080_get_lvds_cnv_clk_cnt(struct ad4080_dev *dev, uint8_t *lvds_cnv_clk_cnt)
Get AD4080 Interface clock periods from CNV rising edge.
Definition ad4080.c:558
int ad4080_set_fifo_watermark(struct ad4080_dev *dev, uint16_t fifo_watermark)
Set AD4080 FIFO Watermark.
Definition ad4080.c:875
int ad4080_read(struct ad4080_dev *dev, uint16_t reg_addr, uint8_t *reg_val)
Read device register.
Definition ad4080.c:69
int ad4080_set_intf_chk_en(struct ad4080_dev *dev, enum ad4080_intf_chk_en intf_chk_en)
Set AD4080 Output Pattern.
Definition ad4080.c:386
int ad4080_get_strict_reg_access(struct ad4080_dev *dev, enum ad4080_strict_reg_access *strict_reg)
Get Strict Register Access.
Definition ad4080.c:362
ad4080_conv_data_spi_lvds
Definition ad4080.h:171
@ AD4080_CONV_DATA_LVDS
Definition ad4080.h:172
@ AD4080_CONV_DATA_SPI
Definition ad4080.h:173
int ad4080_write(struct ad4080_dev *dev, uint16_t reg_addr, uint8_t reg_val)
Write device register.
Definition ad4080.c:48
ad4080_short_instr
Definition ad4080.h:140
@ AD4080_7_BIT_ADDR
Definition ad4080.h:142
@ AD4080_15_BIT_ADDR
Definition ad4080.h:141
int ad4080_get_lvds_self_clk_mode(struct ad4080_dev *dev, enum ad4080_lvds_self_clk_mode *lvds_self_clk_mode)
Get AD4080 LVDS Self Clock Mode.
Definition ad4080.c:607
int ad4080_set_conv_data_spi_lvds(struct ad4080_dev *dev, enum ad4080_conv_data_spi_lvds conv_data_spi_lvds)
Set AD4080 Data Interface Configuration.
Definition ad4080.c:484
int ad4080_get_conv_data_spi_lvds(struct ad4080_dev *dev, enum ad4080_conv_data_spi_lvds *conv_data_spi_lvds)
Get AD4080 Data Interface Configuration.
Definition ad4080.c:509
ad4080_addr_asc
Definition ad4080.h:128
@ AD4080_ADDR_DECR
Definition ad4080.h:129
@ AD4080_ADDR_INCR
Definition ad4080.h:130
int ad4080_get_cnv_spi_lvds_lanes(struct ad4080_dev *dev, enum ad4080_cnv_spi_lvds_lanes *cnv_spi_lvds_lanes)
Get AD4080 LVDS/SPI Lane Control.
Definition ad4080.c:460
int ad4080_get_intf_ldo_pd(struct ad4080_dev *dev, enum ad4080_intf_ldo_pd *intf_ldo_pd)
Get AD4080 Interface LDO.
Definition ad4080.c:802
ad4080_intf_chk_en
Definition ad4080.h:159
@ AD4080_FIXED_PATTERN
Definition ad4080.h:161
@ AD4080_DATA
Definition ad4080.h:160
ad4080_lvds_cnv_clk_mode
Definition ad4080.h:183
@ AD4080_CNV_LVDS_MODE
Definition ad4080.h:185
@ AD4080_CNV_CMOS_MODE
Definition ad4080.h:184
ad4080_single_instr
Definition ad4080.h:134
@ AD4080_STREAM_MODE
Definition ad4080.h:135
@ AD4080_SINGLE_INST
Definition ad4080.h:136
int ad4080_gpio_read_data(struct ad4080_dev *dev, enum ad4080_gpio gpio, bool *data)
Read the GPIO data.
Definition ad4080.c:1024
ad4080_gpio_op_enable
Definition ad4080.h:217
@ AD4080_GPIO_OUTPUT
Definition ad4080.h:219
@ AD4080_GPIO_INPUT
Definition ad4080.h:218
ad4080_fifo_mode
Definition ad4080.h:238
@ AD4080_EVENT_TRIGGER
Definition ad4080.h:242
@ AD4080_IMMEDIATE_TRIGGER
Definition ad4080.h:240
@ AD4080_FIFO_DISABLE
Definition ad4080.h:239
@ AD4080_EVENT_TRIGGER_LAST_WM
Definition ad4080.h:241
int ad4080_set_gpio_output_enable(struct ad4080_dev *dev, enum ad4080_gpio gpio, enum ad4080_gpio_op_enable gpio_op_enable)
Configure GPIO as input or output.
Definition ad4080.c:933
int ad4080_get_addr_asc(struct ad4080_dev *dev, enum ad4080_addr_asc *addr_asc)
Get Address Ascension.
Definition ad4080.c:167
ad4080_strict_reg_access
Definition ad4080.h:153
@ AD4080_REG_NORMAL_MODE
Definition ad4080.h:154
@ AD4080_REG_STRICT_MODE
Definition ad4080.h:155
int ad4080_get_single_instr(struct ad4080_dev *dev, enum ad4080_single_instr *single_instr)
Get Single/Streaming Mode.
Definition ad4080.c:215
int ad4080_set_cnv_spi_lvds_lanes(struct ad4080_dev *dev, enum ad4080_cnv_spi_lvds_lanes cnv_spi_lvds_lanes)
Set AD4080 LVDS/SPI Lane Control.
Definition ad4080.c:435
struct ad7616_init_param init_param
Definition ad7616_sdz.c:107
Header file of GPIO Interface.
Header file of SPI Interface.
Header file of utility functions.
ad4080 Device structure.
Definition ad4080.h:249
enum ad4080_op_mode op_mode
Definition ad4080.h:261
struct no_os_spi_desc * spi_desc
Definition ad4080.h:251
enum ad4080_gpio_op_enable gpio_op_enable[NUM_AD4080_GPIO]
Definition ad4080.h:285
enum ad4080_short_instr short_instr
Definition ad4080.h:259
enum ad4080_single_instr single_instr
Definition ad4080.h:257
uint8_t lvds_cnv_clk_cnt
Definition ad4080.h:271
enum ad4080_ana_dig_ldo_pd ana_dig_ldo_pd
Definition ad4080.h:279
enum ad4080_conv_data_spi_lvds conv_data_spi_lvds
Definition ad4080.h:269
enum ad4080_lvds_cnv_clk_mode cnv_clk_mode
Definition ad4080.h:275
enum ad4080_gpio_op_func_sel gpio_op_func_sel[NUM_AD4080_GPIO]
Definition ad4080.h:287
enum ad4080_intf_chk_en intf_chk_en
Definition ad4080.h:265
enum ad4080_cnv_spi_lvds_lanes cnv_spi_lvds_lanes
Definition ad4080.h:267
enum ad4080_fifo_mode fifo_mode
Definition ad4080.h:283
bool spi3wire
Definition ad4080.h:253
enum ad4080_intf_ldo_pd intf_ldo_pd
Definition ad4080.h:281
enum ad4080_lvds_vod lvds_vod
Definition ad4080.h:277
enum ad4080_lvds_self_clk_mode lvds_self_clk_mode
Definition ad4080.h:273
enum ad4080_strict_reg_access strict_reg
Definition ad4080.h:263
enum ad4080_addr_asc addr_asc
Definition ad4080.h:255
ad4080 Device initialization parameters.
Definition ad4080.h:294
enum ad4080_op_mode op_mode
Definition ad4080.h:306
struct no_os_spi_init_param * spi_init
Definition ad4080.h:296
bool spi3wire
Definition ad4080.h:298
enum ad4080_lvds_vod lvds_vod
Definition ad4080.h:322
enum ad4080_lvds_self_clk_mode lvds_self_clk_mode
Definition ad4080.h:318
enum ad4080_strict_reg_access strict_reg
Definition ad4080.h:308
enum ad4080_cnv_spi_lvds_lanes cnv_spi_lvds_lanes
Definition ad4080.h:312
enum ad4080_ana_dig_ldo_pd ana_dig_ldo_pd
Definition ad4080.h:324
enum ad4080_short_instr short_instr
Definition ad4080.h:304
enum ad4080_lvds_cnv_clk_mode cnv_clk_mode
Definition ad4080.h:320
enum ad4080_gpio_op_func_sel gpio_op_func_sel[NUM_AD4080_GPIO]
Definition ad4080.h:332
enum ad4080_fifo_mode fifo_mode
Definition ad4080.h:328
enum ad4080_intf_chk_en intf_chk_en
Definition ad4080.h:310
enum ad4080_single_instr single_instr
Definition ad4080.h:302
enum ad4080_gpio_op_enable gpio_op_enable[NUM_AD4080_GPIO]
Definition ad4080.h:330
enum ad4080_conv_data_spi_lvds conv_data_spi_lvds
Definition ad4080.h:314
uint8_t lvds_cnv_clk_cnt
Definition ad4080.h:316
enum ad4080_addr_asc addr_asc
Definition ad4080.h:300
enum ad4080_intf_ldo_pd intf_ldo_pd
Definition ad4080.h:326
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