Go to the documentation of this file.
56 #define AD7193_SLAVE_ID 1
59 #define AD7193_REG_COMM 0 // Communications Register (WO, 8-bit)
60 #define AD7193_REG_STAT 0 // Status Register (RO, 8-bit)
61 #define AD7193_REG_MODE 1 // Mode Register (RW, 24-bit
62 #define AD7193_REG_CONF 2 // Configuration Register (RW, 24-bit)
63 #define AD7193_REG_DATA 3 // Data Register (RO, 24/32-bit)
64 #define AD7193_REG_ID 4 // ID Register (RO, 8-bit)
65 #define AD7193_REG_GPOCON 5 // GPOCON Register (RW, 8-bit)
66 #define AD7193_REG_OFFSET 6 // Offset Register (RW, 24-bit
67 #define AD7193_REG_FULLSCALE 7 // Full-Scale Register (RW, 24-bit)
70 #define AD7193_COMM_WEN (1 << 7) // Write Enable.
71 #define AD7193_COMM_WRITE (0 << 6) // Write Operation.
72 #define AD7193_COMM_READ (1 << 6) // Read Operation.
73 #define AD7193_COMM_ADDR(x) (((x) & 0x7) << 3) // Register Address.
74 #define AD7193_COMM_CREAD (1 << 2) // Continuous Read of Data Register.
77 #define AD7193_STAT_RDY (1 << 7) // Ready.
78 #define AD7193_STAT_ERR (1 << 6) // ADC error bit.
79 #define AD7193_STAT_NOREF (1 << 5) // Error no external reference.
80 #define AD7193_STAT_PARITY (1 << 4) // Parity check of the data register.
81 #define AD7193_STAT_CH3 (1 << 3) // Channel 3.
82 #define AD7193_STAT_CH2 (1 << 2) // Channel 2.
83 #define AD7193_STAT_CH1 (1 << 1) // Channel 1.
84 #define AD7193_STAT_CH0 (1 << 0) // Channel 0.
87 #define AD7193_MODE_SEL(x) (((uint32_t)(x) & 0x7) << 21) // Operation Mode Select.
88 #define AD7193_MODE_DAT_STA ((uint32_t)1 << 20) // Status Register transmission.
89 #define AD7193_MODE_CLKSRC(x) (((uint32_t)(x) & 0x3) << 18) // Clock Source Select.
90 #define AD7193_MODE_AVG(x) (((uint32_t)(x) & 0x3) << 16) // Fast settling filter.
91 #define AD7193_MODE_SINC3 (1 << 15) // SINC3 Filter Select.
92 #define AD7193_MODE_ENPAR (1 << 13) // Parity Enable.
93 #define AD7193_MODE_CLKDIV (1 << 12) // Clock divide by 2 (AD7190/2 only).
94 #define AD7193_MODE_SCYCLE (1 << 11) // Single cycle conversion.
95 #define AD7193_MODE_REJ60 (1 << 10) // 50/60Hz notch filter.
96 #define AD7193_MODE_RATE(x) ((x) & 0x3FF) // Filter Update Rate Select.
99 #define AD7193_AVG_NONE 0 // No averaging (fast settling mode disabled).
100 #define AD7193_AVG_BY_2 1 // Average by 2.
101 #define AD7193_AVG_BY_8 2 // Average by 8.
102 #define AD7193_AVG_BY_16 3 // Average by 16.
105 #define AD7193_CONF_CHOP ((uint32_t)1 << 23) // CHOP enable.
106 #define AD7193_CONF_REFSEL ((uint32_t)1 << 20) // REFIN1/REFIN2 Reference Select.
107 #define AD7193_CONF_PSEUDO ((uint32_t)1 << 18) // Pseudo differential analog inputs.
108 #define AD7193_CONF_CHAN(x) ((uint32_t)((x) & 0x3FF) << 8) // Channel select.
109 #define AD7193_CONF_BURN (1 << 7) // Burnout current enable.
110 #define AD7193_CONF_REFDET (1 << 6) // Reference detect enable.
111 #define AD7193_CONF_BUF (1 << 4) // Buffered Mode Enable.
112 #define AD7193_CONF_UNIPOLAR (1 << 3) // Unipolar/Bipolar Enable.
113 #define AD7193_CONF_GAIN(x) ((x) & 0x7) // Gain Select.
117 #define AD7193_CH_0 0 // AIN1(+) - AIN2(-); AIN1 - AINCOM
118 #define AD7193_CH_1 1 // AIN3(+) - AIN4(-); AIN2 - AINCOM
119 #define AD7193_CH_2 2 // AIN5(+) - AIN6(-); AIN3 - AINCOM
120 #define AD7193_CH_3 3 // AIN7(+) - AIN8(-); AIN4 - AINCOM
121 #define AD7193_CH_4 4 // AIN1(+) - AIN2(-); AIN5 - AINCOM
122 #define AD7193_CH_5 5 // AIN3(+) - AIN4(-); AIN6 - AINCOM
123 #define AD7193_CH_6 6 // AIN5(+) - AIN6(-); AIN7 - AINCOM
124 #define AD7193_CH_7 7 // AIN7(+) - AIN8(-); AIN8 - AINCOM
125 #define AD7193_CH_TEMP 8 // Temperature sensor
126 #define AD7193_CH_SHORT 9 // AIN2(+) - AIN2(-); AINCOM(+) - AINCOM(-)
129 #define ID_AD7193 0x2
130 #define AD7193_ID_MASK 0x0F
133 #define AD7193_GPOCON_BPDSW (1 << 6) // Bridge power-down switch enable
134 #define AD7193_GPOCON_GP32EN (1 << 5) // Digital Output P3 and P2 enable
135 #define AD7193_GPOCON_GP10EN (1 << 4) // Digital Output P1 and P0 enable
136 #define AD7193_GPOCON_P3DAT (1 << 3) // P3 state
137 #define AD7193_GPOCON_P2DAT (1 << 2) // P2 state
138 #define AD7193_GPOCON_P1DAT (1 << 1) // P1 state
139 #define AD7193_GPOCON_P0DAT (1 << 0) // P0 state
142 #define AD7193_CH_MASK(x) BIT(x)
233 uint32_t reg_value, uint8_t bytes_number);
237 uint8_t bytes_number, uint32_t *reg_data);
241 uint8_t reg_addr, uint32_t mask, uint32_t data,
259 uint8_t mode, uint8_t channel);
269 uint16_t out_rate_code);
287 uint8_t sample_number, uint32_t *samples_avg);
294 uint32_t raw_data,
float v_ref);
@ AD7193_ADC_2_5V
Definition: ad7193.h:150
int ad7193_remove(struct ad7193_dev *dev)
Free the resources allocated by ad7193_init().
Definition: ad7193.c:152
int32_t spi_remove(struct spi_desc *desc)
Free the resources allocated by spi_init().
Definition: spi.c:70
@ AD7193_MODE_CAL_SYS_FULL
Definition: ad7193.h:185
int ad7193_set_register_value(struct ad7193_dev *dev, uint8_t reg_addr, uint32_t reg_val, uint8_t bytes_number)
Writes data into a register.
Definition: ad7193.c:179
int ad7193_single_conversion(struct ad7193_dev *dev, uint32_t *reg_data)
Returns the result of a single conversion.
Definition: ad7193.c:565
int ad7193_temperature_read(struct ad7193_dev *dev, float *temp)
Read data from temperature sensor and converts it to Celsius degrees.
Definition: ad7193.c:637
int ad7193_get_register_value(struct ad7193_dev *dev, uint8_t reg_addr, uint8_t bytes_number, uint32_t *reg_data)
Reads the value of a register.
Definition: ad7193.c:213
int ad7193_set_bridge_switch(struct ad7193_dev *dev, uint8_t bpdsw_select)
Opens or closes the bridge power-down switch of the ADC.
Definition: ad7193.c:510
Structure holding SPI descriptor.
Definition: spi.h:132
enum ad7193_adc_clock clock_source
Definition: ad7193.h:214
int ad7193_set_register_value(struct ad7193_dev *dev, uint8_t reg_addr, uint32_t reg_value, uint8_t bytes_number)
Writes data into a register.
Definition: ad7193.c:179
int ad7193_temperature_read(struct ad7193_dev *dev, float *temp)
Read data from temperature sensor and converts it to Celsius degrees.
Definition: ad7193.c:637
int ad7193_range_setup(struct ad7193_dev *dev, uint8_t polarity, enum ad7193_adc_range range)
Selects the polarity of the conversion and the ADC input range.
Definition: ad7193.c:538
enum ad7193_adc_modes operating_mode
Definition: ad7193.h:196
#define AD7193_CONF_GAIN(x)
Definition: ad7193.h:113
int ad7193_remove(struct ad7193_dev *dev)
Free the resources allocated by ad7193_init().
Definition: ad7193.c:152
@ AD7193_INT_CLK_4_92_MHZ
Definition: ad7193.h:166
int ad7193_init(struct ad7193_dev **device, struct ad7193_init_param init_param)
Initializes the communication peripheral and the initial Values for AD7193 Board and resets the devic...
Definition: ad7193.c:62
Header file of SPI Interface.
@ AD7193_ADC_19_53mV
Definition: ad7193.h:155
#define AD7193_REG_GPOCON
Definition: ad7193.h:65
int32_t spi_write_and_read(struct spi_desc *desc, uint8_t *data, uint16_t bytes_number)
Write and read data to/from SPI.
Definition: spi.c:82
@ AD7193_MODE_IDLE
Definition: ad7193.h:175
int ad7193_get_register_value(struct ad7193_dev *dev, uint8_t reg_addr, uint8_t bytes_number, uint32_t *reg_data)
Reads the value of a register.
Definition: ad7193.c:213
#define AD7193_MODE_RATE(x)
Definition: ad7193.h:96
uint8_t bpdsw_mode
Definition: ad7193.h:201
#define AD7193_GPOCON_BPDSW
Definition: ad7193.h:133
Definition: ad9361_util.h:75
int ad7193_output_rate_select(struct ad7193_dev *dev, uint16_t out_rate_code)
Selects the filter output data rate of the ADC.
Definition: ad7193.c:454
#define AD7193_MODE_SEL(x)
Definition: ad7193.h:87
int ad7193_range_setup(struct ad7193_dev *dev, uint8_t polarity, enum ad7193_adc_range range)
Selects the polarity of the conversion and the ADC input range.
Definition: ad7193.c:538
int ad7193_channels_select(struct ad7193_dev *dev, uint16_t chn_mask)
Selects the channels to be enabled.
Definition: ad7193.c:355
@ AD7193_MODE_CAL_INT_FULL
Definition: ad7193.h:181
int ad7193_config_input_mode(struct ad7193_dev *dev, uint8_t mode)
Configures the input mode of the ADC.
Definition: ad7193.c:404
float ad7193_convert_to_volts(struct ad7193_dev *dev, uint32_t raw_data, float v_ref)
Converts 24-bit raw data to milivolts.
Definition: ad7193.c:671
uint8_t bpdsw_mode
Definition: ad7193.h:217
ad7193_adc_range
Definition: ad7193.h:148
int ad7193_clock_select(struct ad7193_dev *dev, enum ad7193_adc_clock clk_select)
Selects the clock source of the ADC.
Definition: ad7193.c:483
@ AD7193_INT_CLK_4_92_MHZ_TRIST
Definition: ad7193.h:164
#define AD7193_REG_ID
Definition: ad7193.h:64
int ad7193_set_operating_mode(struct ad7193_dev *dev, enum ad7193_adc_modes opt_mode)
Sets device into the specified operating mode.
Definition: ad7193.c:305
Structure holding the parameters for GPIO initialization.
Definition: gpio.h:71
@ AD7193_ADC_156_2_mV
Definition: ad7193.h:152
int ad7193_continuous_read_avg(struct ad7193_dev *dev, uint8_t sample_number, uint32_t *samples_avg)
Returns the average of several conversion results.
Definition: ad7193.c:596
#define AD7193_REG_DATA
Definition: ad7193.h:63
int ad7193_set_bridge_switch(struct ad7193_dev *dev, uint8_t bpdsw_select)
Opens or closes the bridge power-down switch of the ADC.
Definition: ad7193.c:510
int ad7193_continuous_read_avg(struct ad7193_dev *dev, uint8_t sample_number, uint32_t *samples_avg)
Returns the average of several conversion results.
Definition: ad7193.c:596
int ad7193_set_masked_register_value(struct ad7193_dev *dev, uint8_t reg_addr, uint32_t mask, uint32_t reg_data, uint8_t bytes)
Write masked data into device register.
Definition: ad7193.c:248
float ad7193_convert_to_volts(struct ad7193_dev *dev, uint32_t raw_data, float v_ref)
Converts 24-bit raw data to milivolts.
Definition: ad7193.c:671
spi_desc * spi_desc
Definition: ad7193.h:190
Structure holding the parameters for SPI initialization.
Definition: spi.h:112
struct gpio_init_param gpio_miso
Definition: ad7193.h:208
#define AD7193_CH_TEMP
Definition: ad7193.h:125
uint8_t current_polarity
Definition: ad7193.h:210
int ad7193_reset(struct ad7193_dev *dev)
Resets the device.
Definition: ad7193.c:273
#define AD7193_CONF_PSEUDO
Definition: ad7193.h:107
int ad7193_wait_rdy_go_low(struct ad7193_dev *dev)
Waits for RDY pin to go low.
Definition: ad7193.c:327
uint8_t current_polarity
Definition: ad7193.h:194
#define AD7193_CONF_UNIPOLAR
Definition: ad7193.h:112
int ad7193_output_rate_select(struct ad7193_dev *dev, uint16_t out_rate_code)
Selects the filter output data rate of the ADC.
Definition: ad7193.c:454
@ AD7193_MODE_CONT
Definition: ad7193.h:171
Header file of Delay functions.
@ AD7193_ADC_312_5_mV
Definition: ad7193.h:151
#define AD7193_ID_MASK
Definition: ad7193.h:130
@ AD7193_MODE_PWRDN
Definition: ad7193.h:177
Structure holding the GPIO descriptor.
Definition: gpio.h:84
#define AD7193_COMM_WRITE
Definition: ad7193.h:71
int ad7193_channels_select(struct ad7193_dev *dev, uint16_t chn_mask)
Selects the channels to be enabled.
Definition: ad7193.c:355
@ AD7193_MODE_SINGLE
Definition: ad7193.h:173
enum ad7193_adc_modes operating_mode
Definition: ad7193.h:212
void udelay(uint32_t usecs)
Wait until usecs microseconds passed.
Definition: delay.c:117
int32_t gpio_direction_input(struct gpio_desc *desc)
Enable the input direction of the specified GPIO.
Definition: gpio.c:108
@ AD7193_EXT_CRYSTAL_MCLK1_MCLK2
Definition: ad7193.h:160
ad7193_adc_clock
Definition: ad7193.h:158
int32_t gpio_get(struct gpio_desc **desc, const struct gpio_init_param *param)
Obtain the GPIO decriptor.
Definition: gpio.c:55
int ad7193_buffer_select(struct ad7193_dev *dev, uint8_t buff_en)
Enables or disables the buffer on the ADC input channels.
Definition: ad7193.c:430
int ad7193_calibrate(struct ad7193_dev *dev, uint8_t mode, uint8_t channel)
Performs the given calibration to the specified channel.
Definition: ad7193.c:376
@ AD7193_EXT_CRYSTAL_MCLK2
Definition: ad7193.h:162
Header file of AD7193 Driver.
enum ad7193_adc_clock clock_source
Definition: ad7193.h:198
#define AD7193_REG_MODE
Definition: ad7193.h:61
int ad7193_set_masked_register_value(struct ad7193_dev *dev, uint8_t reg_addr, uint32_t mask, uint32_t data, uint8_t bytes)
Write masked data into device register.
Definition: ad7193.c:248
uint16_t data_rate_code
Definition: ad7193.h:197
@ AD7193_ADC_39_06mV
Definition: ad7193.h:154
Header file of GPIO Interface.
uint8_t buffer
Definition: ad7193.h:216
enum ad7193_adc_range current_gain
Definition: ad7193.h:211
@ AD7193_MODE_CAL_SYS_ZERO
Definition: ad7193.h:183
#define SUCCESS
Definition: error.h:52
struct ad7616_init_param init_param
Definition: ad7616_sdz.c:96
uint8_t input_mode
Definition: ad7193.h:199
uint8_t input_mode
Definition: ad7193.h:215
enum ad7193_adc_range current_gain
Definition: ad7193.h:195
#define AD7193_REG_CONF
Definition: ad7193.h:62
int ad7193_config_input_mode(struct ad7193_dev *dev, uint8_t mode)
Configures the input mode of the ADC.
Definition: ad7193.c:404
int ad7193_buffer_select(struct ad7193_dev *dev, uint8_t buff_en)
Enables or disables the buffer on the ADC input channels.
Definition: ad7193.c:430
int ad7193_calibrate(struct ad7193_dev *dev, uint8_t mode, uint8_t channel)
Performs the given calibration to the specified channel.
Definition: ad7193.c:376
#define AD7193_CONF_CHAN(x)
Definition: ad7193.h:108
int ad7193_clock_select(struct ad7193_dev *dev, enum ad7193_adc_clock clk_select)
Selects the clock source of the ADC.
Definition: ad7193.c:483
#define AD7193_MODE_CLKSRC(x)
Definition: ad7193.h:89
uint16_t data_rate_code
Definition: ad7193.h:213
int ad7193_init(struct ad7193_dev **device, struct ad7193_init_param init_param)
Initializes the communication peripheral and the initial Values for AD7193 Board and resets the devic...
Definition: ad7193.c:62
int ad7193_set_operating_mode(struct ad7193_dev *dev, enum ad7193_adc_modes opt_mode)
Sets device into the specified operating mode.
Definition: ad7193.c:305
int32_t gpio_remove(struct gpio_desc *desc)
Free the resources allocated by gpio_get().
Definition: gpio.c:95
int32_t spi_init(struct spi_desc **desc, const struct spi_init_param *param)
Initialize the SPI communication peripheral.
Definition: spi.c:51
int32_t gpio_get_value(struct gpio_desc *desc, uint8_t *value)
Get the value of the specified GPIO.
Definition: gpio.c:177
@ AD7193_MODE_CAL_INT_ZERO
Definition: ad7193.h:179
uint8_t buffer
Definition: ad7193.h:200
@ AD7193_ADC_78_125mV
Definition: ad7193.h:153
#define AD7193_CH_MASK(x)
Definition: ad7193.h:142
ad7193_adc_modes
Definition: ad7193.h:169
spi_init_param spi_init
Definition: ad7193.h:206
int ad7193_single_conversion(struct ad7193_dev *dev, uint32_t *reg_data)
Returns the result of a single conversion.
Definition: ad7193.c:565
Implementation of utility functions.
#define AD7193_COMM_ADDR(x)
Definition: ad7193.h:73
#define FAILURE
Definition: error.h:56
struct gpio_desc * gpio_miso
Definition: ad7193.h:192
#define ID_AD7193
Definition: ad7193.h:129
int ad7193_reset(struct ad7193_dev *dev)
Resets the device.
Definition: ad7193.c:273
#define AD7193_COMM_READ
Definition: ad7193.h:72
int ad7193_wait_rdy_go_low(struct ad7193_dev *dev)
Waits for RDY pin to go low.
Definition: ad7193.c:327
#define AD7193_CONF_BUF
Definition: ad7193.h:111