no-OS
adaq8092.h
Go to the documentation of this file.
1 /***************************************************************************/
39 #ifndef __ADAQ8092_H__
40 #define __ADAQ8092_H__
41 
42 /******************************************************************************/
43 /***************************** Include Files **********************************/
44 /******************************************************************************/
45 #include <stdint.h>
46 #include <string.h>
47 #include "no_os_util.h"
48 #include "no_os_spi.h"
49 #include "no_os_gpio.h"
50 
51 /******************************************************************************/
52 /********************** Macros and Constants Definitions **********************/
53 /******************************************************************************/
54 /* SPI commands */
55 #define ADAQ8092_SPI_READ NO_OS_BIT(7)
56 #define ADAQ8092_ADDR(x) ((x) & 0xFF)
57 
58 /* ADAQ8092 Register Map */
59 #define ADAQ8092_REG_RESET 0x00
60 #define ADAQ8092_REG_POWERDOWN 0x01
61 #define ADAQ8092_REG_TIMING 0x02
62 #define ADAQ8092_REG_OUTPUT_MODE 0x03
63 #define ADAQ8092_REG_DATA_FORMAT 0x04
64 
65 /* ADAQ8092_REG_RESET Bit Definition */
66 #define ADAQ8092_RESET NO_OS_BIT(7)
67 
68 /* ADAQ8092_REG_POWERDOWN Bit Definition */
69 #define ADAQ8092_POWERDOWN_MODE NO_OS_GENMASK(1, 0)
70 
71 /* ADAQ8092_REG_TIMING Bit Definition */
72 #define ADAQ8092_CLK_INVERT NO_OS_BIT(3)
73 #define ADAQ8092_CLK_PHASE NO_OS_GENMASK(2, 1)
74 #define ADAQ8092_CLK_DUTYCYCLE NO_OS_BIT(0)
75 
76 /* ADAQ8092_REG_OUTPUT_MODE Bit Definition */
77 #define ADAQ8092_ILVDS NO_OS_GENMASK(6, 4)
78 #define ADAQ8092_TERMON NO_OS_BIT(3)
79 #define ADAQ8092_OUTOFF NO_OS_BIT(2)
80 #define ADAQ8092_OUTMODE NO_OS_GENMASK(1, 0)
81 
82 /* ADAQ8092_REG_DATA_FORMAT Bit Definition */
83 #define ADAQ8092_OUTTEST NO_OS_GENMASK(5, 3)
84 #define ADAQ8092_ABP NO_OS_BIT(2)
85 #define ADAQ8092_RAND NO_OS_BIT(1)
86 #define ADAQ8092_TWOSCOMP NO_OS_BIT(0)
87 
88 /******************************************************************************/
89 /*************************** Types Declarations *******************************/
90 /******************************************************************************/
91 /* ADAQ8092 Power Down Modes */
97 };
98 
99 /* ADAQ8092 Output Clock Invert */
103 };
104 
105 /* ADAQ8092 Output Clock Phase Delay Bits */
111 };
112 
113 /*ADAQ8092 Clock Duty Cycle Stabilizer */
117 };
118 
119 /* ADAQ8092 LVDS Output Current */
128 };
129 
130 /* ADAQ8092 LVDS Internal Termination */
134 };
135 
136 /* ADAQ8092 Digital Output */
140 };
141 
142 /* ADAQ8092 Digital Output Mode */
147 };
148 
149 /* ADAQ8092 Digital Test Pattern */
156 };
157 
158 /* ADAQ8092 Alternate Bit Polarity Mode */
162 };
163 
164 /* ADAQ8092 Data Output Randomizer*/
168 };
169 
170 /* ADAQ8092 Twos Complement Mode */
174 };
175 
199 };
200 
205 struct adaq8092_dev {
224 };
225 
226 /******************************************************************************/
227 /************************ Functions Declarations ******************************/
228 /******************************************************************************/
229 
230 /* Read device register. */
231 int adaq8092_read(struct adaq8092_dev *dev, uint8_t reg_addr,
232  uint8_t *reg_data);
233 
234 /* Write device register. */
235 int adaq8092_write(struct adaq8092_dev *dev, uint8_t reg_addr,
236  uint8_t reg_data);
237 
238 /* Update specific register bits. */
239 int adaq8092_update_bits(struct adaq8092_dev *dev, uint8_t reg_addr,
240  uint8_t mask, uint8_t reg_data);
241 
242 /* Initialize the device. */
243 int adaq8092_init(struct adaq8092_dev **device,
245 
246 /* Remove the device and release resources. */
247 int adaq8092_remove(struct adaq8092_dev *dev);
248 
249 /* Set the device powerodown mode. */
250 int adaq8092_set_pd_mode(struct adaq8092_dev *dev,
251  enum adaq8092_powerdown_modes mode);
252 
253 /* Get the device powerdown mode. */
255 
256 /* Set the clock polarity mode. */
258  enum adaq8092_clk_invert mode);
259 
260 /* Get the clock polarity mode. */
262 
263 /* Set the clock phase delay mode. */
265  enum adaq8092_clk_phase_delay mode);
266 
267 /* Get the clock phase delay mode. */
269  struct adaq8092_dev *dev);
270 
271 /* Set the clock duty cycle stabilizer mode. */
272 int adaq8092_set_clk_dc_mode(struct adaq8092_dev *dev,
273  enum adaq8092_clk_dutycycle mode);
274 
275 /* Get the clock duty cycle stabilizer mode. */
277 
278 /* Set the LVDS output current mode. */
280  enum adaq8092_lvds_out_current mode);
281 
282 /* Get the LVDS output current mode. */
284  struct adaq8092_dev *dev);
285 
286 /* Set the LVDS internal temination mode. */
288  enum adaq8092_internal_term mode);
289 
290 /* Get the LVDS internal temination device mode. */
292  struct adaq8092_dev *dev);
293 
294 /* Set digital outputs. */
295 int adaq8092_set_dout_en(struct adaq8092_dev *dev,
296  enum adaq8092_dout_enable mode);
297 
298 /* Get digital outputs. */
300 
301 /* Set the digital output mode. */
302 int adaq8092_set_dout_mode(struct adaq8092_dev *dev,
303  enum adaq8092_dout_modes mode);
304 
305 /* Get the digital output mode. */
307 
308 /* Set digital output test pattern mode. */
309 int adaq8092_set_test_mode(struct adaq8092_dev *dev,
310  enum adaq8092_out_test_modes mode);
311 
312 /* Get digital output test pattern mode. */
314 
315 /* Set the alternate bit polarity mode. */
316 int adaq8092_set_alt_pol_en(struct adaq8092_dev *dev,
317  enum adaq8092_alt_bit_pol mode);
318 
319 /* Get the alternate bit polarity mode. */
321 
322 /* Set the data output randomizer mode. */
324  enum adaq8092_data_rand mode);
325 
326 /* Get the data output randomizer mode. */
328 
329 /* Set the Tows Complement mode. */
330 int adaq8092_set_twos_comp(struct adaq8092_dev *dev,
331  enum adaq8092_twoscomp mode);
332 
333 /* Get the Tows Complement mode. */
335 
336 #endif /* __ADAQ8092_H__ */
ADAQ8092_ALT_BIT_POL_OFF
@ ADAQ8092_ALT_BIT_POL_OFF
Definition: adaq8092.h:160
adaq8092_set_test_mode
int adaq8092_set_test_mode(struct adaq8092_dev *dev, enum adaq8092_out_test_modes mode)
Set digital output test pattern mode.
Definition: adaq8092.c:568
adaq8092_get_test_mode
enum adaq8092_out_test_modes adaq8092_get_test_mode(struct adaq8092_dev *dev)
Get digital output test pattern mode.
Definition: adaq8092.c:589
ADAQ8092_CLK_PHASE
#define ADAQ8092_CLK_PHASE
Definition: adaq8092.h:73
no_os_alloc.h
adaq8092_update_bits
int adaq8092_update_bits(struct adaq8092_dev *dev, uint8_t reg_addr, uint8_t mask, uint8_t reg_data)
Update specific register bits.
Definition: adaq8092.c:102
no_os_gpio_init_param
Structure holding the parameters for GPIO initialization.
Definition: no_os_gpio.h:85
adaq8092_read
int adaq8092_read(struct adaq8092_dev *dev, uint8_t reg_addr, uint8_t *reg_data)
Read device register.
Definition: adaq8092.c:61
ADAQ8092_DOUT_OFF
@ ADAQ8092_DOUT_OFF
Definition: adaq8092.h:139
adaq8092_write
int adaq8092_write(struct adaq8092_dev *dev, uint8_t reg_addr, uint8_t reg_data)
Write device register.
Definition: adaq8092.c:84
ADAQ8092_CLK_INVERT
#define ADAQ8092_CLK_INVERT
Definition: adaq8092.h:72
adaq8092_set_lvds_cur_mode
int adaq8092_set_lvds_cur_mode(struct adaq8092_dev *dev, enum adaq8092_lvds_out_current mode)
Set the LVDS output current mode.
Definition: adaq8092.c:438
adaq8092_get_dout_en
enum adaq8092_dout_enable adaq8092_get_dout_en(struct adaq8092_dev *dev)
Get digital outputs.
Definition: adaq8092.c:525
adaq8092_dev::data_rand_en
enum adaq8092_data_rand data_rand_en
Definition: adaq8092.h:222
adaq8092_dev::alt_bit_pol_en
enum adaq8092_alt_bit_pol alt_bit_pol_en
Definition: adaq8092.h:221
ADAQ8092_CLKOUT_DELAY_180DEG
@ ADAQ8092_CLKOUT_DELAY_180DEG
Definition: adaq8092.h:110
adaq8092_set_clk_pol_mode
int adaq8092_set_clk_pol_mode(struct adaq8092_dev *dev, enum adaq8092_clk_invert mode)
Set the clock polarity mode.
Definition: adaq8092.c:341
adaq8092_clk_phase_delay
adaq8092_clk_phase_delay
Definition: adaq8092.h:106
adaq8092_set_pd_mode
int adaq8092_set_pd_mode(struct adaq8092_dev *dev, enum adaq8092_powerdown_modes mode)
Set the device powerodown mode.
Definition: adaq8092.c:309
adaq8092_set_dout_mode
int adaq8092_set_dout_mode(struct adaq8092_dev *dev, enum adaq8092_dout_modes mode)
Set the digital output mode.
Definition: adaq8092.c:536
adaq8092_write
int adaq8092_write(struct adaq8092_dev *dev, uint8_t reg_addr, uint8_t reg_data)
Write device register.
Definition: adaq8092.c:84
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
ADAQ8092_DOUBLE_RATE_CMOS
@ ADAQ8092_DOUBLE_RATE_CMOS
Definition: adaq8092.h:146
adaq8092_dev::gpio_par_ser
struct no_os_gpio_desc * gpio_par_ser
Definition: adaq8092.h:211
adaq8092_dev::clk_pol_mode
enum adaq8092_clk_invert clk_pol_mode
Definition: adaq8092.h:213
adaq8092_set_data_rand_en
int adaq8092_set_data_rand_en(struct adaq8092_dev *dev, enum adaq8092_data_rand mode)
Set the data output randomizer mode.
Definition: adaq8092.c:632
no_os_spi.h
Header file of SPI Interface.
ADAQ8092_OUTMODE
#define ADAQ8092_OUTMODE
Definition: adaq8092.h:80
adaq8092_get_twos_comp
enum adaq8092_twoscomp adaq8092_get_twos_comp(struct adaq8092_dev *dev)
Get the Tows Complement mode.
Definition: adaq8092.c:685
ADAQ8092_DATA_RAND_OFF
@ ADAQ8092_DATA_RAND_OFF
Definition: adaq8092.h:166
adaq8092_dout_modes
adaq8092_dout_modes
Definition: adaq8092.h:143
ADAQ8092_REG_TIMING
#define ADAQ8092_REG_TIMING
Definition: adaq8092.h:61
adaq8092_dout_enable
adaq8092_dout_enable
Definition: adaq8092.h:137
ADAQ8092_CLK_POL_INVERTED
@ ADAQ8092_CLK_POL_INVERTED
Definition: adaq8092.h:102
adaq8092_dev::gpio_en_1p8
struct no_os_gpio_desc * gpio_en_1p8
Definition: adaq8092.h:210
adaq8092_set_dout_en
int adaq8092_set_dout_en(struct adaq8092_dev *dev, enum adaq8092_dout_enable mode)
Set digital outputs.
Definition: adaq8092.c:504
adaq8092_get_test_mode
enum adaq8092_out_test_modes adaq8092_get_test_mode(struct adaq8092_dev *dev)
Get digital output test pattern mode.
Definition: adaq8092.c:589
adaq8092_init_param::gpio_adc_pd1_param
struct no_os_gpio_init_param * gpio_adc_pd1_param
Definition: adaq8092.h:183
ADAQ8092_2M5A
@ ADAQ8092_2M5A
Definition: adaq8092.h:125
adaq8092_clk_dutycycle
adaq8092_clk_dutycycle
Definition: adaq8092.h:114
ADAQ8092_CLK_DC_STABILIZER_ON
@ ADAQ8092_CLK_DC_STABILIZER_ON
Definition: adaq8092.h:116
adaq8092_remove
int adaq8092_remove(struct adaq8092_dev *dev)
Remove the device and release resources.
Definition: adaq8092.c:274
no_os_delay.h
Header file of Delay functions.
adaq8092_remove
int adaq8092_remove(struct adaq8092_dev *dev)
Remove the device and release resources.
Definition: adaq8092.c:274
adaq8092_set_clk_phase_mode
int adaq8092_set_clk_phase_mode(struct adaq8092_dev *dev, enum adaq8092_clk_phase_delay mode)
Set the clock phase delay mode.
Definition: adaq8092.c:373
ADAQ8092_TERM_ON
@ ADAQ8092_TERM_ON
Definition: adaq8092.h:133
device
Definition: ad9361_util.h:75
ADAQ8092_CH1_CH2_NAP
@ ADAQ8092_CH1_CH2_NAP
Definition: adaq8092.h:95
NO_OS_GPIO_HIGH
@ NO_OS_GPIO_HIGH
Definition: no_os_gpio.h:123
adaq8092_set_test_mode
int adaq8092_set_test_mode(struct adaq8092_dev *dev, enum adaq8092_out_test_modes mode)
Set digital output test pattern mode.
Definition: adaq8092.c:568
adaq8092_get_clk_phase_mode
enum adaq8092_clk_phase_delay adaq8092_get_clk_phase_mode(struct adaq8092_dev *dev)
Get the clock phase delay mode.
Definition: adaq8092.c:394
no_os_calloc
void * no_os_calloc(size_t nitems, size_t size)
Allocate memory and return a pointer to it, set memory to 0.
Definition: chibios_alloc.c:60
adaq8092_set_lvds_cur_mode
int adaq8092_set_lvds_cur_mode(struct adaq8092_dev *dev, enum adaq8092_lvds_out_current mode)
Set the LVDS output current mode.
Definition: adaq8092.c:438
ADAQ8092_REG_POWERDOWN
#define ADAQ8092_REG_POWERDOWN
Definition: adaq8092.h:60
ADAQ8092_SLEEP
@ ADAQ8092_SLEEP
Definition: adaq8092.h:96
adaq8092_get_clk_phase_mode
enum adaq8092_clk_phase_delay adaq8092_get_clk_phase_mode(struct adaq8092_dev *dev)
Get the clock phase delay mode.
Definition: adaq8092.c:394
ADAQ8092_CH1_NORMAL_CH2_NAP
@ ADAQ8092_CH1_NORMAL_CH2_NAP
Definition: adaq8092.h:94
adaq8092_init_param::test_mode
enum adaq8092_out_test_modes test_mode
Definition: adaq8092.h:195
NO_OS_GPIO_LOW
@ NO_OS_GPIO_LOW
Definition: no_os_gpio.h:121
ADAQ8092_CLKOUT_DELAY_45DEG
@ ADAQ8092_CLKOUT_DELAY_45DEG
Definition: adaq8092.h:108
ADAQ8092_FULL_RATE_CMOS
@ ADAQ8092_FULL_RATE_CMOS
Definition: adaq8092.h:144
adaq8092_set_data_rand_en
int adaq8092_set_data_rand_en(struct adaq8092_dev *dev, enum adaq8092_data_rand mode)
Set the data output randomizer mode.
Definition: adaq8092.c:632
adaq8092_init_param::alt_bit_pol_en
enum adaq8092_alt_bit_pol alt_bit_pol_en
Definition: adaq8092.h:196
adaq8092_dev::spi_desc
struct no_os_spi_desc * spi_desc
Definition: adaq8092.h:207
no_os_mdelay
void no_os_mdelay(uint32_t msecs)
Wait until msecs milliseconds passed.
Definition: aducm3029_delay.c:132
no_os_field_prep
uint32_t no_os_field_prep(uint32_t mask, uint32_t val)
ADAQ8092_OFFSET_BINARY
@ ADAQ8092_OFFSET_BINARY
Definition: adaq8092.h:172
ADAQ8092_1M75
@ ADAQ8092_1M75
Definition: adaq8092.h:127
adaq8092_init_param::dout_en
enum adaq8092_dout_enable dout_en
Definition: adaq8092.h:193
ADAQ8092_2M1A
@ ADAQ8092_2M1A
Definition: adaq8092.h:126
adaq8092_init_param::gpio_en_1p8_param
struct no_os_gpio_init_param * gpio_en_1p8_param
Definition: adaq8092.h:185
ADAQ8092_POWERDOWN_MODE
#define ADAQ8092_POWERDOWN_MODE
Definition: adaq8092.h:69
adaq8092_init_param::gpio_par_ser_param
struct no_os_gpio_init_param * gpio_par_ser_param
Definition: adaq8092.h:186
ADAQ8092_CLKOUT_DELAY_90DEG
@ ADAQ8092_CLKOUT_DELAY_90DEG
Definition: adaq8092.h:109
adaq8092_get_pd_mode
enum adaq8092_powerdown_modes adaq8092_get_pd_mode(struct adaq8092_dev *dev)
Get the device powerdown mode.
Definition: adaq8092.c:330
adaq8092_twoscomp
adaq8092_twoscomp
Definition: adaq8092.h:171
ADAQ8092_DOUT_ON
@ ADAQ8092_DOUT_ON
Definition: adaq8092.h:138
ADAQ8092_TWOSCOMP
#define ADAQ8092_TWOSCOMP
Definition: adaq8092.h:86
ADAQ8092_TEST_ONES
@ ADAQ8092_TEST_ONES
Definition: adaq8092.h:152
ADAQ8092_TERM_OFF
@ ADAQ8092_TERM_OFF
Definition: adaq8092.h:132
adaq8092_set_twos_comp
int adaq8092_set_twos_comp(struct adaq8092_dev *dev, enum adaq8092_twoscomp mode)
Set the Tows Complement mode.
Definition: adaq8092.c:664
ADAQ8092_DOUBLE_RATE_LVDS
@ ADAQ8092_DOUBLE_RATE_LVDS
Definition: adaq8092.h:145
ADAQ8092_ALT_BIT_POL_ON
@ ADAQ8092_ALT_BIT_POL_ON
Definition: adaq8092.h:161
ADAQ8092_CLK_DUTYCYCLE
#define ADAQ8092_CLK_DUTYCYCLE
Definition: adaq8092.h:74
adaq8092_dev::twos_comp
enum adaq8092_twoscomp twos_comp
Definition: adaq8092.h:223
adaq8092_dev::lvds_term_mode
enum adaq8092_internal_term lvds_term_mode
Definition: adaq8092.h:217
adaq8092_set_pd_mode
int adaq8092_set_pd_mode(struct adaq8092_dev *dev, enum adaq8092_powerdown_modes mode)
Set the device powerodown mode.
Definition: adaq8092.c:309
ADAQ8092_CLK_DC_STABILIZER_OFF
@ ADAQ8092_CLK_DC_STABILIZER_OFF
Definition: adaq8092.h:115
adaq8092_get_clk_pol_mode
enum adaq8092_clk_invert adaq8092_get_clk_pol_mode(struct adaq8092_dev *dev)
Get the clock polarity mode.
Definition: adaq8092.c:362
ADAQ8092_NORMAL_OP
@ ADAQ8092_NORMAL_OP
Definition: adaq8092.h:93
adaq8092_dev::dout_mode
enum adaq8092_dout_modes dout_mode
Definition: adaq8092.h:219
adaq8092_init_param::lvds_cur_mode
enum adaq8092_lvds_out_current lvds_cur_mode
Definition: adaq8092.h:191
adaq8092_dev::lvds_cur_mode
enum adaq8092_lvds_out_current lvds_cur_mode
Definition: adaq8092.h:216
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
adaq8092_get_clk_dc_mode
enum adaq8092_clk_dutycycle adaq8092_get_clk_dc_mode(struct adaq8092_dev *dev)
Get the clock duty cycle stabilizer mode.
Definition: adaq8092.c:427
no_os_spi_desc
Structure holding SPI descriptor.
Definition: no_os_spi.h:177
ADAQ8092_TERMON
#define ADAQ8092_TERMON
Definition: adaq8092.h:78
adaq8092_set_clk_dc_mode
int adaq8092_set_clk_dc_mode(struct adaq8092_dev *dev, enum adaq8092_clk_dutycycle mode)
Set the clock duty cycle stabilizer mode.
Definition: adaq8092.c:406
adaq8092_dev
ADAQ8092 Device structure.
Definition: adaq8092.h:205
ADAQ8092_TWOS_COMPLEMENT
@ ADAQ8092_TWOS_COMPLEMENT
Definition: adaq8092.h:173
ADAQ8092_TEST_ALTERNATING
@ ADAQ8092_TEST_ALTERNATING
Definition: adaq8092.h:155
adaq8092_init
int adaq8092_init(struct adaq8092_dev **device, struct adaq8092_init_param init_param)
Initialize the device.
Definition: adaq8092.c:125
ADAQ8092_DATA_RAND_ON
@ ADAQ8092_DATA_RAND_ON
Definition: adaq8092.h:167
adaq8092_init_param
ADAQ8092 Device initialization parameters.
Definition: adaq8092.h:180
no_os_gpio_desc
Structure holding the GPIO descriptor.
Definition: no_os_gpio.h:102
adaq8092_out_test_modes
adaq8092_out_test_modes
Definition: adaq8092.h:150
adaq8092_get_dout_mode
enum adaq8092_dout_modes adaq8092_get_dout_mode(struct adaq8092_dev *dev)
Get the digital output mode.
Definition: adaq8092.c:557
adaq8092.h
Header file of ADAQ8092 Driver.
ADAQ8092_REG_OUTPUT_MODE
#define ADAQ8092_REG_OUTPUT_MODE
Definition: adaq8092.h:62
adaq8092_set_twos_comp
int adaq8092_set_twos_comp(struct adaq8092_dev *dev, enum adaq8092_twoscomp mode)
Set the Tows Complement mode.
Definition: adaq8092.c:664
adaq8092_init_param::lvds_term_mode
enum adaq8092_internal_term lvds_term_mode
Definition: adaq8092.h:192
ADAQ8092_ILVDS
#define ADAQ8092_ILVDS
Definition: adaq8092.h:77
ADAQ8092_REG_RESET
#define ADAQ8092_REG_RESET
Definition: adaq8092.h:59
ADAQ8092_OUTOFF
#define ADAQ8092_OUTOFF
Definition: adaq8092.h:79
adaq8092_dev::clk_dc_mode
enum adaq8092_clk_dutycycle clk_dc_mode
Definition: adaq8092.h:215
adaq8092_lvds_out_current
adaq8092_lvds_out_current
Definition: adaq8092.h:120
ADAQ8092_ABP
#define ADAQ8092_ABP
Definition: adaq8092.h:84
no_os_gpio_get
int32_t no_os_gpio_get(struct no_os_gpio_desc **desc, const struct no_os_gpio_init_param *param)
Obtain the GPIO decriptor.
Definition: no_os_gpio.c:55
adaq8092_set_clk_phase_mode
int adaq8092_set_clk_phase_mode(struct adaq8092_dev *dev, enum adaq8092_clk_phase_delay mode)
Set the clock phase delay mode.
Definition: adaq8092.c:373
adaq8092_get_pd_mode
enum adaq8092_powerdown_modes adaq8092_get_pd_mode(struct adaq8092_dev *dev)
Get the device powerdown mode.
Definition: adaq8092.c:330
ADAQ8092_3M5A
@ ADAQ8092_3M5A
Definition: adaq8092.h:121
adaq8092_set_clk_pol_mode
int adaq8092_set_clk_pol_mode(struct adaq8092_dev *dev, enum adaq8092_clk_invert mode)
Set the clock polarity mode.
Definition: adaq8092.c:341
adaq8092_dev::clk_phase_mode
enum adaq8092_clk_phase_delay clk_phase_mode
Definition: adaq8092.h:214
adaq8092_get_clk_dc_mode
enum adaq8092_clk_dutycycle adaq8092_get_clk_dc_mode(struct adaq8092_dev *dev)
Get the clock duty cycle stabilizer mode.
Definition: adaq8092.c:427
ADAQ8092_REG_DATA_FORMAT
#define ADAQ8092_REG_DATA_FORMAT
Definition: adaq8092.h:63
adaq8092_set_clk_dc_mode
int adaq8092_set_clk_dc_mode(struct adaq8092_dev *dev, enum adaq8092_clk_dutycycle mode)
Set the clock duty cycle stabilizer mode.
Definition: adaq8092.c:406
adaq8092_dev::pd_mode
enum adaq8092_powerdown_modes pd_mode
Definition: adaq8092.h:212
no_os_free
void no_os_free(void *ptr)
Deallocate memory previously allocated by a call to no_os_calloc or no_os_malloc.
Definition: chibios_alloc.c:75
ADAQ8092_CLK_POL_NORMAL
@ ADAQ8092_CLK_POL_NORMAL
Definition: adaq8092.h:101
adaq8092_init_param::clk_phase_mode
enum adaq8092_clk_phase_delay clk_phase_mode
Definition: adaq8092.h:189
adaq8092_init_param::clk_pol_mode
enum adaq8092_clk_invert clk_pol_mode
Definition: adaq8092.h:188
adaq8092_get_twos_comp
enum adaq8092_twoscomp adaq8092_get_twos_comp(struct adaq8092_dev *dev)
Get the Tows Complement mode.
Definition: adaq8092.c:685
adaq8092_set_lvds_term_mode
int adaq8092_set_lvds_term_mode(struct adaq8092_dev *dev, enum adaq8092_internal_term mode)
Set the LVDS internal temination mode.
Definition: adaq8092.c:471
adaq8092_powerdown_modes
adaq8092_powerdown_modes
Definition: adaq8092.h:92
ADAQ8092_OUTTEST
#define ADAQ8092_OUTTEST
Definition: adaq8092.h:83
adaq8092_internal_term
adaq8092_internal_term
Definition: adaq8092.h:131
adaq8092_init_param::spi_init
struct no_os_spi_init_param * spi_init
Definition: adaq8092.h:182
ADAQ8092_TEST_CHECKERBOARD
@ ADAQ8092_TEST_CHECKERBOARD
Definition: adaq8092.h:154
adaq8092_dev::gpio_adc_pd1
struct no_os_gpio_desc * gpio_adc_pd1
Definition: adaq8092.h:208
adaq8092_get_clk_pol_mode
enum adaq8092_clk_invert adaq8092_get_clk_pol_mode(struct adaq8092_dev *dev)
Get the clock polarity mode.
Definition: adaq8092.c:362
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
ADAQ8092_NO_DELAY
@ ADAQ8092_NO_DELAY
Definition: adaq8092.h:107
adaq8092_get_data_rand_en
enum adaq8092_data_rand adaq8092_get_data_rand_en(struct adaq8092_dev *dev)
Get the data output randomizer mode.
Definition: adaq8092.c:653
adaq8092_get_dout_mode
enum adaq8092_dout_modes adaq8092_get_dout_mode(struct adaq8092_dev *dev)
Get the digital output mode.
Definition: adaq8092.c:557
adaq8092_dev::dout_en
enum adaq8092_dout_enable dout_en
Definition: adaq8092.h:218
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
adaq8092_alt_bit_pol
adaq8092_alt_bit_pol
Definition: adaq8092.h:159
adaq8092_get_lvds_cur_mode
enum adaq8092_lvds_out_current adaq8092_get_lvds_cur_mode(struct adaq8092_dev *dev)
Get the LVDS output current mode.
Definition: adaq8092.c:459
adaq8092_get_lvds_term_mode
enum adaq8092_internal_term adaq8092_get_lvds_term_mode(struct adaq8092_dev *dev)
Get the LVDS internal temination device mode.
Definition: adaq8092.c:492
adaq8092_get_dout_en
enum adaq8092_dout_enable adaq8092_get_dout_en(struct adaq8092_dev *dev)
Get digital outputs.
Definition: adaq8092.c:525
no_os_gpio.h
Header file of GPIO Interface.
adaq8092_clk_invert
adaq8092_clk_invert
Definition: adaq8092.h:100
adaq8092_init_param::clk_dc_mode
enum adaq8092_clk_dutycycle clk_dc_mode
Definition: adaq8092.h:190
adaq8092_set_lvds_term_mode
int adaq8092_set_lvds_term_mode(struct adaq8092_dev *dev, enum adaq8092_internal_term mode)
Set the LVDS internal temination mode.
Definition: adaq8092.c:471
adaq8092_dev::gpio_adc_pd2
struct no_os_gpio_desc * gpio_adc_pd2
Definition: adaq8092.h:209
adaq8092_init_param::data_rand_en
enum adaq8092_data_rand data_rand_en
Definition: adaq8092.h:197
adaq8092_get_data_rand_en
enum adaq8092_data_rand adaq8092_get_data_rand_en(struct adaq8092_dev *dev)
Get the data output randomizer mode.
Definition: adaq8092.c:653
adaq8092_set_alt_pol_en
int adaq8092_set_alt_pol_en(struct adaq8092_dev *dev, enum adaq8092_alt_bit_pol mode)
Set the alternate bit polarity mode.
Definition: adaq8092.c:600
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
adaq8092_init_param::twos_comp
enum adaq8092_twoscomp twos_comp
Definition: adaq8092.h:198
adaq8092_get_lvds_cur_mode
enum adaq8092_lvds_out_current adaq8092_get_lvds_cur_mode(struct adaq8092_dev *dev)
Get the LVDS output current mode.
Definition: adaq8092.c:459
adaq8092_get_alt_pol_en
enum adaq8092_alt_bit_pol adaq8092_get_alt_pol_en(struct adaq8092_dev *dev)
Get the alternate bit polarity mode.
Definition: adaq8092.c:621
adaq8092_init_param::gpio_adc_pd2_param
struct no_os_gpio_init_param * gpio_adc_pd2_param
Definition: adaq8092.h:184
no_os_util.h
Header file of utility functions.
adaq8092_init_param::pd_mode
enum adaq8092_powerdown_modes pd_mode
Definition: adaq8092.h:187
adaq8092_update_bits
int adaq8092_update_bits(struct adaq8092_dev *dev, uint8_t reg_addr, uint8_t mask, uint8_t reg_data)
Update specific register bits.
Definition: adaq8092.c:102
adaq8092_read
int adaq8092_read(struct adaq8092_dev *dev, uint8_t reg_addr, uint8_t *reg_data)
Read device register.
Definition: adaq8092.c:61
ADAQ8092_SPI_READ
#define ADAQ8092_SPI_READ
Definition: adaq8092.h:55
adaq8092_set_alt_pol_en
int adaq8092_set_alt_pol_en(struct adaq8092_dev *dev, enum adaq8092_alt_bit_pol mode)
Set the alternate bit polarity mode.
Definition: adaq8092.c:600
adaq8092_dev::test_mode
enum adaq8092_out_test_modes test_mode
Definition: adaq8092.h:220
adaq8092_data_rand
adaq8092_data_rand
Definition: adaq8092.h:165
ADAQ8092_TEST_OFF
@ ADAQ8092_TEST_OFF
Definition: adaq8092.h:151
ADAQ8092_3MA
@ ADAQ8092_3MA
Definition: adaq8092.h:124
ADAQ8092_4M5A
@ ADAQ8092_4M5A
Definition: adaq8092.h:123
adaq8092_get_alt_pol_en
enum adaq8092_alt_bit_pol adaq8092_get_alt_pol_en(struct adaq8092_dev *dev)
Get the alternate bit polarity mode.
Definition: adaq8092.c:621
ADAQ8092_4MA
@ ADAQ8092_4MA
Definition: adaq8092.h:122
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
adaq8092_set_dout_en
int adaq8092_set_dout_en(struct adaq8092_dev *dev, enum adaq8092_dout_enable mode)
Set digital outputs.
Definition: adaq8092.c:504
ADAQ8092_TEST_ZEROS
@ ADAQ8092_TEST_ZEROS
Definition: adaq8092.h:153
ADAQ8092_RESET
#define ADAQ8092_RESET
Definition: adaq8092.h:66
adaq8092_set_dout_mode
int adaq8092_set_dout_mode(struct adaq8092_dev *dev, enum adaq8092_dout_modes mode)
Set the digital output mode.
Definition: adaq8092.c:536
adaq8092_init_param::dout_mode
enum adaq8092_dout_modes dout_mode
Definition: adaq8092.h:194
errno.h
Error macro definition for ARM Compiler.
adaq8092_get_lvds_term_mode
enum adaq8092_internal_term adaq8092_get_lvds_term_mode(struct adaq8092_dev *dev)
Get the LVDS internal temination device mode.
Definition: adaq8092.c:492
ADAQ8092_RAND
#define ADAQ8092_RAND
Definition: adaq8092.h:85
no_os_spi_init_param
Structure holding the parameters for SPI initialization.
Definition: no_os_spi.h:131
adaq8092_init
int adaq8092_init(struct adaq8092_dev **device, struct adaq8092_init_param init_param)
Initialize the device.
Definition: adaq8092.c:125