Go to the documentation of this file.
37 #include "drv_digital_out.h"
38 #include "drv_digital_in.h"
39 #include "drv_spi_master.h"
53 #define ADC6_MAP_MIKROBUS( cfg, mikrobus ) \
54 cfg.miso = MIKROBUS( mikrobus, MIKROBUS_MISO ); \
55 cfg.mosi = MIKROBUS( mikrobus, MIKROBUS_MOSI ); \
56 cfg.sck = MIKROBUS( mikrobus, MIKROBUS_SCK ); \
57 cfg.cs = MIKROBUS( mikrobus, MIKROBUS_CS ); \
58 cfg.syn = MIKROBUS( mikrobus, MIKROBUS_RST )
73 #define ADC6_COMMUNICATION_AND_STATUS_REG 0x00
74 #define ADC6_CONTROL_REG 0x01
75 #define ADC6_DATA_REG 0x02
76 #define ADC6_IO_CONTROL_1_REG 0x03
77 #define ADC6_IO_CONTROL_2_REG 0x04
78 #define ADC6_ID_REG 0x05
79 #define ADC6_ERROR_STATUS_REG 0x06
80 #define ADC6_ERROR_ENABLE_REG 0x07
81 #define ADC6_MASTER_CLOCK_COUNTER_REG 0x08
82 #define ADC6_CHANNEL_0_REG 0x09
83 #define ADC6_CHANNEL_1_REG 0x0A
84 #define ADC6_CHANNEL_2_REG 0x0B
85 #define ADC6_CHANNEL_3_REG 0x0C
86 #define ADC6_CHANNEL_4_REG 0x0D
87 #define ADC6_CHANNEL_5_REG 0x0E
88 #define ADC6_CHANNEL_6_REG 0x0F
89 #define ADC6_CHANNEL_7_REG 0x10
90 #define ADC6_CHANNEL_8_REG 0x11
91 #define ADC6_CHANNEL_9_REG 0x12
92 #define ADC6_CHANNEL_10_REG 0x13
93 #define ADC6_CHANNEL_11_REG 0x14
94 #define ADC6_CHANNEL_12_REG 0x15
95 #define ADC6_CHANNEL_13_REG 0x16
96 #define ADC6_CHANNEL_14_REG 0x17
97 #define ADC6_CHANNEL_15_REG 0x18
98 #define ADC6_CONFIG_0_REG 0x19
99 #define ADC6_CONFIG_1_REG 0x1A
100 #define ADC6_CONFIG_2_REG 0x1B
101 #define ADC6_CONFIG_3_REG 0x1C
102 #define ADC6_CONFIG_4_REG 0x1D
103 #define ADC6_CONFIG_5_REG 0x1E
104 #define ADC6_CONFIG_6_REG 0x1F
105 #define ADC6_CONFIG_7_REG 0x20
106 #define ADC6_FILTER_0_REG 0x21
107 #define ADC6_FILTER_1_REG 0x22
108 #define ADC6_FILTER_2_REG 0x23
109 #define ADC6_FILTER_3_REG 0x24
110 #define ADC6_FILTER_4_REG 0x25
111 #define ADC6_FILTER_5_REG 0x26
112 #define ADC6_FILTER_6_REG 0x27
113 #define ADC6_FILTER_7_REG 0x28
114 #define ADC6_OFFSET_0_REG 0x29
115 #define ADC6_OFFSET_1_REG 0x2A
116 #define ADC6_OFFSET_2_REG 0x2B
117 #define ADC6_OFFSET_3_REG 0x2C
118 #define ADC6_OFFSET_4_REG 0x2D
119 #define ADC6_OFFSET_5_REG 0x2E
120 #define ADC6_OFFSET_6_REG 0x2F
121 #define ADC6_OFFSET_7_REG 0x30
122 #define ADC6_GAIN_0_REG 0x31
123 #define ADC6_GAIN_1_REG 0x32
124 #define ADC6_GAIN_2_REG 0x33
125 #define ADC6_GAIN_3_REG 0x34
126 #define ADC6_GAIN_4_REG 0x35
127 #define ADC6_GAIN_5_REG 0x36
128 #define ADC6_GAIN_6_REG 0x37
129 #define ADC6_GAIN_7_REG 0x38
136 #define ADC6_COMMUN_WRITE_COMMAND 0x00
137 #define ADC6_COMMUN_READ_COMMAND 0x40
138 #define ADC6_COMMUN_WRITE_DISABLE 0x80
145 #define ADC6_CONTROL_RDY_DELAY_10NS_LOW_POWER_MODE_RDY_PIN_ENABLE 0x0000
146 #define ADC6_CONTROL_RDY_DELAY_100NS 0x1000
147 #define ADC6_CONTROL_CONTINUOUS_CONVERSION_MODE 0x0800
148 #define ADC6_CONTROL_DATA_STATUS_ENABLE 0x0400
149 #define ADC6_CONTROL_DOUT_PIN_ENABLE 0x0200
150 #define ADC6_CONTROL_INTERNAL_REFERENCE_VOLTAGE_ENABLE 0x0100
151 #define ADC6_CONTROL_MID_POWER_MODE 0x0040
152 #define ADC6_CONTROL_FULL_POWER_MODE 0x0080
153 #define ADC6_CONTROL_SINGLE_CONVERSION_MODE 0x0004
154 #define ADC6_CONTROL_STANDBY_MODE 0x0008
155 #define ADC6_CONTROL_SINGLE_POWER_DOWN_MODE 0x000C
156 #define ADC6_CONTROL_IDLE_MODE 0x0010
157 #define ADC6_CONTROL_MODE_MASK 0x003C
158 #define ADC6_CONTROL_INTERNAL_ZERO_SCALE_OFFSET_CALIBRATION 0x0014
159 #define ADC6_CONTROL_INTERNAL_FULL_SCALE_GAIN_CALIBRATION 0x0018
160 #define ADC6_CONTROL_SYSTEM_ZERO_SCALE_OFFSET_CALIBRATION 0x001C
161 #define ADC6_CONTROL_SYSTEM_FULL_SCALE_GAIN_CALIBRATION 0x0020
168 #define ADC6_IO_CON1_DIGITAL_OUTPUT_PINS_DISABLE_CURRENT_DISABLE 0x00000000
169 #define ADC6_IO_CON1_SET_DIGITAL_OUTPUT_PIN_P4 0x00800000
170 #define ADC6_IO_CON1_SET_DIGITAL_OUTPUT_PIN_P3 0x00400000
171 #define ADC6_IO_CON1_SET_DIGITAL_OUTPUT_PIN_P2 0x00200000
172 #define ADC6_IO_CON1_SET_DIGITAL_OUTPUT_PIN_P1 0x00100000
173 #define ADC6_IO_CON1_ENABLE_DIGITAL_OUTPUT_PIN_P4 0x00080000
174 #define ADC6_IO_CON1_ENABLE_DIGITAL_OUTPUT_PIN_P3 0x00040000
175 #define ADC6_IO_CON1_ENABLE_DIGITAL_OUTPUT_PIN_P2 0x00020000
176 #define ADC6_IO_CON1_ENABLE_DIGITAL_OUTPUT_PIN_P1 0x00010000
177 #define ADC6_IO_CON1_ENABLE_BRIGDE_POWER_DOWN 0x00008000
178 #define ADC6_IO_CON1_IOUT1_CURRENT_50_MIKRO_A 0x00000800
179 #define ADC6_IO_CON1_IOUT1_CURRENT_100_MIKRO_A 0x00001000
180 #define ADC6_IO_CON1_IOUT1_CURRENT_250_MIKRO_A 0x00001800
181 #define ADC6_IO_CON1_IOUT1_CURRENT_500_MIKRO_A 0x00002000
182 #define ADC6_IO_CON1_IOUT1_CURRENT_750_MIKRO_A 0x00002800
183 #define ADC6_IO_CON1_IOUT1_CURRENT_1000_MIKRO_A 0x00003000
184 #define ADC6_IO_CON1_IOUT0_CURRENT_50_MIKRO_A 0x00000100
185 #define ADC6_IO_CON1_IOUT0_CURRENT_100_MIKRO_A 0x00000200
186 #define ADC6_IO_CON1_IOUT0_CURRENT_250_MIKRO_A 0x00000300
187 #define ADC6_IO_CON1_IOUT0_CURRENT_500_MIKRO_A 0x00000400
188 #define ADC6_IO_CON1_IOUT0_CURRENT_750_MIKRO_A 0x00000500
189 #define ADC6_IO_CON1_IOUT0_CURRENT_1000_MIKRO_A 0x00000600
190 #define ADC6_IO_CON1_IOUT1_ON_AIN0_PIN 0x00000000
191 #define ADC6_IO_CON1_IOUT1_ON_AIN1_PIN 0x00000010
192 #define ADC6_IO_CON1_IOUT1_ON_AIN2_PIN 0x00000020
193 #define ADC6_IO_CON1_IOUT1_ON_AIN3_PIN 0x00000030
194 #define ADC6_IO_CON1_IOUT1_ON_AIN4_PIN 0x00000040
195 #define ADC6_IO_CON1_IOUT1_ON_AIN5_PIN 0x00000050
196 #define ADC6_IO_CON1_IOUT1_ON_AIN6_PIN 0x00000060
197 #define ADC6_IO_CON1_IOUT1_ON_AIN7_PIN 0x00000070
198 #define ADC6_IO_CON1_IOUT1_ON_AIN8_PIN 0x00000080
199 #define ADC6_IO_CON1_IOUT1_ON_AIN9_PIN 0x00000090
200 #define ADC6_IO_CON1_IOUT1_ON_AIN10_PIN 0x000000A0
201 #define ADC6_IO_CON1_IOUT1_ON_AIN11_PIN 0x000000B0
202 #define ADC6_IO_CON1_IOUT1_ON_AIN12_PIN 0x000000C0
203 #define ADC6_IO_CON1_IOUT1_ON_AIN13_PIN 0x000000D0
204 #define ADC6_IO_CON1_IOUT1_ON_AIN14_PIN 0x000000E0
205 #define ADC6_IO_CON1_IOUT1_ON_AIN15_PIN 0x000000F0
206 #define ADC6_IO_CON1_IOUT0_ON_AIN0_PIN 0x00000000
207 #define ADC6_IO_CON1_IOUT0_ON_AIN1_PIN 0x00000001
208 #define ADC6_IO_CON1_IOUT0_ON_AIN2_PIN 0x00000002
209 #define ADC6_IO_CON1_IOUT0_ON_AIN3_PIN 0x00000003
210 #define ADC6_IO_CON1_IOUT0_ON_AIN4_PIN 0x00000004
211 #define ADC6_IO_CON1_IOUT0_ON_AIN5_PIN 0x00000005
212 #define ADC6_IO_CON1_IOUT0_ON_AIN6_PIN 0x00000006
213 #define ADC6_IO_CON1_IOUT0_ON_AIN7_PIN 0x00000007
214 #define ADC6_IO_CON1_IOUT0_ON_AIN8_PIN 0x00000008
215 #define ADC6_IO_CON1_IOUT0_ON_AIN9_PIN 0x00000009
216 #define ADC6_IO_CON1_IOUT0_ON_AIN10_PIN 0x0000000A
217 #define ADC6_IO_CON1_IOUT0_ON_AIN11_PIN 0x0000000B
218 #define ADC6_IO_CON1_IOUT0_ON_AIN12_PIN 0x0000000C
219 #define ADC6_IO_CON1_IOUT0_ON_AIN13_PIN 0x0000000D
220 #define ADC6_IO_CON1_IOUT0_ON_AIN14_PIN 0x0000000E
221 #define ADC6_IO_CON1_IOUT0_ON_AIN15_PIN 0x0000000F
228 #define ADC6_IO_CON2_VBIAS_DISABLE 0x0000
229 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN0_CHANNEL 0x0001
230 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN1_CHANNEL 0x0002
231 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN2_CHANNEL 0x0004
232 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN3_CHANNEL 0x0008
233 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN4_CHANNEL 0x0010
234 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN5_CHANNEL 0x0020
235 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN6_CHANNEL 0x0040
236 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN7_CHANNEL 0x0080
237 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN8_CHANNEL 0x0100
238 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN9_CHANNEL 0x0200
239 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN10_CHANNEL 0x0400
240 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN11_CHANNEL 0x0800
241 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN12_CHANNEL 0x1000
242 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN13_CHANNEL 0x2000
243 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN14_CHANNEL 0x4000
244 #define ADC6_IO_CON2_VBIAS_ENABLE_ON_AIN15_CHANNEL 0x8000
251 #define ADC6_DISABLE_ALL_ERROR_FLAG 0x00000000
252 #define ADC6_ENABLE_MASTER_CLOCK_COUNTER 0x00400000
253 #define ADC6_ENABLE_LDO_CAPACITOR_TEST_CHECK 0x00200000
254 #define ADC6_ENABLE_ANALOG_LDO_CALIBRATION_CHECK 0x00080000
255 #define ADC6_ENABLE_DIGITAL_LDO_CALIBRATION_CHECK 0x00100000
256 #define ADC6_DISABLE_LDO_CHECK 0x00180000
257 #define ADC6_ENABLE_CALIBRATION_FAIL_CHECK 0x00040000
258 #define ADC6_ENABLE_CONVERSION_FAIL_CHECK 0x00020000
259 #define ADC6_ENABLE_SATURATION_CHECK 0x00010000
260 #define ADC6_ENABLE_OVERVOLTAGE_MONITOR_ON_AINP_CHANNELS 0x00008000
261 #define ADC6_ENABLE_UNDERVOLTAGE_MONITOR_ON_AINP_CHANNELS 0x00004000
262 #define ADC6_ENABLE_OVERVOLTAGE_MONITOR_ON_AINM_CHANNELS 0x00002000
263 #define ADC6_ENABLE_UNDERVOLTAGE_MONITOR_ON_AINM_CHANNELS 0x00001000
264 #define ADC6_ENABLE_EXT_REFERENCE_DETECT_ERROR 0x00000800
265 #define ADC6_ENABLE_DIG_LDO_TEST_MECHANISM_CHECK 0x00000400
266 #define ADC6_ENABLE_DIG_LDO_VOLTAGE_MONITORING 0x00000200
267 #define ADC6_ENABLE_AN_LDO_TEST_MECHANISM_CHECK 0x00000100
268 #define ADC6_ENABLE_AN_LDO_VOLTAGE_MONITORING 0x00000080
269 #define ADC6_ENABLE_SPI_IGNORE_ERROR 0x00000040
270 #define ADC6_ENABLE_SPI_SCLK_COUNTER_ERROR_CHECK 0x00000020
271 #define ADC6_ENABLE_SPI_READ_ERROR_CHECK 0x00000010
272 #define ADC6_ENABLE_SPI_WRITE_ERROR_CHECK 0x00000008
273 #define ADC6_ENABLE_SPI_CRC_CHECK 0x00000004
274 #define ADC6_ENABLE_SPI_CRC_CALCULATION_PERFORMING_ON_MEMORY 0x00000002
281 #define ADC6_DISABLE_CHANNEL 0x0000
282 #define ADC6_ENABLE_CHANNEL 0x8000
283 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN0 0x0000
284 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN1 0x0020
285 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN2 0x0040
286 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN3 0x0060
287 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN4 0x0080
288 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN5 0x00A0
289 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN6 0x00C0
290 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN7 0x00E0
291 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN8 0x0100
292 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN9 0x0120
293 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN10 0x0140
294 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN11 0x0160
295 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN12 0x0180
296 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN13 0x01A0
297 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN14 0x01C0
298 #define ADC6_CHANNEL_POSITIVE_ANALOG_INPUT_AIN15 0x01E0
299 #define ADC6_POSITIVE_CHANNEL_TEMPERATURE_SENSOR 0x0200
300 #define ADC6_POSITIVE_CHANNEL_AVSS 0x0220
301 #define ADC6_POSITIVE_CHANNEL_INTERNAL_REFERENCE 0x0240
302 #define ADC6_POSITIVE_CHANNEL_DGND 0x0260
303 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN0 0x0000
304 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN1 0x0001
305 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN2 0x0002
306 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN3 0x0003
307 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN4 0x0004
308 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN5 0x0005
309 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN6 0x0006
310 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN7 0x0007
311 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN8 0x0008
312 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN9 0x0009
313 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN10 0x000A
314 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN11 0x000B
315 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN12 0x000C
316 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN13 0x000D
317 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN14 0x000E
318 #define ADC6_CHANNEL_NEGATIVE_ANALOG_INPUT_AIN15 0x000F
319 #define ADC6_NEGATIVE_CHANNEL_TEMPERATURE_SENSOR 0x0010
320 #define ADC6_NEGATIVE_CHANNEL_AVSS 0x0011
321 #define ADC6_NEGATIVE_CHANNEL_INTERNAL_REFERENCE 0x0012
322 #define ADC6_NEGATIVE_CHANNEL_DGND 0x0013
329 #define ADC6_CONFIG_UNIPOLAR_OP_BUFFER_DISABLE_BURNOUT_CURRENT_OFF 0x0000
330 #define ADC6_CONFIG_ENABLE_BIPOLAR_OP 0x0800
331 #define ADC6_CONFIG_ENABLE_BURNOUT_CURRENT_ON_500_NANO_A 0x0200
332 #define ADC6_CONFIG_ENABLE_BURNOUT_CURRENT_ON_2_MIKRO_A 0x0400
333 #define ADC6_CONFIG_ENABLE_BURNOUT_CURRENT_ON_4_MIKRO_A 0x0600
334 #define ADC6_CONFIG_ENABLE_BUFFER_ON_REFIN_POSITIVE 0x0100
335 #define ADC6_CONFIG_ENABLE_BUFFER_ON_REFIN_NEGATIVE 0x0080
336 #define ADC6_CONFIG_ENABLE_BUFFER_ON_AINP 0x0040
337 #define ADC6_CONFIG_ENABLE_BUFFER_ON_AINM 0x0020
338 #define ADC6_CONFIG_SELECT_REFIN1 0x0000
339 #define ADC6_CONFIG_SELECT_REFIN2 0x0008
340 #define ADC6_CONFIG_SELECT_INTERNAL_REFERENCE 0x0010
341 #define ADC6_CONFIG_SELECT_AVDD_FOR_REFERENCE 0x0018
342 #define ADC6_CONFIG_SET_GAIN_1 0x0000
343 #define ADC6_CONFIG_SET_GAIN_2 0x0001
344 #define ADC6_CONFIG_SET_GAIN_4 0x0002
345 #define ADC6_CONFIG_SET_GAIN_8 0x0003
346 #define ADC6_CONFIG_SET_GAIN_16 0x0004
347 #define ADC6_CONFIG_SET_GAIN_32 0x0005
348 #define ADC6_CONFIG_SET_GAIN_64 0x0006
349 #define ADC6_CONFIG_SET_GAIN_128 0x0007
uint32_t adc6_get_adc_data(adc6_t *ctx)
Get data function.
pin_name_t mosi
Definition: adc6.h:385
pin_name_t sck
Definition: adc6.h:386
uint32_t spi_speed
Definition: adc6.h:395
spi_master_mode_t spi_mode
Definition: adc6.h:396
err_t adc6_init(adc6_t *ctx, adc6_cfg_t *cfg)
Initialization function.
void adc6_default_cfg(adc6_t *ctx)
Click Default Configuration function.
pin_name_t syn
Definition: adc6.h:391
spi_master_chip_select_polarity_t cs_polarity
Definition: adc6.h:397
pin_name_t cs
Definition: adc6.h:387
digital_out_t syn
Definition: adc6.h:368
void adc6_write_reg(adc6_t *ctx, uint8_t register_address, uint32_t transfer_data)
Generic write function.
spi_master_t spi
Definition: adc6.h:372
void adc6_reset_device(adc6_t *ctx)
Reset device.
Click ctx object definition.
Definition: adc6.h:363
void adc6_cfg_setup(adc6_cfg_t *cfg)
Config Object Initialization function.
Click configuration structure definition.
Definition: adc6.h:381
digital_out_t cs
Definition: adc6.h:364
pin_name_t miso
Definition: adc6.h:384
pin_name_t chip_select
Definition: adc6.h:373
uint32_t adc6_read_reg(adc6_t *ctx, uint8_t register_address)
Generic read function.