1fda8d26eSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
2f87f1a23SLars-Peter Clausen /*
3f87f1a23SLars-Peter Clausen  * AD7792/AD7793 SPI ADC driver
4f87f1a23SLars-Peter Clausen  *
5f87f1a23SLars-Peter Clausen  * Copyright 2011 Analog Devices Inc.
6f87f1a23SLars-Peter Clausen  */
7f87f1a23SLars-Peter Clausen #ifndef __LINUX_PLATFORM_DATA_AD7793_H__
8f87f1a23SLars-Peter Clausen #define __LINUX_PLATFORM_DATA_AD7793_H__
9f87f1a23SLars-Peter Clausen 
10f87f1a23SLars-Peter Clausen /**
11f87f1a23SLars-Peter Clausen  * enum ad7793_clock_source - AD7793 clock source selection
12f87f1a23SLars-Peter Clausen  * @AD7793_CLK_SRC_INT: Internal 64 kHz clock, not available at the CLK pin.
13f87f1a23SLars-Peter Clausen  * @AD7793_CLK_SRC_INT_CO: Internal 64 kHz clock, available at the CLK pin.
14f87f1a23SLars-Peter Clausen  * @AD7793_CLK_SRC_EXT: Use external clock.
15f87f1a23SLars-Peter Clausen  * @AD7793_CLK_SRC_EXT_DIV2: Use external clock divided by 2.
16f87f1a23SLars-Peter Clausen  */
17f87f1a23SLars-Peter Clausen enum ad7793_clock_source {
18f87f1a23SLars-Peter Clausen 	AD7793_CLK_SRC_INT,
19f87f1a23SLars-Peter Clausen 	AD7793_CLK_SRC_INT_CO,
20f87f1a23SLars-Peter Clausen 	AD7793_CLK_SRC_EXT,
21f87f1a23SLars-Peter Clausen 	AD7793_CLK_SRC_EXT_DIV2,
22f87f1a23SLars-Peter Clausen };
23f87f1a23SLars-Peter Clausen 
24f87f1a23SLars-Peter Clausen /**
25f87f1a23SLars-Peter Clausen  * enum ad7793_bias_voltage - AD7793 bias voltage selection
26f87f1a23SLars-Peter Clausen  * @AD7793_BIAS_VOLTAGE_DISABLED: Bias voltage generator disabled
27f87f1a23SLars-Peter Clausen  * @AD7793_BIAS_VOLTAGE_AIN1: Bias voltage connected to AIN1(-).
28f87f1a23SLars-Peter Clausen  * @AD7793_BIAS_VOLTAGE_AIN2: Bias voltage connected to AIN2(-).
29f87f1a23SLars-Peter Clausen  * @AD7793_BIAS_VOLTAGE_AIN3: Bias voltage connected to AIN3(-).
30f87f1a23SLars-Peter Clausen  *	Only valid for AD7795/AD7796.
31f87f1a23SLars-Peter Clausen  */
32f87f1a23SLars-Peter Clausen enum ad7793_bias_voltage {
33f87f1a23SLars-Peter Clausen 	AD7793_BIAS_VOLTAGE_DISABLED,
34f87f1a23SLars-Peter Clausen 	AD7793_BIAS_VOLTAGE_AIN1,
35f87f1a23SLars-Peter Clausen 	AD7793_BIAS_VOLTAGE_AIN2,
36f87f1a23SLars-Peter Clausen 	AD7793_BIAS_VOLTAGE_AIN3,
37f87f1a23SLars-Peter Clausen };
38f87f1a23SLars-Peter Clausen 
39f87f1a23SLars-Peter Clausen /**
40f87f1a23SLars-Peter Clausen  * enum ad7793_refsel - AD7793 reference voltage selection
41f87f1a23SLars-Peter Clausen  * @AD7793_REFSEL_REFIN1: External reference applied between REFIN1(+)
42f87f1a23SLars-Peter Clausen  *	and REFIN1(-).
43*781cb90bSRandy Dunlap  * @AD7793_REFSEL_REFIN2: External reference applied between REFIN2(+)
44f87f1a23SLars-Peter Clausen  *	and REFIN1(-). Only valid for AD7795/AD7796.
45f87f1a23SLars-Peter Clausen  * @AD7793_REFSEL_INTERNAL: Internal 1.17 V reference.
46f87f1a23SLars-Peter Clausen  */
47f87f1a23SLars-Peter Clausen enum ad7793_refsel {
48f87f1a23SLars-Peter Clausen 	AD7793_REFSEL_REFIN1 = 0,
49f87f1a23SLars-Peter Clausen 	AD7793_REFSEL_REFIN2 = 1,
50f87f1a23SLars-Peter Clausen 	AD7793_REFSEL_INTERNAL = 2,
51f87f1a23SLars-Peter Clausen };
52f87f1a23SLars-Peter Clausen 
53f87f1a23SLars-Peter Clausen /**
54f87f1a23SLars-Peter Clausen  * enum ad7793_current_source_direction - AD7793 excitation current direction
55f87f1a23SLars-Peter Clausen  * @AD7793_IEXEC1_IOUT1_IEXEC2_IOUT2: Current source IEXC1 connected to pin
56f87f1a23SLars-Peter Clausen  *	IOUT1, current source IEXC2 connected to pin IOUT2.
57f87f1a23SLars-Peter Clausen  * @AD7793_IEXEC1_IOUT2_IEXEC2_IOUT1: Current source IEXC2 connected to pin
58f87f1a23SLars-Peter Clausen  *	IOUT1, current source IEXC1 connected to pin IOUT2.
59f87f1a23SLars-Peter Clausen  * @AD7793_IEXEC1_IEXEC2_IOUT1: Both current sources connected to pin IOUT1.
60f87f1a23SLars-Peter Clausen  *	Only valid when the current sources are set to 10 uA or 210 uA.
61f87f1a23SLars-Peter Clausen  * @AD7793_IEXEC1_IEXEC2_IOUT2: Both current sources connected to Pin IOUT2.
62f87f1a23SLars-Peter Clausen  *	Only valid when the current ources are set to 10 uA or 210 uA.
63f87f1a23SLars-Peter Clausen  */
64f87f1a23SLars-Peter Clausen enum ad7793_current_source_direction {
65f87f1a23SLars-Peter Clausen 	AD7793_IEXEC1_IOUT1_IEXEC2_IOUT2 = 0,
66f87f1a23SLars-Peter Clausen 	AD7793_IEXEC1_IOUT2_IEXEC2_IOUT1 = 1,
67f87f1a23SLars-Peter Clausen 	AD7793_IEXEC1_IEXEC2_IOUT1 = 2,
68f87f1a23SLars-Peter Clausen 	AD7793_IEXEC1_IEXEC2_IOUT2 = 3,
69f87f1a23SLars-Peter Clausen };
70f87f1a23SLars-Peter Clausen 
71f87f1a23SLars-Peter Clausen /**
72f87f1a23SLars-Peter Clausen  * enum ad7793_excitation_current - AD7793 excitation current selection
73f87f1a23SLars-Peter Clausen  * @AD7793_IX_DISABLED: Excitation current Disabled.
74f87f1a23SLars-Peter Clausen  * @AD7793_IX_10uA: Enable 10 micro-ampere excitation current.
75f87f1a23SLars-Peter Clausen  * @AD7793_IX_210uA: Enable 210 micro-ampere excitation current.
76f87f1a23SLars-Peter Clausen  * @AD7793_IX_1mA: Enable 1 milli-Ampere excitation current.
77f87f1a23SLars-Peter Clausen  */
78f87f1a23SLars-Peter Clausen enum ad7793_excitation_current {
79f87f1a23SLars-Peter Clausen 	AD7793_IX_DISABLED = 0,
80f87f1a23SLars-Peter Clausen 	AD7793_IX_10uA = 1,
81f87f1a23SLars-Peter Clausen 	AD7793_IX_210uA = 2,
82f87f1a23SLars-Peter Clausen 	AD7793_IX_1mA = 3,
83f87f1a23SLars-Peter Clausen };
84f87f1a23SLars-Peter Clausen 
85f87f1a23SLars-Peter Clausen /**
86f87f1a23SLars-Peter Clausen  * struct ad7793_platform_data - AD7793 platform data
87f87f1a23SLars-Peter Clausen  * @clock_src: Clock source selection
88f87f1a23SLars-Peter Clausen  * @burnout_current: If set to true the 100nA burnout current is enabled.
89f87f1a23SLars-Peter Clausen  * @boost_enable: Enable boost for the bias voltage generator.
90f87f1a23SLars-Peter Clausen  * @buffered: If set to true configure the device for buffered input mode.
91f87f1a23SLars-Peter Clausen  * @unipolar: If set to true sample in unipolar mode, if set to false sample in
92f87f1a23SLars-Peter Clausen  *		bipolar mode.
93f87f1a23SLars-Peter Clausen  * @refsel: Reference voltage selection
94f87f1a23SLars-Peter Clausen  * @bias_voltage: Bias voltage selection
95f87f1a23SLars-Peter Clausen  * @exitation_current: Excitation current selection
96f87f1a23SLars-Peter Clausen  * @current_source_direction: Excitation current direction selection
97f87f1a23SLars-Peter Clausen  */
98f87f1a23SLars-Peter Clausen struct ad7793_platform_data {
99f87f1a23SLars-Peter Clausen 	enum ad7793_clock_source clock_src;
100f87f1a23SLars-Peter Clausen 	bool burnout_current;
101f87f1a23SLars-Peter Clausen 	bool boost_enable;
102f87f1a23SLars-Peter Clausen 	bool buffered;
103f87f1a23SLars-Peter Clausen 	bool unipolar;
104f87f1a23SLars-Peter Clausen 
105f87f1a23SLars-Peter Clausen 	enum ad7793_refsel refsel;
106f87f1a23SLars-Peter Clausen 	enum ad7793_bias_voltage bias_voltage;
107f87f1a23SLars-Peter Clausen 	enum ad7793_excitation_current exitation_current;
108f87f1a23SLars-Peter Clausen 	enum ad7793_current_source_direction current_source_direction;
109f87f1a23SLars-Peter Clausen };
110f87f1a23SLars-Peter Clausen 
111f87f1a23SLars-Peter Clausen #endif /* IIO_ADC_AD7793_H_ */
112