33#ifndef AD5592R_BASE_H_
34#define AD5592R_BASE_H_
44#define CH_MODE_UNUSED 0
47#define CH_MODE_DAC_AND_ADC 3
51#define CH_OFFSTATE_PULLDOWN 0
52#define CH_OFFSTATE_OUT_LOW 1
53#define CH_OFFSTATE_OUT_HIGH 2
54#define CH_OFFSTATE_OUT_TRISTATE 3
74#define AD5592R_REG_PD_PD_ALL NO_OS_BIT(10)
75#define AD5592R_REG_PD_EN_REF NO_OS_BIT(9)
77#define AD5592R_REG_CTRL_ADC_PC_BUFF NO_OS_BIT(9)
78#define AD5592R_REG_CTRL_ADC_BUFF_EN NO_OS_BIT(8)
79#define AD5592R_REG_CTRL_CONFIG_LOCK NO_OS_BIT(7)
80#define AD5592R_REG_CTRL_W_ALL_DACS NO_OS_BIT(6)
81#define AD5592R_REG_CTRL_ADC_RANGE NO_OS_BIT(5)
82#define AD5592R_REG_CTRL_DAC_RANGE NO_OS_BIT(4)
84#define AD5592R_REG_ADC_SEQ_REP NO_OS_BIT(9)
85#define AD5592R_REG_ADC_SEQ_TEMP_READBACK NO_OS_BIT(8)
86#define AD5592R_REG_ADC_SEQ_CODE_MSK(x) ((x) & 0x0FFF)
88#define AD5592R_REG_GPIO_OUT_EN_ADC_NOT_BUSY NO_OS_BIT(8)
90#define AD5592R_REG_LDAC_IMMEDIATE_OUT 0x00
91#define AD5592R_REG_LDAC_INPUT_REG_ONLY 0x01
92#define AD5592R_REG_LDAC_INPUT_REG_OUT 0x02
94#define INTERNAL_VREF_VOLTAGE 2.5
96#define NUM_OF_CHANNELS 8
106 uint16_t chans, uint16_t *value);
161 uint8_t offset, int32_t value);
173 uint16_t data, uint16_t mask);
int32_t ad5592r_set_adc_range(struct ad5592r_dev *dev, enum ad559xr_range adc_range)
Definition ad5592r-base.c:364
int32_t ad5592r_set_int_ref(struct ad5592r_dev *dev, bool enable)
Definition ad5592r-base.c:448
int32_t ad5592r_gpio_get(struct ad5592r_dev *dev, uint8_t offset)
Definition ad5592r-base.c:71
ad559xr_range
Definition ad5592r-base.h:114
@ ZERO_TO_VREF
Definition ad5592r-base.h:115
@ ZERO_TO_2VREF
Definition ad5592r-base.h:116
int32_t ad5592r_set_channel_modes(struct ad5592r_dev *dev)
Definition ad5592r-base.c:203
int32_t ad5592r_gpio_set(struct ad5592r_dev *dev, uint8_t offset, int32_t value)
Definition ad5592r-base.c:97
int32_t ad5592r_base_reg_read(struct ad5592r_dev *dev, uint8_t reg, uint16_t *value)
Definition ad5592r-base.c:58
int32_t ad5592r_power_down(struct ad5592r_dev *dev, uint8_t chan, bool enable)
Definition ad5592r-base.c:421
int32_t ad5592r_base_reg_write(struct ad5592r_dev *dev, uint8_t reg, uint16_t value)
Definition ad5592r-base.c:44
int32_t ad5592r_set_dac_range(struct ad5592r_dev *dev, enum ad559xr_range dac_range)
Definition ad5592r-base.c:392
int32_t ad5592r_software_reset(struct ad5592r_dev *dev)
Definition ad5592r-base.c:182
int32_t ad5592r_base_reg_update(struct ad5592r_dev *dev, uint16_t reg_addr, uint16_t data, uint16_t mask)
Definition ad5592r-base.c:333
int32_t ad5592r_reset_channel_modes(struct ad5592r_dev *dev)
Definition ad5592r-base.c:311
int32_t ad5592r_gpio_direction_output(struct ad5592r_dev *dev, uint8_t offset, int32_t value)
Definition ad5592r-base.c:145
int32_t ad5592r_set_adc_buffer(struct ad5592r_dev *dev, bool enable)
Definition ad5592r-base.c:475
int32_t ad5592r_gpio_direction_input(struct ad5592r_dev *dev, uint8_t offset)
Definition ad5592r-base.c:118
ad5592r_registers
Definition ad5592r-base.h:56
@ AD5592R_REG_RESET
Definition ad5592r-base.h:71
@ AD5592R_REG_TRISTATE
Definition ad5592r-base.h:70
@ AD5592R_REG_OPEN_DRAIN
Definition ad5592r-base.h:69
@ AD5592R_REG_GPIO_SET
Definition ad5592r-base.h:66
@ AD5592R_REG_PD
Definition ad5592r-base.h:68
@ AD5592R_REG_CTRL
Definition ad5592r-base.h:60
@ AD5592R_REG_GPIO_IN_EN
Definition ad5592r-base.h:67
@ AD5592R_REG_LDAC
Definition ad5592r-base.h:64
@ AD5592R_REG_GPIO_OUT_EN
Definition ad5592r-base.h:65
@ AD5592R_REG_ADC_EN
Definition ad5592r-base.h:61
@ AD5592R_REG_ADC_SEQ
Definition ad5592r-base.h:59
@ AD5592R_REG_DAC_READBACK
Definition ad5592r-base.h:58
@ AD5592R_REG_DAC_EN
Definition ad5592r-base.h:62
@ AD5592R_REG_NOOP
Definition ad5592r-base.h:57
@ AD5592R_REG_PULLDOWN
Definition ad5592r-base.h:63
Header file of Delay functions.
Header file of I2C Interface.
Header file of SPI Interface.
Header file of utility functions.
Definition ad5592r-base.h:131
uint16_t cached_dac[8]
Definition ad5592r-base.h:137
uint8_t channel_modes[8]
Definition ad5592r-base.h:139
const struct ad5592r_rw_ops * ops
Definition ad5592r-base.h:132
uint8_t power_down[8]
Definition ad5592r-base.h:148
bool adc_buf
Definition ad5592r-base.h:149
uint8_t gpio_val
Definition ad5592r-base.h:143
uint8_t channel_offstate[8]
Definition ad5592r-base.h:140
bool int_ref
Definition ad5592r-base.h:147
uint16_t spi_msg
Definition ad5592r-base.h:135
enum ad559xr_range dac_range
Definition ad5592r-base.h:146
struct no_os_spi_desc * spi
Definition ad5592r-base.h:134
uint16_t cached_gp_ctrl
Definition ad5592r-base.h:138
uint8_t gpio_out
Definition ad5592r-base.h:141
uint8_t gpio_in
Definition ad5592r-base.h:142
uint8_t num_channels
Definition ad5592r-base.h:136
uint8_t ldac_mode
Definition ad5592r-base.h:144
enum ad559xr_range adc_range
Definition ad5592r-base.h:145
struct no_os_i2c_desc * i2c
Definition ad5592r-base.h:133
Definition ad5592r-base.h:119
struct no_os_i2c_init_param * i2c_init
Definition ad5592r-base.h:122
bool int_ref
Definition ad5592r-base.h:120
uint8_t channel_offstate[8]
Definition ad5592r-base.h:124
uint8_t power_down[8]
Definition ad5592r-base.h:128
bool adc_buf
Definition ad5592r-base.h:127
enum ad559xr_range dac_range
Definition ad5592r-base.h:126
uint8_t channel_modes[8]
Definition ad5592r-base.h:123
enum ad559xr_range adc_range
Definition ad5592r-base.h:125
struct no_os_spi_init_param * spi_init
Definition ad5592r-base.h:121
Definition ad5592r-base.h:100
int32_t(* multi_read_adc)(struct ad5592r_dev *dev, uint16_t chans, uint16_t *value)
Definition ad5592r-base.h:105
int32_t(* reg_read)(struct ad5592r_dev *dev, uint8_t reg, uint16_t *value)
Definition ad5592r-base.h:109
int32_t(* write_dac)(struct ad5592r_dev *dev, uint8_t chan, uint16_t value)
Definition ad5592r-base.h:101
int32_t(* read_adc)(struct ad5592r_dev *dev, uint8_t chan, uint16_t *value)
Definition ad5592r-base.h:103
int32_t(* reg_write)(struct ad5592r_dev *dev, uint8_t reg, uint16_t value)
Definition ad5592r-base.h:107
int32_t(* gpio_read)(struct ad5592r_dev *dev, uint8_t *value)
Definition ad5592r-base.h:111
Structure holding I2C address descriptor.
Definition no_os_i2c.h:89
Structure holding the parameters for I2C initialization.
Definition no_os_i2c.h:52
Structure holding SPI descriptor.
Definition no_os_spi.h:180
Structure holding the parameters for SPI initialization.
Definition no_os_spi.h:128