no-OS
ad4170.h
Go to the documentation of this file.
1 /***************************************************************************/
39 #ifndef AD4170_H_
40 #define AD4170_H_
41 
42 #include <stdint.h>
43 #include <stdbool.h>
44 #include "no_os_util.h"
45 #include "no_os_gpio.h"
46 #include "no_os_spi.h"
47 
48 #ifndef ECOMM
49 #define ECOMM 70
50 #endif
51 
52 #define AD4170_R1B (1ul << 16)
53 #define AD4170_R2B (2ul << 16)
54 #define AD4170_R3B (3ul << 16)
55 #define AD4170_R4B (4ul << 16)
56 #define AD4170_TRANSF_LEN(x) ((x) >> 16)
57 #define AD4170_ADDR(x) ((x) & 0xFFFF)
58 
59 #define AD4170_SPI_SYNC_PATTERN 0x2645
60 
61 #define AD4170_REG_READ_6(x) (((x) & 0x3F) | 0x40)
62 #define AD4170_REG_WRITE_6(x) ((x) & 0x3F)
63 #define AD4170_REG_READ_14(x) (((x) & 0x3FFF) | 0x4000)
64 #define AD4170_REG_WRITE_14(x) ((x) & 0x3FFF)
65 #define AD4170_REG_INTERFACE_CONFIG_A (AD4170_R1B | 0x00)
66 #define AD4170_REG_INTERFACE_CONFIG_B (AD4170_R1B | 0x01)
67 #define AD4170_REG_DEVICE_CONFIG (AD4170_R1B | 0x02)
68 #define AD4170_REG_CHIP_TYPE (AD4170_R1B | 0x03)
69 #define AD4170_REG_PRODUCT_ID_L (AD4170_R1B | 0x04)
70 #define AD4170_REG_PRODUCT_ID_H (AD4170_R1B | 0x05)
71 #define AD4170_REG_CHIP_GRADE (AD4170_R1B | 0x06)
72 #define AD4170_REG_SCRATCH_PAD (AD4170_R1B | 0x0a)
73 #define AD4170_REG_SPI_REVISION (AD4170_R1B | 0x0b)
74 #define AD4170_REG_VENDOR_L (AD4170_R1B | 0x0c)
75 #define AD4170_REG_VENDOR_H (AD4170_R1B | 0x0d)
76 #define AD4170_REG_INTERFACE_CONFIG_C (AD4170_R1B | 0x10)
77 #define AD4170_REG_INTERFACE_STATUS_A (AD4170_R1B | 0x11)
78 #define AD4170_REG_DATA_STATUS (AD4170_R2B | 0x14)
79 #define AD4170_REG_DATA_16b (AD4170_R2B | 0x16)
80 #define AD4170_REG_DATA_16b_STATUS (AD4170_R3B | 0x18)
81 #define AD4170_REG_DATA_24b (AD4170_R3B | 0x1c)
82 #define AD4170_REG_DATA_24b_STATUS (AD4170_R4B | 0x20)
83 #define AD4170_REG_DATA_32b (AD4170_R4B | 0x24)
84 #define AD4170_REG_DATA_PER_CHANNEL(ch) (AD4170_R4B | (0x28 + 4 * (ch)))
85 #define AD4170_REG_PIN_MUXING (AD4170_R2B | 0x68)
86 #define AD4170_REG_CLOCK_CTRL (AD4170_R2B | 0x6a)
87 #define AD4170_REG_STANDBY_CTRL (AD4170_R2B | 0x6c)
88 #define AD4170_REG_POWER_DOWN_SW (AD4170_R2B | 0x6e)
89 #define AD4170_REG_ADC_CTRL (AD4170_R2B | 0x70)
90 #define AD4170_REG_ERROR_EN (AD4170_R2B | 0x72)
91 #define AD4170_REG_ERROR (AD4170_R2B | 0x74)
92 #define AD4170_REG_CHANNEL_EN (AD4170_R2B | 0x78)
93 #define AD4170_REG_ADC_CHANNEL_SETUP(ch) (AD4170_R2B | (0x80 + 4 * (ch)))
94 #define AD4170_REG_ADC_CHANNEL_MAP(ch) (AD4170_R2B | (0x82 + 4 * (ch)))
95 #define AD4170_REG_ADC_SETUPS_MISC(n) (AD4170_R2B | (0xc0 + 14 * (n)))
96 #define AD4170_REG_ADC_SETUPS_AFE(n) (AD4170_R2B | (0xc2 + 14 * (n)))
97 #define AD4170_REG_ADC_SETUPS_FILTER(n) (AD4170_R2B | (0xc4 + 14 * (n)))
98 #define AD4170_REG_ADC_SETUPS_FILTER_FS(n) (AD4170_R2B | (0xc6 + 14 * (n)))
99 #define AD4170_REG_ADC_SETUPS_OFFSET(n) (AD4170_R3B | (0xc8 + 14 * (n)))
100 #define AD4170_REG_ADC_SETUPS_GAIN(n) (AD4170_R3B | (0xcb + 14 * (n)))
101 #define AD4170_REG_REF_CONTROL (AD4170_R2B | 0x130)
102 #define AD4170_REG_V_BIAS (AD4170_R2B | 0x134)
103 #define AD4170_REG_I_PULLUP (AD4170_R2B | 0x136)
104 #define AD4170_REG_CURRENT_SOURCE(n) (AD4170_R2B | (0x138 + 2 * (n)))
105 #define AD4170_REG_FIR_CONTROL (AD4170_R2B | 0x140)
106 #define AD4170_REG_COEFF_WRITE_DATA (AD4170_R4B | 0x143)
107 #define AD4170_REG_COEFF_READ_DATA (AD4170_R4B | 0x147)
108 #define AD4170_REG_COEFF_ADDRESS (AD4170_R2B | 0x14b)
109 #define AD4170_REG_COEFF_WRRD_STB (AD4170_R2B | 0x14d)
110 #define AD4170_REG_DAC_SPAN (AD4170_R2B | 0x150)
111 #define AD4170_REG_DAC_CHANNEL_EN (AD4170_R2B | 0x152)
112 #define AD4170_REG_DAC_HW_TOGGLE_MASK (AD4170_R2B | 0x154)
113 #define AD4170_REG_DAC_HW_LDAC_MASK (AD4170_R2B | 0x156)
114 #define AD4170_REG_DAC_DATA(ch) (AD4170_R2B | (0x158 + 2 * (ch)))
115 #define AD4170_REG_DAC_SW_TOGGLE_TRIGGERS (AD4170_R2B | 0x168)
116 #define AD4170_REG_DAC_SW_LDAC_TRIGGERS (AD4170_R2B | 0x16a)
117 #define AD4170_REG_DAC_INPUTA(ch) (AD4170_R2B | (0x16c + 2 * (ch)))
118 #define AD4170_REG_DAC_INPUTB(ch) (AD4170_R2B | (0x17c + 2 * (ch)))
119 #define AD4170_REG_GPIO_MODE (AD4170_R2B | 0x190)
120 #define AD4170_REG_OUTPUT_DATA (AD4170_R2B | 0x192)
121 #define AD4170_REG_INPUT_DATA (AD4170_R2B | 0x194)
122 
123 /* AD4170_REG_INTERFACE_CONFIG_A */
124 #define AD4170_SW_RESET_MSK NO_OS_BIT(7)
125 #define AD4170_ADDR_ASCENSION_MSK NO_OS_BIT(5)
126 #define AD4170_SDO_ENABLE_MSK NO_OS_BIT(4)
127 #define AD4170_SW_RESETX_MSK NO_OS_BIT(0)
128 
129 /* AD4170_REG_INTERFACE_CONFIG_B */
130 #define AD4170_INTERFACE_CONFIG_B_SINGLE_INST_MSK NO_OS_BIT(7)
131 #define AD4170_INTERFACE_CONFIG_B_SHORT_INSTRUCTION_MSK NO_OS_BIT(3)
132 #define AD4170_INTERFACE_CONFIG_B_SHORT_INSTRUCTION(x) (((x) & 0x1) << 3)
133 
134 /* AD4170_REG_INTERFACE_CONFIG_C */
135 #define AD4170_INTERFACE_CONFIG_C_CRC_MSK (NO_OS_BIT(7) | NO_OS_BIT(6) | NO_OS_BIT(1) | NO_OS_BIT(0))
136 #define AD4170_INTERFACE_CONFIG_C_CRC(x) (((~x) & 0x3) | (((x) << 6) & 0xC0))
137 #define AD4170_INTERFACE_CONFIG_C_STRICT_REG_ACCESS_MSK NO_OS_BIT(5)
138 #define AD4170_INTERFACE_CONFIG_C_STRICT_REG_ACCESS(x) (((x) & 0x1) << 5)
139 #define AD4170_CRC8_POLYNOMIAL 0x7
140 #define AD4170_CRC8_INITIAL_VALUE 0xA5
141 
142 /* AD4170_REG_INTERFACE_STATUS_A */
143 #define AD4170_INTERFACE_STATUS_A_NOT_READY_ERR_MSK NO_OS_BIT(7)
144 #define AD4170_INTERFACE_STATUS_A_CLOCK_COUNT_ERR_MSK NO_OS_BIT(4)
145 #define AD4170_INTERFACE_STATUS_A_CRC_ERR_MSK NO_OS_BIT(3)
146 #define AD4170_INTERFACE_STATUS_A_INVALID_ACCESS_ERR_MSK NO_OS_BIT(2)
147 #define AD4170_INTERFACE_STATUS_A_PARTIAL_ACCESS_ERR_MSK NO_OS_BIT(1)
148 #define AD4170_INTERFACE_STATUS_A_ADDR_INVALID_ERR_MSK NO_OS_BIT(0)
149 
150 /* AD4170_REG_PRODUCT_ID */
151 #define AD4170_PRODUCT_ID_L_VALUE 0x40
152 #define AD4170_PRODUCT_ID_H_VALUE 0x0
153 
154 /* AD4190_REG_PRODUCT_ID */
155 #define AD4190_PRODUCT_ID_L_VALUE 0x48
156 #define AD4190_PRODUCT_ID_H_VALUE 0x0
157 
158 /* AD4170_REG_DATA_STATUS */
159 #define AD4170_DATA_STATUS_MASTER_ERR_S_MSK NO_OS_BIT(7)
160 #define AD4170_DATA_STATUS_POR_FLAG_S_MSK NO_OS_BIT(6)
161 #define AD4170_DATA_STATUS_RDYB_MSK NO_OS_BIT(5)
162 #define AD4170_DATA_STATUS_SETTLED_FIR_MSK NO_OS_BIT(4)
163 #define AD4170_DATA_STATUS_CH_ACTIVE_MSK NO_OS_GENMASK(3,0)
164 
165 /* AD4170_REG_PIN_MUXING */
166 #define AD4170_PIN_MUXING_CHAN_TO_GPIO_MSK NO_OS_BIT(14)
167 #define AD4170_PIN_MUXING_DIG_AUX2_CTRL_MSK NO_OS_GENMASK(7,6)
168 #define AD4170_PIN_MUXING_DIG_AUX1_CTRL_MSK NO_OS_GENMASK(5,4)
169 #define AD4170_PIN_MUXING_SYNC_CTRL_MSK NO_OS_GENMASK(3,2)
170 #define AD4170_PIN_MUXING_DIG_OUT_STR_MSK NO_OS_BIT(1)
171 #define AD4170_PIN_MUXING_SDO_RDBY_DLY_MSK NO_OS_BIT(0)
172 
173 /* AD4170_REG_CLOCK_CTRL */
174 #define AD4170_CLOCK_CTRL_DCLK_DIVIDE_MSK NO_OS_GENMASK(7,6)
175 #define AD4170_CLOCK_CTRL_CLOCKDIV_MSK NO_OS_GENMASK(5,4)
176 #define AD4170_CLOCK_CTRL_CLOCKSEL_MSK NO_OS_GENMASK(1,0)
177 
178 /* AD4170_REG_STANDBY_CTRL */
179 #define AD4170_STANDBY_CTRL_STB_EN_CLOCK_MSK NO_OS_BIT(8)
180 #define AD4170_STANDBY_CTRL_STB_EN_IPULLUP_MSK NO_OS_BIT(7)
181 #define AD4170_STANDBY_CTRL_STB_EN_DIAGNOSTICS_MSK NO_OS_BIT(6)
182 #define AD4170_STANDBY_CTRL_STB_EN_DAC_MSK NO_OS_BIT(5)
183 #define AD4170_STANDBY_CTRL_STB_EN_PDSW1_MSK NO_OS_BIT(4)
184 #define AD4170_STANDBY_CTRL_STB_EN_PDSW0_MSK NO_OS_BIT(3)
185 #define AD4170_STANDBY_CTRL_STB_EN_VBIAS_MSK NO_OS_BIT(2)
186 #define AD4170_STANDBY_CTRL_STB_EN_IEXC_MSK NO_OS_BIT(1)
187 #define AD4170_STANDBY_CTRL_STB_EN_REFERENCE_MSK NO_OS_BIT(0)
188 
189 /* AD4170_REG_POWER_DOWN_SW */
190 #define AD4170_POWER_DOWN_SW_PDSW1_MSK NO_OS_BIT(1)
191 #define AD4170_POWER_DOWN_SW_PDSW0_MSK NO_OS_BIT(0)
192 
193 /* AD4170_REG_ADC_CTRL */
194 #define AD4170_ADC_CTRL_PARALLEL_FILT_EN_MSK NO_OS_BIT(8)
195 #define AD4170_ADC_CTRL_MULTI_DATA_REG_SEL_MSK NO_OS_BIT(7)
196 #define AD4170_ADC_CTRL_CONT_READ_STATUS_EN_MSK NO_OS_BIT(6)
197 #define AD4170_REG_CTRL_CONT_READ_MSK NO_OS_GENMASK(5,4)
198 #define AD4170_REG_CTRL_MODE_MSK NO_OS_GENMASK(3,0)
199 
200 /* AD4170_REG_ERROR_EN and AD4170_REG_ERROR */
201 #define AD4170_ERROR_DEVICE_ERROR_MSK NO_OS_BIT(15)
202 #define AD4170_ERROR_DLDO_PSM_ERR_MSK NO_OS_BIT(13)
203 #define AD4170_ERROR_ALDO_PSM_ERR_MSK NO_OS_BIT(12)
204 #define AD4170_ERROR_IOUT3_COMP_ERR_MSK NO_OS_BIT(11)
205 #define AD4170_ERROR_IOUT2_COMP_ERR_MSK NO_OS_BIT(10)
206 #define AD4170_ERROR_IOUT1_COMP_ERR_MSK NO_OS_BIT(9)
207 #define AD4170_ERROR_IOUT0_COMP_ERR_MSK NO_OS_BIT(8)
208 #define AD4170_ERROR_REF_DIFF_MIN_ERR_MSK NO_OS_BIT(7)
209 #define AD4170_ERROR_REF_OV_UV_ERR_MSK NO_OS_BIT(6)
210 #define AD4170_ERROR_AINM_OV_UV_ERR_MSK NO_OS_BIT(5)
211 #define AD4170_ERROR_AINP_OV_UV_ERR_MSK NO_OS_BIT(4)
212 #define AD4170_ERROR_ADC_CONV_ERR_MSK NO_OS_BIT(3)
213 #define AD4170_ERROR_MM_CRC_ERR_MSK NO_OS_BIT(1)
214 #define AD4170_ERROR_ROM_CRC_ERR_MSK NO_OS_BIT(0)
215 
216 /* AD4170_REG_CHANNEL_EN */
217 #define AD4170_CHANNEL(ch) NO_OS_BIT(ch)
218 
219 /* AD4170_REG_ADC_CHANNEL_SETUP */
220 #define AD4170_CHANNEL_SETUPN_REPEAT_N_MSK NO_OS_GENMASK(15,8)
221 #define AD4170_CHANNEL_SETUPN_DELAY_N_MSK NO_OS_GENMASK(6,4)
222 #define AD4170_CHANNEL_SETUPN_SETUP_N_MSK NO_OS_GENMASK(2,0)
223 
224 /* AD4170_REG_ADC_CHANNEL_MAP */
225 #define AD4170_CHANNEL_MAPN_AINP_MSK NO_OS_GENMASK(12,8)
226 #define AD4170_CHANNEL_MAPN_AINM_MSK NO_OS_GENMASK(4,0)
227 
228 /* AD4170_REG_ADC_SETUPS_MISC */
229 #define AD4170_ADC_SETUPS_MISC_CHOP_IEXC_MSK NO_OS_GENMASK(15,14)
230 #define AD4170_ADC_SETUPS_MISC_CHOP_ADC_MSK NO_OS_GENMASK(9,8)
231 #define AD4170_ADC_SETUPS_MISC_BURNOUT_MSK NO_OS_GENMASK(1,0)
232 
233 /* AD4170_REG_ADC_SETUPS_AFE */
234 #define AD4170_ADC_SETUPS_AFE_REF_BUF_M_MSK NO_OS_GENMASK(11,10)
235 #define AD4170_ADC_SETUPS_AFE_REF_BUF_P_MSK NO_OS_GENMASK(9,8)
236 #define AD4170_ADC_SETUPS_AFE_REF_SELECT_MSK NO_OS_GENMASK(6,5)
237 #define AD4170_ADC_SETUPS_AFE_BIPOLAR_MSK NO_OS_BIT(4)
238 #define AD4170_ADC_SETUPS_AFE_PGA_GAIN_MSK NO_OS_GENMASK(3,0)
239 
240 /* AD4170_REG_ADC_SETUPS_FILTER */
241 #define AD4170_ADC_SETUPS_POST_FILTER_SEL_MSK NO_OS_GENMASK(7,4)
242 #define AD4170_ADC_SETUPS_FILTER_TYPE_MSK NO_OS_GENMASK(3,0)
243 
244 /* AD4170_REG_CURRENT_SOURCE */
245 #define AD4170_CURRENT_SOURCE_I_OUT_PIN_MSK NO_OS_GENMASK(12,8)
246 #define AD4170_CURRENT_SOURCE_I_OUT_VAL_MSK NO_OS_GENMASK(2,0)
247 
248 /* AD4170_REG_REF_CONTROL */
249 #define AD4170_REF_CONTROL_REF_EN_MSK NO_OS_BIT(0)
250 
251 /* AD4170_REG_FIR_CONTROL */
252 #define AD4170_FIR_CONTROL_IIR_MODE_MSK NO_OS_BIT(15)
253 #define AD4170_FIR_CONTROL_FIR_MODE_MSK NO_OS_GENMASK(14,12)
254 #define AD4170_FIR_CONTROL_COEFF_SET_MSK NO_OS_BIT(10)
255 #define AD4170_FIR_CONTROL_FIR_LENGTH_MSK NO_OS_GENMASK(6,0)
256 
257 /* AD4170_REG_DAC_SPAN */
258 #define AD4170_REG_DAC_SPAN_DAC_GAIN_MSK NO_OS_BIT(0)
259 
260 /* AD4170_REG_DAC_CHANNEL_EN */
261 #define AD4170_REG_DAC_CHANNEL_EN_DAC_EN_MSK NO_OS_BIT(0)
262 
263 /* AD4170_REG_DAC_HW_TOGGLE_MASK */
264 #define AD4170_REG_DAC_HW_TOGGLE_MASK_HW_TOGGLE_EN_MSK NO_OS_BIT(0)
265 
266 /* AD4170_REG_DAC_HW_LDAC_MASK */
267 #define AD4170_REG_DAC_HW_LDAC_MASK_HW_LDAC_EN_MSK NO_OS_BIT(0)
268 
269 /* AD4170_REG_DAC_DATA */
270 #define AD4170_REG_DAC_DATA_MSK NO_OS_GENMASK(11,0)
271 
272 /* AD4170_REG_DAC_SW_TOGGLE_TRIGGERS */
273 #define AD4170_REG_DAC_SW_TOGGLE_TRIGGERS_SW_TOGGLE_MSK NO_OS_BIT(0)
274 
275 /* AD4170_REG_DAC_SW_LDAC_TRIGGERS */
276 #define AD4170_REG_DAC_SW_LDAC_TRIGGERS_SW_LDAC_EN_MSK NO_OS_BIT(0)
277 
278 #define AD4170_NUM_CHANNELS 16
279 #define AD4170_NUM_SETUPS 8
280 #define AD4170_NUM_CURRENT_SOURCE 4
281 #define AD4170_FIR_COEFF_MAX_LENGTH 72
282 
292 };
293 
307 };
308 
322 };
323 
335 };
336 
346 };
347 
357 };
358 
376 };
377 
391 };
392 
406 };
407 
421 };
422 
434 };
435 
447 };
448 
476 };
477 
493 };
494 
516 };
517 
557 };
558 
565  uint8_t repeat_n;
569  uint8_t setup_n;
570 };
571 
581 };
582 
596 };
597 
611 };
612 
626 };
627 
632 struct ad4170_misc {
639 };
640 
652 };
653 
667 };
668 
694 };
695 
700 struct ad4170_afe {
708  bool bipolar;
711 };
712 
734 };
735 
747 };
748 
758 };
759 
764 struct ad4170_setup {
767  struct ad4170_afe afe;
771  uint16_t filter_fs;
773  uint32_t offset;
775  uint32_t gain;
776 };
777 
784  bool ref_en;
785 };
786 
834 };
835 
857 };
858 
866 };
867 
885 };
886 
892  /* FIR set 0. Use coefficient addresses 0 to FIR_LENGTH-1 */
894  /* FIR set 1. Use coefficient addresses 72 to 72 + FIR_LENGTH-1 */
896 };
897 
908  uint8_t fir_length;
911 };
912 
922 };
923 
930  bool enabled;
934  bool hw_toggle;
936  bool hw_ldac;
937 };
938 
949  uint16_t standby_ctrl;
951  uint16_t powerdown_sw;
953  uint16_t error_en;
957  uint16_t channel_en;
967  uint16_t v_bias;
969  uint16_t i_pullup;
976 };
977 
989 };
990 
995 enum ad4170_id {
1000 };
1001 
1013  /* Rdy GPIO (EOC) monitor timeout loop counter */
1023 };
1024 
1029 struct ad4170_dev {
1038  /* Rdy GPIO (EOC) monitor timeout loop counter */
1059  bool digif;
1060 };
1061 
1063 extern struct ad4170_config ad4170_config_reset;
1064 
1065 int ad4170_spi_reg_read(struct ad4170_dev *dev,
1066  uint32_t reg_addr,
1067  uint32_t *reg_data);
1068 int ad4170_spi_reg_write(struct ad4170_dev *dev,
1069  uint32_t reg_addr,
1070  uint32_t reg_data);
1071 int ad4170_spi_reg_write_mask(struct ad4170_dev *dev,
1072  uint32_t reg_addr,
1073  uint8_t mask,
1074  uint32_t reg_data);
1075 int ad4170_reset_spi_interface(struct ad4170_dev *dev);
1076 int ad4170_get_data16(struct ad4170_dev *dev, uint16_t *data);
1077 int ad4170_get_data16s(struct ad4170_dev *dev, uint16_t *data,
1078  uint8_t *status);
1079 int ad4170_get_data24(struct ad4170_dev *dev, uint32_t *data);
1080 int ad4170_get_data24s(struct ad4170_dev *dev, uint32_t *data,
1081  uint8_t *status);
1082 int ad4170_get_data32(struct ad4170_dev *dev, uint32_t *data);
1083 int ad4170_get_ch_data(struct ad4170_dev *dev, uint8_t ch, uint32_t *data);
1084 int ad4170_read16(struct ad4170_dev *dev, uint32_t *pbuf,
1085  uint16_t nb_samples);
1086 int ad4170_read16s(struct ad4170_dev *dev, uint32_t *pbuf,
1087  uint16_t nb_samples);
1088 int ad4170_read24(struct ad4170_dev *dev, uint32_t *pbuf,
1089  uint16_t nb_samples);
1090 int ad4170_read24s(struct ad4170_dev *dev, uint32_t *pbuf,
1091  uint16_t nb_samples);
1092 int ad4170_read32(struct ad4170_dev *dev, uint32_t *pbuf,
1093  uint16_t nb_samples);
1094 int ad4170_continuous_read(struct ad4170_dev *dev, uint32_t *data_out,
1095  uint8_t *status_out, uint16_t nb_samples);
1096 int ad4170_continuous_read_exit(struct ad4170_dev *dev);
1098 int ad4170_reset(struct ad4170_dev *dev);
1099 int ad4170_get_status(struct ad4170_dev *dev, uint16_t *status);
1100 int ad4170_set_pin_muxing(struct ad4170_dev *dev,
1101  struct ad4170_pin_muxing pin_muxing);
1102 int ad4170_set_dclk_div(struct ad4170_dev *dev,
1103  enum ad4170_dclk_div clk_div);
1104 int ad4170_set_mclk_div(struct ad4170_dev *dev,
1105  enum ad4170_mclk_div clk_div);
1106 int ad4170_set_clocksel(struct ad4170_dev *dev, enum ad4170_clocksel sel);
1107 int ad4170_set_standby_ctrl(struct ad4170_dev *dev, uint16_t standby_ctrl);
1108 int ad4170_set_powerdown_sw(struct ad4170_dev *dev, uint16_t powerdown_sw);
1109 int ad4170_set_error_en(struct ad4170_dev *dev, uint16_t error_en);
1110 int ad4170_set_error(struct ad4170_dev *dev, uint16_t error);
1111 int ad4170_get_error(struct ad4170_dev *dev, uint16_t *error);
1112 int ad4170_set_adc_ctrl(struct ad4170_dev *dev,
1113  struct ad4170_adc_ctrl adc_ctrl);
1114 int ad4170_set_channel_en(struct ad4170_dev *dev, uint16_t channel_en);
1115 int ad4170_set_channel_setup(struct ad4170_dev *dev, uint8_t ch,
1116  struct ad4170_channel_setup setup);
1117 int ad4170_set_channel_map(struct ad4170_dev *dev, uint8_t ch,
1118  struct ad4170_channel_map map);
1119 int ad4170_set_setup(struct ad4170_dev *dev, uint8_t n,
1120  struct ad4170_setup setup);
1121 int ad4170_set_ref_control(struct ad4170_dev *dev, bool enable);
1122 int ad4170_set_v_bias(struct ad4170_dev *dev, uint16_t ch_mask);
1123 int ad4170_set_i_pullup(struct ad4170_dev *dev, uint16_t ch_mask);
1124 int ad4170_set_current_source(struct ad4170_dev *dev, uint8_t n,
1126 int ad4170_set_fir_control(struct ad4170_dev *dev,
1128 int ad4170_set_dac_config(struct ad4170_dev *dev,
1129  struct ad4170_dac_config config);
1130 int ad4170_set_dac_data(struct ad4170_dev *dev, uint16_t code);
1131 int ad4170_set_dac_inputa(struct ad4170_dev *dev, uint16_t code);
1132 int ad4170_set_dac_inputb(struct ad4170_dev *dev, uint16_t code);
1133 int ad4170_dac_sw_ldac(struct ad4170_dev *dev, bool polarity);
1134 int ad4170_dac_sw_toggle(struct ad4170_dev *dev, bool polarity);
1135 int ad4170_dac_hw_toggle(struct ad4170_dev *dev, bool polarity);
1136 int ad4170_init(struct ad4170_dev **device,
1137  struct ad4170_init_param *init_param);
1138 int ad4170_remove(struct ad4170_dev *dev);
1139 int ad4170_regmap(struct ad4170_dev *dev);
1140 #endif
1141 
AD4170_ADC_SETUPS_AFE_REF_BUF_P_MSK
#define AD4170_ADC_SETUPS_AFE_REF_BUF_P_MSK
Definition: ad4170.h:235
ad4170_set_pin_muxing
int ad4170_set_pin_muxing(struct ad4170_dev *dev, struct ad4170_pin_muxing pin_muxing)
Set the AD4170 Pin Muxing settings.
Definition: ad4170.c:1049
ad4170_init_param::spi_settings
struct ad4170_spi_settings spi_settings
Definition: ad4170.h:1012
AD4170_DCLKDIVBY8
@ AD4170_DCLKDIVBY8
Definition: ad4170.h:390
ad4170_pga_gain
ad4170_pga_gain
PGA Gain Selection.
Definition: ad4170.h:673
AD4170_CHANNEL_NOT_TO_GPIO
@ AD4170_CHANNEL_NOT_TO_GPIO
Definition: ad4170.h:289
AD4170_REG_FIR_CONTROL
#define AD4170_REG_FIR_CONTROL
Definition: ad4170.h:105
AD4170_I_OUT_AIN0
@ AD4170_I_OUT_AIN0
Definition: ad4170.h:793
AD4170_REG_DAC_HW_TOGGLE_MASK_HW_TOGGLE_EN_MSK
#define AD4170_REG_DAC_HW_TOGGLE_MASK_HW_TOGGLE_EN_MSK
Definition: ad4170.h:264
ad4170_fir_control::coeff_set
enum ad4170_fir_coeff_set coeff_set
Definition: ad4170.h:906
ad4170_config::adc_ctrl
struct ad4170_adc_ctrl adc_ctrl
Definition: ad4170.h:955
AD4170_REFIN1_P
@ AD4170_REFIN1_P
Definition: ad4170.h:551
ad4170_set_fir_control
int ad4170_set_fir_control(struct ad4170_dev *dev, struct ad4170_fir_control fir_control)
Set the AD4170 FIR control settings.
Definition: ad4170.c:1560
ad4170_config::ref_control
struct ad4170_ref_control ref_control
Definition: ad4170.h:965
AD4170_DLY_16384
@ AD4170_DLY_16384
Definition: ad4170.h:515
ad4170_read16
int ad4170_read16(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_16b.
Definition: ad4170.c:669
timeout
uint32_t timeout
Definition: ad413x.c:55
ad4170_dev::config
struct ad4170_config config
Definition: ad4170.h:1043
no_os_gpio_init_param
Structure holding the parameters for GPIO initialization.
Definition: no_os_gpio.h:85
ad4170_fir_control::fir_mode
enum ad4170_fir_mode fir_mode
Definition: ad4170.h:904
AD4170_REG_CURRENT_SOURCE
#define AD4170_REG_CURRENT_SOURCE(n)
Definition: ad4170.h:104
ad4170_filter
Filter register settings.
Definition: ad4170.h:753
ad4170_init_param::gpio_dig_aux2
struct no_os_gpio_init_param * gpio_dig_aux2
Definition: ad4170.h:1022
AD4170_FIR_ASYM
@ AD4170_FIR_ASYM
Definition: ad4170.h:884
ad4170_cont_read
ad4170_cont_read
Configures continuous Data Register Read/Transmit.
Definition: ad4170.h:440
AD4170_REG_DAC_SW_TOGGLE_TRIGGERS
#define AD4170_REG_DAC_SW_TOGGLE_TRIGGERS
Definition: ad4170.h:115
ad4170_config::dac
struct ad4170_dac_config dac
Definition: ad4170.h:975
ad4170_reset_spi_interface
int ad4170_reset_spi_interface(struct ad4170_dev *dev)
Reset the SPI interface by sending reset sequence to device.
Definition: ad4170.c:410
ad4170_set_dac_inputa
int ad4170_set_dac_inputa(struct ad4170_dev *dev, uint16_t code)
Set the AD4170 DAC data by writing the INPUTA register to be loaded separately by LDAC or Toggle oper...
Definition: ad4170.c:1693
ad4170_config::pin_muxing
struct ad4170_pin_muxing pin_muxing
Definition: ad4170.h:945
AD4170_PRODUCT_ID_H_VALUE
#define AD4170_PRODUCT_ID_H_VALUE
Definition: ad4170.h:152
ad4170_get_error
int ad4170_get_error(struct ad4170_dev *dev, uint16_t *error)
Get the Error register.
Definition: ad4170.c:1252
ad4170_set_dac_inputb
int ad4170_set_dac_inputb(struct ad4170_dev *dev, uint16_t code)
Set the AD4170 DAC data by writing the INPUTB register to be loaded separately by LDAC or Toggle oper...
Definition: ad4170.c:1705
ad4170_dev::id
enum ad4170_id id
Definition: ad4170.h:1031
AD4170_REF_BUF_PRE
@ AD4170_REF_BUF_PRE
Definition: ad4170.h:647
AD4170_REG_DAC_SPAN
#define AD4170_REG_DAC_SPAN
Definition: ad4170.h:110
AD4170_NUM_SETUPS
#define AD4170_NUM_SETUPS
Definition: ad4170.h:279
ad4170_dev::spi_init
struct no_os_spi_init_param spi_init
Definition: ad4170.h:1033
ad4170_set_channel_setup
int ad4170_set_channel_setup(struct ad4170_dev *dev, uint8_t ch, struct ad4170_channel_setup setup)
Set the AD4170 Channel specific setup.
Definition: ad4170.c:1336
AD4170_REG_ADC_SETUPS_FILTER_FS
#define AD4170_REG_ADC_SETUPS_FILTER_FS(n)
Definition: ad4170.h:98
ad4170_dev::gpio_sync_inb
struct no_os_gpio_desc * gpio_sync_inb
Definition: ad4170.h:1047
ad4170_init
int ad4170_init(struct ad4170_dev **device, struct ad4170_init_param *init_param)
Initialize an AD4170 device structure.
Definition: ad4170.c:1760
ad4170_fir_control
FIR_Control register settings.
Definition: ad4170.h:902
ad4170_setup::gain
uint32_t gain
Definition: ad4170.h:775
ad4170_continuous_read_exit
int ad4170_continuous_read_exit(struct ad4170_dev *dev)
Exit continuous read mode.
Definition: ad4170.c:919
AD4170_BURNOUT_10U
@ AD4170_BURNOUT_10U
Definition: ad4170.h:625
AD4170_I_OUT_AIN10
@ AD4170_I_OUT_AIN10
Definition: ad4170.h:813
AD4170_CLOCK_CTRL_CLOCKDIV_MSK
#define AD4170_CLOCK_CTRL_CLOCKDIV_MSK
Definition: ad4170.h:175
ad4170_i_out_val
ad4170_i_out_val
Current Source Value.
Definition: ad4170.h:840
ad4170_set_error
int ad4170_set_error(struct ad4170_dev *dev, uint16_t error)
Set the Error register with a value to clear specific errors.
Definition: ad4170.c:1241
AD4170_CHOP_OFF
@ AD4170_CHOP_OFF
Definition: ad4170.h:604
AD4170_MODE_POWER_DOWN
@ AD4170_MODE_POWER_DOWN
Definition: ad4170.h:465
ad4170_mode
ad4170_mode
ADC Operating Mode.
Definition: ad4170.h:453
ad4170_adc_ctrl
ADC_Ctrl register settings.
Definition: ad4170.h:482
AD4170_I_OUT_AIN4
@ AD4170_I_OUT_AIN4
Definition: ad4170.h:801
AD4170_PGA_GAIN_1_PRECHARGE
@ AD4170_PGA_GAIN_1_PRECHARGE
Definition: ad4170.h:693
ad4170_config::map
struct ad4170_channel_map map[AD4170_NUM_CHANNELS]
Definition: ad4170.h:961
AD4170_DIG_STR_DEFAULT
@ AD4170_DIG_STR_DEFAULT
Definition: ad4170.h:343
AD4170_CHOP_IEXC_AB
@ AD4170_CHOP_IEXC_AB
Definition: ad4170.h:591
AD4170_FIR_COEFF_SET0
@ AD4170_FIR_COEFF_SET0
Definition: ad4170.h:893
ad4170_set_clocksel
int ad4170_set_clocksel(struct ad4170_dev *dev, enum ad4170_clocksel sel)
Set the AD4170 clock selection configuration.
Definition: ad4170.c:1145
ad4170_filter_type
ad4170_filter_type
Filter Mode for Sinc-Based Filters.
Definition: ad4170.h:740
no_os_spi_write_and_read
int32_t no_os_spi_write_and_read(struct no_os_spi_desc *desc, uint8_t *data, uint16_t bytes_number)
Write and read data to/from SPI.
Definition: no_os_spi.c:165
AD4170_REFIN2_N
@ AD4170_REFIN2_N
Definition: ad4170.h:554
ad4170_config::setups
struct ad4170_setup setups[AD4170_NUM_SETUPS]
Definition: ad4170.h:963
AD4170_MODE_CONT_IIR
@ AD4170_MODE_CONT_IIR
Definition: ad4170.h:459
AD4170_REG_ADC_SETUPS_FILTER
#define AD4170_REG_ADC_SETUPS_FILTER(n)
Definition: ad4170.h:97
AD4170_FIR_CONTROL_FIR_MODE_MSK
#define AD4170_FIR_CONTROL_FIR_MODE_MSK
Definition: ad4170.h:253
AD4170_POST_FILTER_AVG16
@ AD4170_POST_FILTER_AVG16
Definition: ad4170.h:729
ad4170_get_data24s
int ad4170_get_data24s(struct ad4170_dev *dev, uint32_t *data, uint8_t *status)
Get data and status from register Data_24b_Status.
Definition: ad4170.c:506
AD4170_CHANNEL_SETUPN_DELAY_N_MSK
#define AD4170_CHANNEL_SETUPN_DELAY_N_MSK
Definition: ad4170.h:221
no_os_spi.h
Header file of SPI Interface.
ID_AD4170
@ ID_AD4170
Definition: ad4170.h:996
ad4170_set_spi_settings
int ad4170_set_spi_settings(struct ad4170_dev *dev, const struct ad4170_spi_settings *spi_settings)
Set the AD4170 SPI settings.
Definition: ad4170.c:1008
AD4170_REG_CHIP_TYPE
#define AD4170_REG_CHIP_TYPE
Definition: ad4170.h:68
ad4170_afe
AFE register settings.
Definition: ad4170.h:700
ad4170_get_ch_data
int ad4170_get_ch_data(struct ad4170_dev *dev, uint8_t ch, uint32_t *data)
Get data from register Data_Per_Channel[n].
Definition: ad4170.c:559
AD4170_REG_DAC_INPUTB
#define AD4170_REG_DAC_INPUTB(ch)
Definition: ad4170.h:118
AD4170_DIG_AUX2_LDAC
@ AD4170_DIG_AUX2_LDAC
Definition: ad4170.h:302
ad4170_set_ref_control
int ad4170_set_ref_control(struct ad4170_dev *dev, bool enable)
Set the AD4170 Ref Control.
Definition: ad4170.c:1465
ad4170_adc_ctrl::cont_read
enum ad4170_cont_read cont_read
Definition: ad4170.h:490
ad4170_pin_muxing::dig_aux1_ctrl
enum ad4170_dig_aux1_ctrl dig_aux1_ctrl
Definition: ad4170.h:369
AD4170_I_OUT_AIN8
@ AD4170_I_OUT_AIN8
Definition: ad4170.h:809
AD4170_REG_CTRL_CONT_READ_MSK
#define AD4170_REG_CTRL_CONT_READ_MSK
Definition: ad4170.h:197
AD4170_REG_CHIP_GRADE
#define AD4170_REG_CHIP_GRADE
Definition: ad4170.h:71
ad4170_read32
int ad4170_read32(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_32b.
Definition: ad4170.c:721
AD4170_ADC_SETUPS_MISC_CHOP_ADC_MSK
#define AD4170_ADC_SETUPS_MISC_CHOP_ADC_MSK
Definition: ad4170.h:230
AD4170_REG_WRITE_14
#define AD4170_REG_WRITE_14(x)
Definition: ad4170.h:64
AD4170_I_OUT_AIN1
@ AD4170_I_OUT_AIN1
Definition: ad4170.h:795
ad4170_setup::offset
uint32_t offset
Definition: ad4170.h:773
ad4170_set_fir_control
int ad4170_set_fir_control(struct ad4170_dev *dev, struct ad4170_fir_control fir_control)
Set the AD4170 FIR control settings.
Definition: ad4170.c:1560
AD4170_BURNOUT_OFF
@ AD4170_BURNOUT_OFF
Definition: ad4170.h:619
no_os_gpio_get_value
int32_t no_os_gpio_get_value(struct no_os_gpio_desc *desc, uint8_t *value)
Get the value of the specified GPIO.
Definition: no_os_gpio.c:227
ID_AD4172
@ ID_AD4172
Definition: ad4170.h:998
ad4170_setup::misc
struct ad4170_misc misc
Definition: ad4170.h:765
ad4170_dac_sw_ldac
int ad4170_dac_sw_ldac(struct ad4170_dev *dev, bool polarity)
Perform a software LDAC.
Definition: ad4170.c:1717
ad4170_get_data24s
int ad4170_get_data24s(struct ad4170_dev *dev, uint32_t *data, uint8_t *status)
Get data and status from register Data_24b_Status.
Definition: ad4170.c:506
AD4170_POST_FILTER_AVG20
@ AD4170_POST_FILTER_AVG20
Definition: ad4170.h:731
AD4170_ADC_CTRL_PARALLEL_FILT_EN_MSK
#define AD4170_ADC_CTRL_PARALLEL_FILT_EN_MSK
Definition: ad4170.h:194
ad4170_continuous_read_exit
int ad4170_continuous_read_exit(struct ad4170_dev *dev)
Exit continuous read mode.
Definition: ad4170.c:919
no_os_delay.h
Header file of Delay functions.
ad4170_read24
int ad4170_read24(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_24.
Definition: ad4170.c:695
ad4170_set_dclk_div
int ad4170_set_dclk_div(struct ad4170_dev *dev, enum ad4170_dclk_div div)
Set the AD4170 DCLK configuration.
Definition: ad4170.c:1085
AD4170_POST_FILTER_60MS
@ AD4170_POST_FILTER_60MS
Definition: ad4170.h:725
AD4170_I_OUT_1500UA
@ AD4170_I_OUT_1500UA
Definition: ad4170.h:856
AD4170_DATA_STATUS_POR_FLAG_S_MSK
#define AD4170_DATA_STATUS_POR_FLAG_S_MSK
Definition: ad4170.h:160
AD4170_CHANNEL_SETUPN_SETUP_N_MSK
#define AD4170_CHANNEL_SETUPN_SETUP_N_MSK
Definition: ad4170.h:222
AD4170_REG_POWER_DOWN_SW
#define AD4170_REG_POWER_DOWN_SW
Definition: ad4170.h:88
ad4170_set_error_en
int ad4170_set_error_en(struct ad4170_dev *dev, uint16_t error_en)
Set the AD4170 Error enable settings.
Definition: ad4170.c:1219
ad4170_init_param::gpio_dig_aux1
struct no_os_gpio_init_param * gpio_dig_aux1
Definition: ad4170.h:1020
AD4170_FIR_CONTROL_FIR_LENGTH_MSK
#define AD4170_FIR_CONTROL_FIR_LENGTH_MSK
Definition: ad4170.h:255
AD4170_I_OUT_250UA
@ AD4170_I_OUT_250UA
Definition: ad4170.h:850
ad4170_dev::gpio_dig_aux2
struct no_os_gpio_desc * gpio_dig_aux2
Definition: ad4170.h:1057
AD4170_EXTERNAL_OSC
@ AD4170_EXTERNAL_OSC
Definition: ad4170.h:418
ad4170_clock_ctrl::dclk_divide
enum ad4170_dclk_div dclk_divide
Definition: ad4170.h:429
ad4170_ref_buf
ad4170_ref_buf
REFIN Buffer Enable.
Definition: ad4170.h:645
ad4170_read24s
int ad4170_read24s(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_24_Status.
Definition: ad4170.c:708
AD4170_DLY_0
@ AD4170_DLY_0
Definition: ad4170.h:501
AD4170_NUM_CURRENT_SOURCE
#define AD4170_NUM_CURRENT_SOURCE
Definition: ad4170.h:280
AD4170_DIG_AUX2_SYNC
@ AD4170_DIG_AUX2_SYNC
Definition: ad4170.h:304
AD4170_REG_DAC_SPAN_DAC_GAIN_MSK
#define AD4170_REG_DAC_SPAN_DAC_GAIN_MSK
Definition: ad4170.h:258
AD4170_REF_BUF_FULL
@ AD4170_REF_BUF_FULL
Definition: ad4170.h:649
AD4170_AIN12
@ AD4170_AIN12
Definition: ad4170.h:535
AD4170_I_OUT_50UA
@ AD4170_I_OUT_50UA
Definition: ad4170.h:846
AD4170_PGA_GAIN_8
@ AD4170_PGA_GAIN_8
Definition: ad4170.h:681
AD4170_I_OUT_10UA
@ AD4170_I_OUT_10UA
Definition: ad4170.h:844
AD4170_AVDD_AVSS_P
@ AD4170_AVDD_AVSS_P
Definition: ad4170.h:542
device
Definition: ad9361_util.h:75
AD4170_CHOP_MUX
@ AD4170_CHOP_MUX
Definition: ad4170.h:606
AD4170_SPI_SYNC_PATTERN
#define AD4170_SPI_SYNC_PATTERN
Definition: ad4170.h:59
AD4170_ADC_SETUPS_MISC_CHOP_IEXC_MSK
#define AD4170_ADC_SETUPS_MISC_CHOP_IEXC_MSK
Definition: ad4170.h:229
AD4170_REG_READ_6
#define AD4170_REG_READ_6(x)
Definition: ad4170.h:61
AD4170_CLOCK_CTRL_DCLK_DIVIDE_MSK
#define AD4170_CLOCK_CTRL_DCLK_DIVIDE_MSK
Definition: ad4170.h:174
AD4170_SDO_RDY_CSB
@ AD4170_SDO_RDY_CSB
Definition: ad4170.h:356
NO_OS_GPIO_HIGH
@ NO_OS_GPIO_HIGH
Definition: no_os_gpio.h:123
AD4170_BURNOUT_100N
@ AD4170_BURNOUT_100N
Definition: ad4170.h:621
ad4170_afe::bipolar
bool bipolar
Definition: ad4170.h:708
ad4170_get_status
int ad4170_get_status(struct ad4170_dev *dev, uint16_t *status)
Get status from register Data_Status.
Definition: ad4170.c:582
AD4170_ADC_CTRL_MULTI_DATA_REG_SEL_MSK
#define AD4170_ADC_CTRL_MULTI_DATA_REG_SEL_MSK
Definition: ad4170.h:195
AD4170_REG_ADC_CHANNEL_SETUP
#define AD4170_REG_ADC_CHANNEL_SETUP(ch)
Definition: ad4170.h:93
AD4170_DCLKDIVBY1
@ AD4170_DCLKDIVBY1
Definition: ad4170.h:384
ad4170_dev::digif
bool digif
Definition: ad4170.h:1059
ad4170_config::standby_ctrl
uint16_t standby_ctrl
Definition: ad4170.h:949
AD4170_REG_ERROR_EN
#define AD4170_REG_ERROR_EN
Definition: ad4170.h:90
ad4170_pin_muxing::sdo_rdby_dly
enum ad4170_sdo_rdby_dly sdo_rdby_dly
Definition: ad4170.h:375
ad4170_set_mclk_div
int ad4170_set_mclk_div(struct ad4170_dev *dev, enum ad4170_mclk_div clk_div)
Set the AD4170 MCLK configuration.
Definition: ad4170.c:1115
AD4170_FILT_SINC3
@ AD4170_FILT_SINC3
Definition: ad4170.h:746
AD4170_REG_PRODUCT_ID_L
#define AD4170_REG_PRODUCT_ID_L
Definition: ad4170.h:69
AD4170_OPEN
@ AD4170_OPEN
Definition: ad4170.h:556
AD4170_AIN14
@ AD4170_AIN14
Definition: ad4170.h:537
ad4170_filter::filter_type
enum ad4170_filter_type filter_type
Definition: ad4170.h:757
AD4170_REG_DAC_SW_TOGGLE_TRIGGERS_SW_TOGGLE_MSK
#define AD4170_REG_DAC_SW_TOGGLE_TRIGGERS_SW_TOGGLE_MSK
Definition: ad4170.h:273
NO_OS_ARRAY_SIZE
#define NO_OS_ARRAY_SIZE(x)
Definition: no_os_util.h:53
AD4170_REG_ADC_CTRL
#define AD4170_REG_ADC_CTRL
Definition: ad4170.h:89
AD4170_CHOP_IEXC_OFF
@ AD4170_CHOP_IEXC_OFF
Definition: ad4170.h:589
no_os_gpio_direction_input
int32_t no_os_gpio_direction_input(struct no_os_gpio_desc *desc)
Enable the input direction of the specified GPIO.
Definition: no_os_gpio.c:130
ad4170_chop_iexc
ad4170_chop_iexc
Excitation Current Chopping Control.
Definition: ad4170.h:587
ad4170_set_standby_ctrl
int ad4170_set_standby_ctrl(struct ad4170_dev *dev, uint16_t standby_ctrl)
Set the AD4170 Standby control settings.
Definition: ad4170.c:1175
AD4170_POST_FILTER_AVG24
@ AD4170_POST_FILTER_AVG24
Definition: ad4170.h:733
AD4170_I_OUT_AINCOM
@ AD4170_I_OUT_AINCOM
Definition: ad4170.h:825
AD4170_DAC_GAIN_1
@ AD4170_DAC_GAIN_1
Definition: ad4170.h:919
AD4170_REG_DAC_INPUTA
#define AD4170_REG_DAC_INPUTA(ch)
Definition: ad4170.h:117
ad4170_config::clock_ctrl
struct ad4170_clock_ctrl clock_ctrl
Definition: ad4170.h:947
AD4170_ADC_SETUPS_FILTER_TYPE_MSK
#define AD4170_ADC_SETUPS_FILTER_TYPE_MSK
Definition: ad4170.h:242
ad4170_set_powerdown_sw
int ad4170_set_powerdown_sw(struct ad4170_dev *dev, uint16_t powerdown_sw)
Set the AD4170 Powerdown switches settings.
Definition: ad4170.c:1197
AD4170_FIR_DEFAULT
@ AD4170_FIR_DEFAULT
Definition: ad4170.h:874
ad4170_dac_gain
ad4170_dac_gain
DAC Output Span.
Definition: ad4170.h:917
AD4170_CURRENT_SOURCE_I_OUT_VAL_MSK
#define AD4170_CURRENT_SOURCE_I_OUT_VAL_MSK
Definition: ad4170.h:246
AD4170_EXTERNAL_XTAL
@ AD4170_EXTERNAL_XTAL
Definition: ad4170.h:420
AD4170_DIG_AUX1_RDY
@ AD4170_DIG_AUX1_RDY
Definition: ad4170.h:317
ad4170_regmap
int ad4170_regmap(struct ad4170_dev *dev)
Debugging function to print the register map to console.
Definition: ad4170.c:1967
ad4170_get_data16s
int ad4170_get_data16s(struct ad4170_dev *dev, uint16_t *data, uint8_t *status)
Get data and status from register Data_16b_Status.
Definition: ad4170.c:457
AD4170_CHOP_IEXC_CD
@ AD4170_CHOP_IEXC_CD
Definition: ad4170.h:593
AD4170_PGA_GAIN_16
@ AD4170_PGA_GAIN_16
Definition: ad4170.h:683
NO_OS_GPIO_LOW
@ NO_OS_GPIO_LOW
Definition: no_os_gpio.h:121
AD4170_DIG_AUX1_SYNC
@ AD4170_DIG_AUX1_SYNC
Definition: ad4170.h:319
ad4170_read16s
int ad4170_read16s(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_16b_Status.
Definition: ad4170.c:682
AD4170_AIN11
@ AD4170_AIN11
Definition: ad4170.h:534
AD4170_FIR_ANTISYM_ODD
@ AD4170_FIR_ANTISYM_ODD
Definition: ad4170.h:880
AD4170_INTERNAL_OSC_OUTPUT
@ AD4170_INTERNAL_OSC_OUTPUT
Definition: ad4170.h:416
AD4170_INTERFACE_CONFIG_C_CRC
#define AD4170_INTERFACE_CONFIG_C_CRC(x)
Definition: ad4170.h:136
ad4170_read24
int ad4170_read24(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_24.
Definition: ad4170.c:695
AD4170_AIN10
@ AD4170_AIN10
Definition: ad4170.h:533
ad4170_config::powerdown_sw
uint16_t powerdown_sw
Definition: ad4170.h:951
AD4170_REG_DAC_HW_LDAC_MASK
#define AD4170_REG_DAC_HW_LDAC_MASK
Definition: ad4170.h:113
AD4170_MODE_SELF_OFFSET_CAL
@ AD4170_MODE_SELF_OFFSET_CAL
Definition: ad4170.h:473
AD4170_REG_COEFF_READ_DATA
#define AD4170_REG_COEFF_READ_DATA
Definition: ad4170.h:107
ad4170_spi_reg_write_mask
int ad4170_spi_reg_write_mask(struct ad4170_dev *dev, uint32_t reg_addr, uint8_t mask, uint32_t reg_data)
SPI write device register using a mask.
Definition: ad4170.c:387
ad4170_regmap
int ad4170_regmap(struct ad4170_dev *dev)
Debugging function to print the register map to console.
Definition: ad4170.c:1967
ECOMM
#define ECOMM
Definition: ad4170.h:49
AD4170_FIR_ANTISYM_EVEN
@ AD4170_FIR_ANTISYM_EVEN
Definition: ad4170.h:882
AD4170_REG_REF_CONTROL
#define AD4170_REG_REF_CONTROL
Definition: ad4170.h:101
ad4170_pin_muxing::sync_ctrl
enum ad4170_sync_ctrl sync_ctrl
Definition: ad4170.h:371
AD4170_DLY_256
@ AD4170_DLY_256
Definition: ad4170.h:505
AD4170_REG_ADC_SETUPS_OFFSET
#define AD4170_REG_ADC_SETUPS_OFFSET(n)
Definition: ad4170.h:99
AD4170_FIR_COEFF_MAX_LENGTH
#define AD4170_FIR_COEFF_MAX_LENGTH
Definition: ad4170.h:281
ad4170_set_channel_map
int ad4170_set_channel_map(struct ad4170_dev *dev, uint8_t ch, struct ad4170_channel_map map)
Set the AD4170 Channel specific map.
Definition: ad4170.c:1364
no_os_mdelay
void no_os_mdelay(uint32_t msecs)
Wait until msecs milliseconds passed.
Definition: aducm3029_delay.c:132
ad4170_get_ch_data
int ad4170_get_ch_data(struct ad4170_dev *dev, uint8_t ch, uint32_t *data)
Get data from register Data_Per_Channel[n].
Definition: ad4170.c:559
ad4170_set_powerdown_sw
int ad4170_set_powerdown_sw(struct ad4170_dev *dev, uint16_t powerdown_sw)
Set the AD4170 Powerdown switches settings.
Definition: ad4170.c:1197
ad4170_set_channel_setup
int ad4170_set_channel_setup(struct ad4170_dev *dev, uint8_t ch, struct ad4170_channel_setup setup)
Set the AD4170 Channel specific setup.
Definition: ad4170.c:1336
no_os_field_prep
uint32_t no_os_field_prep(uint32_t mask, uint32_t val)
AD4170_CHOP_ACX_4PIN
@ AD4170_CHOP_ACX_4PIN
Definition: ad4170.h:608
ad4170_spi_reg_read
int ad4170_spi_reg_read(struct ad4170_dev *dev, uint32_t reg_addr, uint32_t *reg_data)
Read device register.
Definition: ad4170.c:236
ad4170_remove
int ad4170_remove(struct ad4170_dev *dev)
Remove the device and free al the resources.
Definition: ad4170.c:1954
ad4170_fir_mode
ad4170_fir_mode
Selects FIR Type.
Definition: ad4170.h:872
ad4170_init_param::spi_init
struct no_os_spi_init_param spi_init
Definition: ad4170.h:1010
AD4170_I_OUT_AIN11
@ AD4170_I_OUT_AIN11
Definition: ad4170.h:815
ad4170_setup::filter
struct ad4170_filter filter
Definition: ad4170.h:769
ad4170_pin_muxing
Pin_Muxing register settings.
Definition: ad4170.h:363
no_os_error.h
Error codes definition.
AD4170_INTERFACE_CONFIG_B_SHORT_INSTRUCTION_MSK
#define AD4170_INTERFACE_CONFIG_B_SHORT_INSTRUCTION_MSK
Definition: ad4170.h:131
AD4170_I_OUT_AIN6
@ AD4170_I_OUT_AIN6
Definition: ad4170.h:805
ad4170_adc_ctrl::cont_read_status_en
bool cont_read_status_en
Definition: ad4170.h:488
ad4170_burnout
ad4170_burnout
Burnout Current Values.
Definition: ad4170.h:617
ad4170_config::fir_control
struct ad4170_fir_control fir_control
Definition: ad4170.h:973
AD4170_ADC_SETUPS_AFE_BIPOLAR_MSK
#define AD4170_ADC_SETUPS_AFE_BIPOLAR_MSK
Definition: ad4170.h:237
ad4170_spi_reg_write_mask
int ad4170_spi_reg_write_mask(struct ad4170_dev *dev, uint32_t reg_addr, uint8_t mask, uint32_t reg_data)
SPI write device register using a mask.
Definition: ad4170.c:387
AD4170_PIN_MUXING_DIG_OUT_STR_MSK
#define AD4170_PIN_MUXING_DIG_OUT_STR_MSK
Definition: ad4170.h:170
ad4170_ref_select
ad4170_ref_select
ADC Reference Selection.
Definition: ad4170.h:658
AD4170_INTERFACE_CONFIG_B_SHORT_INSTRUCTION
#define AD4170_INTERFACE_CONFIG_B_SHORT_INSTRUCTION(x)
Definition: ad4170.h:132
ad4170_set_dclk_div
int ad4170_set_dclk_div(struct ad4170_dev *dev, enum ad4170_dclk_div clk_div)
Set the AD4170 DCLK configuration.
Definition: ad4170.c:1085
AD4170_ALDO
@ AD4170_ALDO
Definition: ad4170.h:547
AD4170_IOVDD_DGND_N
@ AD4170_IOVDD_DGND_N
Definition: ad4170.h:545
AD4170_REG_DAC_HW_TOGGLE_MASK
#define AD4170_REG_DAC_HW_TOGGLE_MASK
Definition: ad4170.h:112
ad4170_dig_aux2_ctrl
ad4170_dig_aux2_ctrl
Configures Functionality of DIG_AUX2 Pin.
Definition: ad4170.h:298
AD4170_INTERNAL_OSC
@ AD4170_INTERNAL_OSC
Definition: ad4170.h:414
ad4170_dac_sw_ldac
int ad4170_dac_sw_ldac(struct ad4170_dev *dev, bool polarity)
Perform a software LDAC.
Definition: ad4170.c:1717
AD4170_CLKDIVBY1
@ AD4170_CLKDIVBY1
Definition: ad4170.h:399
no_os_crc8_populate_msb
void no_os_crc8_populate_msb(uint8_t *table, const uint8_t polynomial)
AD4170_REG_DAC_SW_LDAC_TRIGGERS
#define AD4170_REG_DAC_SW_LDAC_TRIGGERS
Definition: ad4170.h:116
ad4170_get_data16
int ad4170_get_data16(struct ad4170_dev *dev, uint16_t *data)
Get data from register Data_16b.
Definition: ad4170.c:433
AD4190_PRODUCT_ID_H_VALUE
#define AD4190_PRODUCT_ID_H_VALUE
Definition: ad4170.h:156
NO_OS_DECLARE_CRC8_TABLE
NO_OS_DECLARE_CRC8_TABLE(ad4170_crc8)
ad4170_ref_control
Ref_Control register settings.
Definition: ad4170.h:782
AD4170_REG_ERROR
#define AD4170_REG_ERROR
Definition: ad4170.h:91
ad4170_init_param::id
enum ad4170_id id
Definition: ad4170.h:1008
ad4170_misc
Misc register settings.
Definition: ad4170.h:632
ad4170_afe::pga_gain
enum ad4170_pga_gain pga_gain
Definition: ad4170.h:710
ad4170_ref_control::ref_en
bool ref_en
Definition: ad4170.h:784
AD4170_SYNC_STANDARD
@ AD4170_SYNC_STANDARD
Definition: ad4170.h:332
AD4170_REG_PRODUCT_ID_H
#define AD4170_REG_PRODUCT_ID_H
Definition: ad4170.h:70
ad4170_set_standby_ctrl
int ad4170_set_standby_ctrl(struct ad4170_dev *dev, uint16_t standby_ctrl)
Set the AD4170 Standby control settings.
Definition: ad4170.c:1175
ad4170_dclk_div
ad4170_dclk_div
Continuous Transmit Data Clock Divider.
Definition: ad4170.h:382
AD4170_AIN16
@ AD4170_AIN16
Definition: ad4170.h:539
AD4170_REFIN_REFIN2
@ AD4170_REFIN_REFIN2
Definition: ad4170.h:662
AD4170_DCLKDIVBY2
@ AD4170_DCLKDIVBY2
Definition: ad4170.h:386
ad4170_set_mclk_div
int ad4170_set_mclk_div(struct ad4170_dev *dev, enum ad4170_mclk_div div)
Set the AD4170 MCLK configuration.
Definition: ad4170.c:1115
ad4170_pin_muxing::dig_aux2_ctrl
enum ad4170_dig_aux2_ctrl dig_aux2_ctrl
Definition: ad4170.h:367
AD4170_I_OUT_AIN2
@ AD4170_I_OUT_AIN2
Definition: ad4170.h:797
ad4170_current_source::i_out_pin
enum ad4170_i_out_pin i_out_pin
Definition: ad4170.h:864
ad4170_set_setup
int ad4170_set_setup(struct ad4170_dev *dev, uint8_t n, struct ad4170_setup setup)
Configure an ADC setup.
Definition: ad4170.c:1391
AD4170_AIN13
@ AD4170_AIN13
Definition: ad4170.h:536
ad4170_read16
int ad4170_read16(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_16b.
Definition: ad4170.c:669
ad4170_continuous_read
int ad4170_continuous_read(struct ad4170_dev *dev, uint32_t *data_out, uint8_t *status_out, uint16_t nb_samples)
Read multiple samples in continuous read mode.
Definition: ad4170.c:809
ad4170_config
AD4170 configuration.
Definition: ad4170.h:943
AD4170_CHANNEL_MAPN_AINP_MSK
#define AD4170_CHANNEL_MAPN_AINP_MSK
Definition: ad4170.h:225
AD4170_DIG_AUX1_MODOUT
@ AD4170_DIG_AUX1_MODOUT
Definition: ad4170.h:321
ad4170_channel_setup
Channel_Setup register settings.
Definition: ad4170.h:563
ad4170_continuous_transmit_exit
int ad4170_continuous_transmit_exit(struct ad4170_dev *dev)
Exit continuous transmit mode.
Definition: ad4170.c:944
ad4170_config_reset
struct ad4170_config ad4170_config_reset
Definition: ad4170.c:52
ad4170_get_status
int ad4170_get_status(struct ad4170_dev *dev, uint16_t *status)
Get status from register Data_Status.
Definition: ad4170.c:582
AD4170_ADC_SETUPS_AFE_PGA_GAIN_MSK
#define AD4170_ADC_SETUPS_AFE_PGA_GAIN_MSK
Definition: ad4170.h:238
ad4170_config::i_pullup
uint16_t i_pullup
Definition: ad4170.h:969
AD4170_IOVDD_DGND_P
@ AD4170_IOVDD_DGND_P
Definition: ad4170.h:544
AD4170_REG_DAC_HW_LDAC_MASK_HW_LDAC_EN_MSK
#define AD4170_REG_DAC_HW_LDAC_MASK_HW_LDAC_EN_MSK
Definition: ad4170.h:267
AD4170_I_OUT_100UA
@ AD4170_I_OUT_100UA
Definition: ad4170.h:848
AD4170_PIN_MUXING_CHAN_TO_GPIO_MSK
#define AD4170_PIN_MUXING_CHAN_TO_GPIO_MSK
Definition: ad4170.h:166
AD4170_CHANNEL
#define AD4170_CHANNEL(ch)
Definition: ad4170.h:217
ad4170_dev::gpio_sync_inb_init
struct no_os_gpio_init_param * gpio_sync_inb_init
Definition: ad4170.h:1045
ad4170_config::v_bias
uint16_t v_bias
Definition: ad4170.h:967
ad4170_reset
int ad4170_reset(struct ad4170_dev *dev)
Perform a software reset.
Definition: ad4170.c:978
ad4170_set_i_pullup
int ad4170_set_i_pullup(struct ad4170_dev *dev, uint16_t ch_mask)
Set the AD4170 Input pullup.
Definition: ad4170.c:1509
ad4170_adc_ctrl::parallel_filt_en
bool parallel_filt_en
Definition: ad4170.h:484
AD4170_AIN3
@ AD4170_AIN3
Definition: ad4170.h:526
AD4170_CLKDIVBY4
@ AD4170_CLKDIVBY4
Definition: ad4170.h:403
AD4170_MODE_CONT
@ AD4170_MODE_CONT
Definition: ad4170.h:455
AD4170_REG_DAC_CHANNEL_EN
#define AD4170_REG_DAC_CHANNEL_EN
Definition: ad4170.h:111
AD4170_I_OUT_AIN5
@ AD4170_I_OUT_AIN5
Definition: ad4170.h:803
ad4170_init_param::rdy_conv_timeout
uint32_t rdy_conv_timeout
Definition: ad4170.h:1014
ad4170_dac_config::hw_toggle
bool hw_toggle
Definition: ad4170.h:934
AD4170_REFIN_REFIN1
@ AD4170_REFIN_REFIN1
Definition: ad4170.h:660
AD4170_SW_RESET_MSK
#define AD4170_SW_RESET_MSK
Definition: ad4170.h:124
ad4170_set_clocksel
int ad4170_set_clocksel(struct ad4170_dev *dev, enum ad4170_clocksel sel)
Set the AD4170 clock selection configuration.
Definition: ad4170.c:1145
AD4170_REG_SCRATCH_PAD
#define AD4170_REG_SCRATCH_PAD
Definition: ad4170.h:72
AD4170_MODE_SYS_GAIN_CAL
@ AD4170_MODE_SYS_GAIN_CAL
Definition: ad4170.h:471
AD4170_CURRENT_SOURCE_I_OUT_PIN_MSK
#define AD4170_CURRENT_SOURCE_I_OUT_PIN_MSK
Definition: ad4170.h:245
AD4170_PGA_GAIN_1
@ AD4170_PGA_GAIN_1
Definition: ad4170.h:675
AD4170_REG_DATA_24b_STATUS
#define AD4170_REG_DATA_24b_STATUS
Definition: ad4170.h:82
ad4170_init_param::config
struct ad4170_config config
Definition: ad4170.h:1016
AD4170_AVSS
@ AD4170_AVSS
Definition: ad4170.h:549
ad4170_setup::filter_fs
uint16_t filter_fs
Definition: ad4170.h:771
AD4170_REG_V_BIAS
#define AD4170_REG_V_BIAS
Definition: ad4170.h:102
AD4170_REG_DATA_16b_STATUS
#define AD4170_REG_DATA_16b_STATUS
Definition: ad4170.h:80
AD4170_PIN_MUXING_DIG_AUX1_CTRL_MSK
#define AD4170_PIN_MUXING_DIG_AUX1_CTRL_MSK
Definition: ad4170.h:168
ad4170_sync_ctrl
ad4170_sync_ctrl
Configures SYNC_IN Pin for ADC Synchronization.
Definition: ad4170.h:328
AD4170_I_OUT_GPIO2
@ AD4170_I_OUT_GPIO2
Definition: ad4170.h:831
AD4170_TRANSF_LEN
#define AD4170_TRANSF_LEN(x)
Definition: ad4170.h:56
ad4170_set_current_source
int ad4170_set_current_source(struct ad4170_dev *dev, uint8_t n, struct ad4170_current_source current_source)
Set the AD4170 Excitation Current.
Definition: ad4170.c:1532
AD4170_DIG_STR_HIGH
@ AD4170_DIG_STR_HIGH
Definition: ad4170.h:345
ad4170_afe::ref_buf_m
enum ad4170_ref_buf ref_buf_m
Definition: ad4170.h:702
ad4170_setup
Sequencer Setup register settings.
Definition: ad4170.h:764
AD4170_AIN6
@ AD4170_AIN6
Definition: ad4170.h:529
AD4170_REG_DEVICE_CONFIG
#define AD4170_REG_DEVICE_CONFIG
Definition: ad4170.h:67
ad4170_fir_coeff_set
ad4170_fir_coeff_set
Selects FIR coefficient set.
Definition: ad4170.h:891
ad4170_channel_setup::setup_n
uint8_t setup_n
Definition: ad4170.h:569
ad4170_set_error_en
int ad4170_set_error_en(struct ad4170_dev *dev, uint16_t error_en)
Set the AD4170 Error enable settings.
Definition: ad4170.c:1219
ad4170_reset_spi_interface
int ad4170_reset_spi_interface(struct ad4170_dev *dev)
Reset the SPI interface by sending reset sequence to device.
Definition: ad4170.c:410
AD4170_REG_INTERFACE_CONFIG_B
#define AD4170_REG_INTERFACE_CONFIG_B
Definition: ad4170.h:66
ad4170_dev::big_endian
bool big_endian
Definition: ad4170.h:1041
no_os_gpio_remove
int32_t no_os_gpio_remove(struct no_os_gpio_desc *desc)
Free the resources allocated by no_os_gpio_get().
Definition: no_os_gpio.c:110
no_os_spi_desc
Structure holding SPI descriptor.
Definition: no_os_spi.h:177
ad4170_pin_muxing::dig_out_str
enum ad4170_dig_out_str dig_out_str
Definition: ad4170.h:373
AD4170_DAC
@ AD4170_DAC
Definition: ad4170.h:546
ad4170_set_current_source
int ad4170_set_current_source(struct ad4170_dev *dev, uint8_t n, struct ad4170_current_source current_source)
Set the AD4170 Excitation Current.
Definition: ad4170.c:1532
AD4170_ADC_CTRL_CONT_READ_STATUS_EN_MSK
#define AD4170_ADC_CTRL_CONT_READ_STATUS_EN_MSK
Definition: ad4170.h:196
AD4170_CHOP_IEXC_ABCD
@ AD4170_CHOP_IEXC_ABCD
Definition: ad4170.h:595
ad4170_ain
ad4170_ain
Multiplexer Positive/Negative Input for This Channel.
Definition: ad4170.h:522
AD4170_MODE_SYS_OFFSET_CAL
@ AD4170_MODE_SYS_OFFSET_CAL
Definition: ad4170.h:469
ad4170_dac_config::hw_ldac
bool hw_ldac
Definition: ad4170.h:936
AD4170_REG_CTRL_MODE_MSK
#define AD4170_REG_CTRL_MODE_MSK
Definition: ad4170.h:198
AD4170_REG_DATA_PER_CHANNEL
#define AD4170_REG_DATA_PER_CHANNEL(ch)
Definition: ad4170.h:84
ad4170_dig_out_str
ad4170_dig_out_str
Configures the drive strength of the Digital Outputs.
Definition: ad4170.h:341
ad4170_fir_control::fir_length
uint8_t fir_length
Definition: ad4170.h:908
ad4170_get_data16
int ad4170_get_data16(struct ad4170_dev *dev, uint16_t *data)
Get data from register Data_16b.
Definition: ad4170.c:433
ad4170_config::setup
struct ad4170_channel_setup setup[AD4170_NUM_CHANNELS]
Definition: ad4170.h:959
ad4170_set_channel_map
int ad4170_set_channel_map(struct ad4170_dev *dev, uint8_t ch, struct ad4170_channel_map map)
Set the AD4170 Channel specific map.
Definition: ad4170.c:1364
ad4170_channel_setup::repeat_n
uint8_t repeat_n
Definition: ad4170.h:565
ad4170_clock_ctrl::clocksel
enum ad4170_clocksel clocksel
Definition: ad4170.h:433
AD4170_REFIN1_N
@ AD4170_REFIN1_N
Definition: ad4170.h:552
AD4170_ADC_SETUPS_AFE_REF_SELECT_MSK
#define AD4170_ADC_SETUPS_AFE_REF_SELECT_MSK
Definition: ad4170.h:236
AD4170_PGA_GAIN_64
@ AD4170_PGA_GAIN_64
Definition: ad4170.h:687
ad4170_set_error
int ad4170_set_error(struct ad4170_dev *dev, uint16_t error)
Set the Error register with a value to clear specific errors.
Definition: ad4170.c:1241
ad4170_set_adc_ctrl
int ad4170_set_adc_ctrl(struct ad4170_dev *dev, struct ad4170_adc_ctrl adc_ctrl)
Set the AD4170 ADC Control.
Definition: ad4170.c:1275
no_os_gpio_desc
Structure holding the GPIO descriptor.
Definition: no_os_gpio.h:102
AD4170_DIG_AUX2_MODOUT
@ AD4170_DIG_AUX2_MODOUT
Definition: ad4170.h:306
ad4170_set_dac_data
int ad4170_set_dac_data(struct ad4170_dev *dev, uint16_t code)
Set the AD4170 DAC data by directly writing the DAT_DATA register.
Definition: ad4170.c:1681
AD4170_PGA_GAIN_0P5
@ AD4170_PGA_GAIN_0P5
Definition: ad4170.h:691
ad4170_spi_settings::short_instruction
bool short_instruction
Definition: ad4170.h:984
AD4170_CONT_READ_ON
@ AD4170_CONT_READ_ON
Definition: ad4170.h:444
AD4170_REFIN_AVDD
@ AD4170_REFIN_AVDD
Definition: ad4170.h:666
AD4170_REG_VENDOR_H
#define AD4170_REG_VENDOR_H
Definition: ad4170.h:75
ad4170.h
Header file for the ad4170 driver.
ad4170_fir_control::fir_coefficients
int32_t * fir_coefficients
Definition: ad4170.h:910
AD4170_PIN_MUXING_SYNC_CTRL_MSK
#define AD4170_PIN_MUXING_SYNC_CTRL_MSK
Definition: ad4170.h:169
ad4170_continuous_transmit_exit
int ad4170_continuous_transmit_exit(struct ad4170_dev *dev)
Exit continuous transmit mode.
Definition: ad4170.c:944
ID_AD4190
@ ID_AD4190
Definition: ad4170.h:999
AD4170_I_OUT_GPIO1
@ AD4170_I_OUT_GPIO1
Definition: ad4170.h:829
ad4170_read24s
int ad4170_read24s(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_24_Status.
Definition: ad4170.c:708
AD4170_AIN15
@ AD4170_AIN15
Definition: ad4170.h:538
ad4170_dev::gpio_dig_aux2_init
struct no_os_gpio_init_param * gpio_dig_aux2_init
Definition: ad4170.h:1053
AD4170_I_OUT_AIN14
@ AD4170_I_OUT_AIN14
Definition: ad4170.h:821
ad4170_dac_config::gain
enum ad4170_dac_gain gain
Definition: ad4170.h:932
AD4170_PIN_MUXING_DIG_AUX2_CTRL_MSK
#define AD4170_PIN_MUXING_DIG_AUX2_CTRL_MSK
Definition: ad4170.h:167
AD4170_REG_SPI_REVISION
#define AD4170_REG_SPI_REVISION
Definition: ad4170.h:73
ad4170_dac_sw_toggle
int ad4170_dac_sw_toggle(struct ad4170_dev *dev, bool polarity)
Perform a software toggle.
Definition: ad4170.c:1729
AD4170_I_OUT_AIN15
@ AD4170_I_OUT_AIN15
Definition: ad4170.h:823
ad4170_set_dac_config
int ad4170_set_dac_config(struct ad4170_dev *dev, struct ad4170_dac_config config)
Set the AD4170 DAC settings.
Definition: ad4170.c:1625
AD4170_PRODUCT_ID_L_VALUE
#define AD4170_PRODUCT_ID_L_VALUE
Definition: ad4170.h:151
AD4170_REF_BUF_BYPASS
@ AD4170_REF_BUF_BYPASS
Definition: ad4170.h:651
AD4170_MODE_IDLE
@ AD4170_MODE_IDLE
Definition: ad4170.h:467
AD4170_REG_CHANNEL_EN
#define AD4170_REG_CHANNEL_EN
Definition: ad4170.h:92
AD4170_REG_PIN_MUXING
#define AD4170_REG_PIN_MUXING
Definition: ad4170.h:85
AD4170_FILT_SINC5
@ AD4170_FILT_SINC5
Definition: ad4170.h:744
AD4170_REG_DAC_SW_LDAC_TRIGGERS_SW_LDAC_EN_MSK
#define AD4170_REG_DAC_SW_LDAC_TRIGGERS_SW_LDAC_EN_MSK
Definition: ad4170.h:276
ad4170_adc_ctrl::multi_data_reg_sel
bool multi_data_reg_sel
Definition: ad4170.h:486
ad4170_channel_map
Channel_Map register settings. Selects Analog Inputs for This Sequencer Channel.
Definition: ad4170.h:576
AD4170_REG_READ_14
#define AD4170_REG_READ_14(x)
Definition: ad4170.h:63
AD4170_FILT_SINC5_AVG
@ AD4170_FILT_SINC5_AVG
Definition: ad4170.h:742
ad4170_init_param
AD4170 SPI init paraeter structure, used for initializing the ad4170_dev.
Definition: ad4170.h:1006
ad4170_init
int ad4170_init(struct ad4170_dev **device, struct ad4170_init_param *init_param)
Initialize an AD4170 device structure.
Definition: ad4170.c:1760
AD4170_REG_DAC_DATA_MSK
#define AD4170_REG_DAC_DATA_MSK
Definition: ad4170.h:270
AD4170_POST_FILTER_NONE
@ AD4170_POST_FILTER_NONE
Definition: ad4170.h:719
AD4170_AVDD_AVSS_N
@ AD4170_AVDD_AVSS_N
Definition: ad4170.h:543
ad4170_clock_ctrl::clockdiv
enum ad4170_mclk_div clockdiv
Definition: ad4170.h:431
AD4170_AIN0
@ AD4170_AIN0
Definition: ad4170.h:523
ad4170_spi_reg_read
int ad4170_spi_reg_read(struct ad4170_dev *dev, uint32_t reg_addr, uint32_t *reg_data)
Read device register.
Definition: ad4170.c:236
ad4170_init_param::gpio_sync_inb
struct no_os_gpio_init_param * gpio_sync_inb
Definition: ad4170.h:1018
ad4170_set_channel_en
int ad4170_set_channel_en(struct ad4170_dev *dev, uint16_t channel_en)
Enable AD4170 channels.
Definition: ad4170.c:1313
AD4170_FIR_COEFF_SET1
@ AD4170_FIR_COEFF_SET1
Definition: ad4170.h:895
AD4170_REG_DAC_DATA
#define AD4170_REG_DAC_DATA(ch)
Definition: ad4170.h:114
ad4170_config_reset
struct ad4170_config ad4170_config_reset
Definition: ad4170.c:52
AD4170_REG_I_PULLUP
#define AD4170_REG_I_PULLUP
Definition: ad4170.h:103
NO_OS_BIT
#define NO_OS_BIT(x)
Definition: no_os_util.h:51
no_os_crc8
uint8_t no_os_crc8(const uint8_t *table, const uint8_t *pdata, size_t nbytes, uint8_t crc)
AD4170_CLKDIVBY2
@ AD4170_CLKDIVBY2
Definition: ad4170.h:401
AD4170_DLDO
@ AD4170_DLDO
Definition: ad4170.h:548
ad4170_set_i_pullup
int ad4170_set_i_pullup(struct ad4170_dev *dev, uint16_t ch_mask)
Set the AD4170 Input pullup.
Definition: ad4170.c:1509
ID_AD4171
@ ID_AD4171
Definition: ad4170.h:997
AD4170_PGA_GAIN_4
@ AD4170_PGA_GAIN_4
Definition: ad4170.h:679
AD4170_CHOP_ACX_2PIN
@ AD4170_CHOP_ACX_2PIN
Definition: ad4170.h:610
AD4170_ADDR
#define AD4170_ADDR(x)
Definition: ad4170.h:57
AD4170_CHANNEL_TO_GPIO
@ AD4170_CHANNEL_TO_GPIO
Definition: ad4170.h:291
ad4170_current_source
Current_Source register settings.
Definition: ad4170.h:863
AD4170_REFIN2_P
@ AD4170_REFIN2_P
Definition: ad4170.h:553
AD4170_REFIN_REFOUT
@ AD4170_REFIN_REFOUT
Definition: ad4170.h:664
AD4170_AIN9
@ AD4170_AIN9
Definition: ad4170.h:532
ad4170_config::current_source
struct ad4170_current_source current_source[AD4170_NUM_CURRENT_SOURCE]
Definition: ad4170.h:971
AD4170_CHANNEL_SETUPN_REPEAT_N_MSK
#define AD4170_CHANNEL_SETUPN_REPEAT_N_MSK
Definition: ad4170.h:220
AD4170_PIN_MUXING_SDO_RDBY_DLY_MSK
#define AD4170_PIN_MUXING_SDO_RDBY_DLY_MSK
Definition: ad4170.h:171
ad4170_dig_aux1_ctrl
ad4170_dig_aux1_ctrl
Configures Functionality of DIG_AUX1 Pin.
Definition: ad4170.h:313
AD4170_ADC_SETUPS_MISC_BURNOUT_MSK
#define AD4170_ADC_SETUPS_MISC_BURNOUT_MSK
Definition: ad4170.h:231
no_os_hweight8
unsigned int no_os_hweight8(uint8_t word)
ad4170_config::error_en
uint16_t error_en
Definition: ad4170.h:953
AD4170_FIR_CONTROL_COEFF_SET_MSK
#define AD4170_FIR_CONTROL_COEFF_SET_MSK
Definition: ad4170.h:254
ad4170_adc_ctrl::mode
enum ad4170_mode mode
Definition: ad4170.h:492
AD4170_MODE_SINGLE
@ AD4170_MODE_SINGLE
Definition: ad4170.h:461
ad4170_current_source::i_out_val
enum ad4170_i_out_val i_out_val
Definition: ad4170.h:865
no_os_udelay
void no_os_udelay(uint32_t usecs)
Wait until usecs microseconds passed.
Definition: aducm3029_delay.c:120
ad4170_get_data16s
int ad4170_get_data16s(struct ad4170_dev *dev, uint16_t *data, uint8_t *status)
Get data and status from register Data_16b_Status.
Definition: ad4170.c:457
AD4170_REG_COEFF_WRRD_STB
#define AD4170_REG_COEFF_WRRD_STB
Definition: ad4170.h:109
AD4170_TEMP_SENSOR_P
@ AD4170_TEMP_SENSOR_P
Definition: ad4170.h:540
ad4170_misc::burnout
enum ad4170_burnout burnout
Definition: ad4170.h:638
ad4170_misc::chop_adc
enum ad4170_chop_adc chop_adc
Definition: ad4170.h:636
AD4170_I_OUT_AIN13
@ AD4170_I_OUT_AIN13
Definition: ad4170.h:819
AD4170_MODE_CONT_FIR
@ AD4170_MODE_CONT_FIR
Definition: ad4170.h:457
AD4170_I_OUT_GPIO0
@ AD4170_I_OUT_GPIO0
Definition: ad4170.h:827
ad4170_post_filter
ad4170_post_filter
Optional Post-Filter configuration.
Definition: ad4170.h:717
AD4190_PRODUCT_ID_L_VALUE
#define AD4190_PRODUCT_ID_L_VALUE
Definition: ad4170.h:155
AD4170_AIN1
@ AD4170_AIN1
Definition: ad4170.h:524
ad4170_dac_sw_toggle
int ad4170_dac_sw_toggle(struct ad4170_dev *dev, bool polarity)
Perform a software toggle.
Definition: ad4170.c:1729
no_os_gpio_set_value
int32_t no_os_gpio_set_value(struct no_os_gpio_desc *desc, uint8_t value)
Set the value of the specified GPIO.
Definition: no_os_gpio.c:203
init_param
struct ad7616_init_param init_param
Definition: ad7616_sdz.c:119
ad4170_continuous_read
int ad4170_continuous_read(struct ad4170_dev *dev, uint32_t *data_out, uint8_t *status_out, uint16_t nb_samples)
Read multiple samples in continuous read mode.
Definition: ad4170.c:809
ad4170_pin_muxing::chan_to_gpio
enum ad4170_chan_to_gpio chan_to_gpio
Definition: ad4170.h:365
AD4170_REFOUT
@ AD4170_REFOUT
Definition: ad4170.h:555
AD4170_REG_ADC_SETUPS_MISC
#define AD4170_REG_ADC_SETUPS_MISC(n)
Definition: ad4170.h:95
ad4170_get_data32
int ad4170_get_data32(struct ad4170_dev *dev, uint32_t *data)
Get data from register Data_32b.
Definition: ad4170.c:531
ad4170_remove
int ad4170_remove(struct ad4170_dev *dev)
Remove the device and free al the resources.
Definition: ad4170.c:1954
ad4170_id
ad4170_id
Device selector ID.
Definition: ad4170.h:995
ad4170_misc::chop_iexc
enum ad4170_chop_iexc chop_iexc
Definition: ad4170.h:634
AD4170_ADC_SETUPS_AFE_REF_BUF_M_MSK
#define AD4170_ADC_SETUPS_AFE_REF_BUF_M_MSK
Definition: ad4170.h:234
AD4170_REG_COEFF_WRITE_DATA
#define AD4170_REG_COEFF_WRITE_DATA
Definition: ad4170.h:106
ad4170_dac_config::enabled
bool enabled
Definition: ad4170.h:930
ad4170_delay_n
ad4170_delay_n
Delay to Add After Channel Switch.
Definition: ad4170.h:499
ad4170_spi_reg_write
int ad4170_spi_reg_write(struct ad4170_dev *dev, uint32_t reg_addr, uint32_t reg_data)
Write device register.
Definition: ad4170.c:313
AD4170_ADC_SETUPS_POST_FILTER_SEL_MSK
#define AD4170_ADC_SETUPS_POST_FILTER_SEL_MSK
Definition: ad4170.h:241
ad4170_sdo_rdby_dly
ad4170_sdo_rdby_dly
Reset Interface on CS or SCLK.
Definition: ad4170.h:352
ad4170_dac_hw_toggle
int ad4170_dac_hw_toggle(struct ad4170_dev *dev, bool polarity)
Perform a hardware toggle using the DIG_AUX2 pin, assumed to be pre-configured for this.
Definition: ad4170.c:1741
AD4170_POST_FILTER_50MS
@ AD4170_POST_FILTER_50MS
Definition: ad4170.h:723
AD4170_DLY_4096
@ AD4170_DLY_4096
Definition: ad4170.h:511
AD4170_I_OUT_AIN9
@ AD4170_I_OUT_AIN9
Definition: ad4170.h:811
AD4170_POST_FILTER_40MS
@ AD4170_POST_FILTER_40MS
Definition: ad4170.h:721
AD4170_SYNC_ALTERNATE
@ AD4170_SYNC_ALTERNATE
Definition: ad4170.h:334
AD4170_REG_ADC_SETUPS_GAIN
#define AD4170_REG_ADC_SETUPS_GAIN(n)
Definition: ad4170.h:100
ad4170_dev::dig_aux2_output
bool dig_aux2_output
Definition: ad4170.h:1055
ad4170_spi_settings::sync_loss_detect
bool sync_loss_detect
Definition: ad4170.h:988
ad4170_set_dac_inputa
int ad4170_set_dac_inputa(struct ad4170_dev *dev, uint16_t code)
Set the AD4170 DAC data by writing the INPUTA register to be loaded separately by LDAC or Toggle oper...
Definition: ad4170.c:1693
ad4170_chop_adc
ad4170_chop_adc
ADC/Mux Chopping Control.
Definition: ad4170.h:602
ad4170_get_data24
int ad4170_get_data24(struct ad4170_dev *dev, uint32_t *data)
Get data from register Data_24b.
Definition: ad4170.c:482
ad4170_get_data32
int ad4170_get_data32(struct ad4170_dev *dev, uint32_t *data)
Get data from register Data_32b.
Definition: ad4170.c:531
AD4170_PGA_GAIN_2
@ AD4170_PGA_GAIN_2
Definition: ad4170.h:677
AD4170_DLY_2048
@ AD4170_DLY_2048
Definition: ad4170.h:509
ad4170_reset
int ad4170_reset(struct ad4170_dev *dev)
Perform a software reset.
Definition: ad4170.c:978
ad4170_get_error
int ad4170_get_error(struct ad4170_dev *dev, uint16_t *error)
Get the Error register.
Definition: ad4170.c:1252
AD4170_REG_STANDBY_CTRL
#define AD4170_REG_STANDBY_CTRL
Definition: ad4170.h:87
AD4170_POST_FILTER_FAST_AC
@ AD4170_POST_FILTER_FAST_AC
Definition: ad4170.h:727
ad4170_read16s
int ad4170_read16s(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_16b_Status.
Definition: ad4170.c:682
ad4170_set_v_bias
int ad4170_set_v_bias(struct ad4170_dev *dev, uint16_t ch_mask)
Set the AD4170 Voltage bias.
Definition: ad4170.c:1487
no_os_spi_remove
int32_t no_os_spi_remove(struct no_os_spi_desc *desc)
Free the resources allocated by no_os_spi_init().
Definition: no_os_spi.c:122
AD4170_NUM_CHANNELS
#define AD4170_NUM_CHANNELS
Definition: ad4170.h:278
ad4170_set_channel_en
int ad4170_set_channel_en(struct ad4170_dev *dev, uint16_t channel_en)
Enable AD4170 channels.
Definition: ad4170.c:1313
AD4170_INTERFACE_CONFIG_C_CRC_MSK
#define AD4170_INTERFACE_CONFIG_C_CRC_MSK
Definition: ad4170.h:135
AD4170_I_OUT_1000UA
@ AD4170_I_OUT_1000UA
Definition: ad4170.h:854
AD4170_DCLKDIVBY4
@ AD4170_DCLKDIVBY4
Definition: ad4170.h:388
no_os_gpio.h
Header file of GPIO Interface.
AD4170_FIR_SYM_EVEN
@ AD4170_FIR_SYM_EVEN
Definition: ad4170.h:878
ad4170_set_adc_ctrl
int ad4170_set_adc_ctrl(struct ad4170_dev *dev, struct ad4170_adc_ctrl adc_ctrl)
Set the AD4170 ADC Control.
Definition: ad4170.c:1275
ad4170_set_dac_data
int ad4170_set_dac_data(struct ad4170_dev *dev, uint16_t code)
Set the AD4170 DAC data by directly writing the DAT_DATA register.
Definition: ad4170.c:1681
ad4170_set_ref_control
int ad4170_set_ref_control(struct ad4170_dev *dev, bool enable)
Set the AD4170 Ref Control.
Definition: ad4170.c:1465
AD4170_AIN8
@ AD4170_AIN8
Definition: ad4170.h:531
ad4170_mclk_div
ad4170_mclk_div
Master Clock Divider.
Definition: ad4170.h:397
AD4170_DLY_16
@ AD4170_DLY_16
Definition: ad4170.h:503
ad4170_config::channel_en
uint16_t channel_en
Definition: ad4170.h:957
ad4170_read32
int ad4170_read32(struct ad4170_dev *dev, uint32_t *pbuf, uint16_t nb_samples)
Read multiple samples using direct register access from Data_32b.
Definition: ad4170.c:721
ad4170_set_setup
int ad4170_set_setup(struct ad4170_dev *dev, uint8_t n, struct ad4170_setup setup)
Configure an ADC setup.
Definition: ad4170.c:1391
ad4170_afe::ref_select
enum ad4170_ref_select ref_select
Definition: ad4170.h:706
AD4170_DAC_GAIN_2
@ AD4170_DAC_GAIN_2
Definition: ad4170.h:921
AD4170_REG_CLOCK_CTRL
#define AD4170_REG_CLOCK_CTRL
Definition: ad4170.h:86
AD4170_AIN2
@ AD4170_AIN2
Definition: ad4170.h:525
AD4170_REG_COEFF_ADDRESS
#define AD4170_REG_COEFF_ADDRESS
Definition: ad4170.h:108
AD4170_DGND
@ AD4170_DGND
Definition: ad4170.h:550
ad4170_set_dac_config
int ad4170_set_dac_config(struct ad4170_dev *dev, struct ad4170_dac_config config)
Set the AD4170 DAC settings.
Definition: ad4170.c:1625
no_os_spi_init
int32_t no_os_spi_init(struct no_os_spi_desc **desc, const struct no_os_spi_init_param *param)
Initialize the SPI communication peripheral.
Definition: no_os_spi.c:58
AD4170_MODE_STANDBY
@ AD4170_MODE_STANDBY
Definition: ad4170.h:463
ad4170_get_data24
int ad4170_get_data24(struct ad4170_dev *dev, uint32_t *data)
Get data from register Data_24b.
Definition: ad4170.c:482
AD4170_DIG_AUX1_DISABLED
@ AD4170_DIG_AUX1_DISABLED
Definition: ad4170.h:315
AD4170_REG_DAC_CHANNEL_EN_DAC_EN_MSK
#define AD4170_REG_DAC_CHANNEL_EN_DAC_EN_MSK
Definition: ad4170.h:261
ad4170_set_v_bias
int ad4170_set_v_bias(struct ad4170_dev *dev, uint16_t ch_mask)
Set the AD4170 Voltage bias.
Definition: ad4170.c:1487
ad4170_spi_settings::crc_enabled
bool crc_enabled
Definition: ad4170.h:986
AD4170_CHANNEL_MAPN_AINM_MSK
#define AD4170_CHANNEL_MAPN_AINM_MSK
Definition: ad4170.h:226
AD4170_PGA_GAIN_128
@ AD4170_PGA_GAIN_128
Definition: ad4170.h:689
no_os_util.h
Header file of utility functions.
AD4170_SW_RESETX_MSK
#define AD4170_SW_RESETX_MSK
Definition: ad4170.h:127
AD4170_MODE_SELF_GAIN_CAL
@ AD4170_MODE_SELF_GAIN_CAL
Definition: ad4170.h:475
AD4170_AIN5
@ AD4170_AIN5
Definition: ad4170.h:528
AD4170_CRC8_INITIAL_VALUE
#define AD4170_CRC8_INITIAL_VALUE
Definition: ad4170.h:140
AD4170_DIG_AUX2_DISABLED
@ AD4170_DIG_AUX2_DISABLED
Definition: ad4170.h:300
ad4170_i_out_pin
ad4170_i_out_pin
Current Source Destination.
Definition: ad4170.h:791
ad4170_dev::spi_settings
struct ad4170_spi_settings spi_settings
Definition: ad4170.h:1037
AD4170_REG_ADC_SETUPS_AFE
#define AD4170_REG_ADC_SETUPS_AFE(n)
Definition: ad4170.h:96
ad4170_dev::gpio_dig_aux1
struct no_os_gpio_desc * gpio_dig_aux1
Definition: ad4170.h:1051
AD4170_REG_DATA_16b
#define AD4170_REG_DATA_16b
Definition: ad4170.h:79
AD4170_REG_DATA_24b
#define AD4170_REG_DATA_24b
Definition: ad4170.h:81
ad4170_clock_ctrl
Clock_Ctrl register settings.
Definition: ad4170.h:427
AD4170_CONT_TRANSMIT_ON
@ AD4170_CONT_TRANSMIT_ON
Definition: ad4170.h:446
ad4170_dev::rdy_conv_timeout
uint32_t rdy_conv_timeout
Definition: ad4170.h:1039
AD4170_REG_INTERFACE_CONFIG_C
#define AD4170_REG_INTERFACE_CONFIG_C
Definition: ad4170.h:76
ad4170_dev
AD4170 device descriptor.
Definition: ad4170.h:1029
AD4170_REG_DATA_32b
#define AD4170_REG_DATA_32b
Definition: ad4170.h:83
ad4170_channel_map::ainm
enum ad4170_ain ainm
Definition: ad4170.h:580
AD4170_REG_WRITE_6
#define AD4170_REG_WRITE_6(x)
Definition: ad4170.h:62
no_os_gpio_direction_output
int32_t no_os_gpio_direction_output(struct no_os_gpio_desc *desc, uint8_t value)
Enable the output direction of the specified GPIO.
Definition: no_os_gpio.c:153
ad4170_afe::ref_buf_p
enum ad4170_ref_buf ref_buf_p
Definition: ad4170.h:704
AD4170_I_OUT_500UA
@ AD4170_I_OUT_500UA
Definition: ad4170.h:852
ad4170_dac_config
DAC Config settings (registers HW_LDAC_Mask, HW_Toggle_Mask, Channel_En and DAC_Span)
Definition: ad4170.h:928
AD4170_I_OUT_GPIO3
@ AD4170_I_OUT_GPIO3
Definition: ad4170.h:833
ad4170_channel_map::ainp
enum ad4170_ain ainp
Definition: ad4170.h:578
ad4170_spi_reg_write
int ad4170_spi_reg_write(struct ad4170_dev *dev, uint32_t reg_addr, uint32_t reg_data)
Write device register.
Definition: ad4170.c:313
AD4170_I_OUT_AIN3
@ AD4170_I_OUT_AIN3
Definition: ad4170.h:799
ad4170_dac_hw_toggle
int ad4170_dac_hw_toggle(struct ad4170_dev *dev, bool polarity)
Perform a hardware toggle using the DIG_AUX2 pin, assumed to be pre-configured for this.
Definition: ad4170.c:1741
ad4170_spi_settings
AD4170 SPI settings.
Definition: ad4170.h:982
AD4170_SYNC_DISABLED
@ AD4170_SYNC_DISABLED
Definition: ad4170.h:330
ad4170_set_dac_inputb
int ad4170_set_dac_inputb(struct ad4170_dev *dev, uint16_t code)
Set the AD4170 DAC data by writing the INPUTB register to be loaded separately by LDAC or Toggle oper...
Definition: ad4170.c:1705
ad4170_set_pin_muxing
int ad4170_set_pin_muxing(struct ad4170_dev *dev, struct ad4170_pin_muxing pin_muxing)
Set the AD4170 Pin Muxing settings.
Definition: ad4170.c:1049
AD4170_REG_VENDOR_L
#define AD4170_REG_VENDOR_L
Definition: ad4170.h:74
AD4170_I_OUT_AIN7
@ AD4170_I_OUT_AIN7
Definition: ad4170.h:807
ad4170_dev::gpio_dig_aux1_init
struct no_os_gpio_init_param * gpio_dig_aux1_init
Definition: ad4170.h:1049
AD4170_REG_DATA_STATUS
#define AD4170_REG_DATA_STATUS
Definition: ad4170.h:78
AD4170_I_OUT_AIN12
@ AD4170_I_OUT_AIN12
Definition: ad4170.h:817
AD4170_DLY_1024
@ AD4170_DLY_1024
Definition: ad4170.h:507
AD4170_CLOCK_CTRL_CLOCKSEL_MSK
#define AD4170_CLOCK_CTRL_CLOCKSEL_MSK
Definition: ad4170.h:176
no_os_crc8.h
Header file of CRC-8 computation.
AD4170_PGA_GAIN_32
@ AD4170_PGA_GAIN_32
Definition: ad4170.h:685
AD4170_CLKDIVBY8
@ AD4170_CLKDIVBY8
Definition: ad4170.h:405
AD4170_AIN4
@ AD4170_AIN4
Definition: ad4170.h:527
AD4170_REG_INTERFACE_CONFIG_A
#define AD4170_REG_INTERFACE_CONFIG_A
Definition: ad4170.h:65
ad4170_filter::post_filter_sel
enum ad4170_post_filter post_filter_sel
Definition: ad4170.h:755
AD4170_AIN7
@ AD4170_AIN7
Definition: ad4170.h:530
AD4170_DLY_8192
@ AD4170_DLY_8192
Definition: ad4170.h:513
AD4170_CONT_READ_OFF
@ AD4170_CONT_READ_OFF
Definition: ad4170.h:442
AD4170_REG_ADC_CHANNEL_MAP
#define AD4170_REG_ADC_CHANNEL_MAP(ch)
Definition: ad4170.h:94
AD4170_BURNOUT_2U
@ AD4170_BURNOUT_2U
Definition: ad4170.h:623
AD4170_I_OUT_0UA
@ AD4170_I_OUT_0UA
Definition: ad4170.h:842
ad4170_clocksel
ad4170_clocksel
ADC Clock Select.
Definition: ad4170.h:412
AD4170_FIR_SYM_ODD
@ AD4170_FIR_SYM_ODD
Definition: ad4170.h:876
ad4170_dev::spi_desc
struct no_os_spi_desc * spi_desc
Definition: ad4170.h:1035
AD4170_TEMP_SENSOR_N
@ AD4170_TEMP_SENSOR_N
Definition: ad4170.h:541
AD4170_SDO_RDY_SCLK
@ AD4170_SDO_RDY_SCLK
Definition: ad4170.h:354
no_os_spi_init_param
Structure holding the parameters for SPI initialization.
Definition: no_os_spi.h:131
ad4170_channel_setup::delay_n
enum ad4170_delay_n delay_n
Definition: ad4170.h:567
ad4170_setup::afe
struct ad4170_afe afe
Definition: ad4170.h:767
ad4170_chan_to_gpio
ad4170_chan_to_gpio
Enables Current Channel Number Be Output to GPIO Pins.
Definition: ad4170.h:287
AD4170_REG_INTERFACE_STATUS_A
#define AD4170_REG_INTERFACE_STATUS_A
Definition: ad4170.h:77
no_os_gpio_get_optional
int32_t no_os_gpio_get_optional(struct no_os_gpio_desc **desc, const struct no_os_gpio_init_param *param)
Get the value of an optional GPIO.
Definition: no_os_gpio.c:81