blob: 7de6c16122df5f80811c8a949698ad81b058d764 [file] [log] [blame]
Thomas Gleixnerfda8d262019-05-28 09:57:06 -07001/* SPDX-License-Identifier: GPL-2.0-only */
Lars-Peter Clausen8ec4cf52012-06-25 14:52:49 +02002/*
3 * AD7266/65 SPI ADC driver
4 *
5 * Copyright 2012 Analog Devices Inc.
Lars-Peter Clausen8ec4cf52012-06-25 14:52:49 +02006 */
7
8#ifndef __IIO_ADC_AD7266_H__
9#define __IIO_ADC_AD7266_H__
10
11/**
12 * enum ad7266_range - AD7266 reference voltage range
13 * @AD7266_RANGE_VREF: Device is configured for input range 0V - VREF
14 * (RANGE pin set to low)
15 * @AD7266_RANGE_2VREF: Device is configured for input range 0V - 2VREF
16 * (RANGE pin set to high)
17 */
18enum ad7266_range {
19 AD7266_RANGE_VREF,
20 AD7266_RANGE_2VREF,
21};
22
23/**
24 * enum ad7266_mode - AD7266 sample mode
25 * @AD7266_MODE_DIFF: Device is configured for full differential mode
26 * (SGL/DIFF pin set to low, AD0 pin set to low)
27 * @AD7266_MODE_PSEUDO_DIFF: Device is configured for pseudo differential mode
28 * (SGL/DIFF pin set to low, AD0 pin set to high)
29 * @AD7266_MODE_SINGLE_ENDED: Device is configured for single-ended mode
30 * (SGL/DIFF pin set to high)
31 */
32enum ad7266_mode {
33 AD7266_MODE_DIFF,
34 AD7266_MODE_PSEUDO_DIFF,
35 AD7266_MODE_SINGLE_ENDED,
36};
37
38/**
39 * struct ad7266_platform_data - Platform data for the AD7266 driver
40 * @range: Reference voltage range the device is configured for
41 * @mode: Sample mode the device is configured for
42 * @fixed_addr: Whether the address pins are hard-wired
43 * @addr_gpios: GPIOs used for controlling the address pins, only used if
44 * fixed_addr is set to false.
45 */
46struct ad7266_platform_data {
47 enum ad7266_range range;
48 enum ad7266_mode mode;
49 bool fixed_addr;
50 unsigned int addr_gpios[3];
51};
52
53#endif