blob: a48f7a43596cb06022c3102642686e72fcfba2b5 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Marek Vasuta10669a2012-05-01 11:09:48 +00002/*
3 * Freescale i.MX28 LRADC Register Definitions
4 *
5 * Copyright (C) 2011 Marek Vasut <marek.vasut@gmail.com>
6 * on behalf of DENX Software Engineering GmbH
7 *
8 * Based on code from LTIB:
9 * Copyright 2008-2009 Freescale Semiconductor, Inc. All Rights Reserved.
Marek Vasuta10669a2012-05-01 11:09:48 +000010 */
11
12#ifndef __MX28_REGS_LRADC_H__
13#define __MX28_REGS_LRADC_H__
14
Stefano Babic33731bc2017-06-29 10:16:06 +020015#include <asm/mach-imx/regs-common.h>
Marek Vasuta10669a2012-05-01 11:09:48 +000016
17#ifndef __ASSEMBLY__
Otavio Salvador22f4ff92012-08-05 09:05:31 +000018struct mxs_lradc_regs {
Otavio Salvador5309b002012-08-05 09:05:30 +000019 mxs_reg_32(hw_lradc_ctrl0);
20 mxs_reg_32(hw_lradc_ctrl1);
21 mxs_reg_32(hw_lradc_ctrl2);
22 mxs_reg_32(hw_lradc_ctrl3);
23 mxs_reg_32(hw_lradc_status);
24 mxs_reg_32(hw_lradc_ch0);
25 mxs_reg_32(hw_lradc_ch1);
26 mxs_reg_32(hw_lradc_ch2);
27 mxs_reg_32(hw_lradc_ch3);
28 mxs_reg_32(hw_lradc_ch4);
29 mxs_reg_32(hw_lradc_ch5);
30 mxs_reg_32(hw_lradc_ch6);
31 mxs_reg_32(hw_lradc_ch7);
32 mxs_reg_32(hw_lradc_delay0);
33 mxs_reg_32(hw_lradc_delay1);
34 mxs_reg_32(hw_lradc_delay2);
35 mxs_reg_32(hw_lradc_delay3);
36 mxs_reg_32(hw_lradc_debug0);
37 mxs_reg_32(hw_lradc_debug1);
38 mxs_reg_32(hw_lradc_conversion);
39 mxs_reg_32(hw_lradc_ctrl4);
40 mxs_reg_32(hw_lradc_treshold0);
41 mxs_reg_32(hw_lradc_treshold1);
42 mxs_reg_32(hw_lradc_version);
Marek Vasuta10669a2012-05-01 11:09:48 +000043};
44#endif
45
46#define LRADC_CTRL0_SFTRST (1 << 31)
47#define LRADC_CTRL0_CLKGATE (1 << 30)
48#define LRADC_CTRL0_ONCHIP_GROUNDREF (1 << 26)
49#define LRADC_CTRL0_BUTTON1_DETECT_ENABLE (1 << 25)
50#define LRADC_CTRL0_BUTTON0_DETECT_ENABLE (1 << 24)
51#define LRADC_CTRL0_TOUCH_DETECT_ENABLE (1 << 23)
52#define LRADC_CTRL0_TOUCH_SCREEN_TYPE (1 << 22)
53#define LRADC_CTRL0_YNLRSW (1 << 21)
54#define LRADC_CTRL0_YPLLSW_MASK (0x3 << 19)
55#define LRADC_CTRL0_YPLLSW_OFFSET 19
56#define LRADC_CTRL0_XNURSW_MASK (0x3 << 17)
57#define LRADC_CTRL0_XNURSW_OFFSET 17
58#define LRADC_CTRL0_XPULSW (1 << 16)
59#define LRADC_CTRL0_SCHEDULE_MASK 0xff
60#define LRADC_CTRL0_SCHEDULE_OFFSET 0
61
62#define LRADC_CTRL1_BUTTON1_DETECT_IRQ_EN (1 << 28)
63#define LRADC_CTRL1_BUTTON0_DETECT_IRQ_EN (1 << 27)
64#define LRADC_CTRL1_THRESHOLD1_DETECT_IRQ_EN (1 << 26)
65#define LRADC_CTRL1_THRESHOLD0_DETECT_IRQ_EN (1 << 25)
66#define LRADC_CTRL1_TOUCH_DETECT_IRQ_EN (1 << 24)
67#define LRADC_CTRL1_LRADC7_IRQ_EN (1 << 23)
68#define LRADC_CTRL1_LRADC6_IRQ_EN (1 << 22)
69#define LRADC_CTRL1_LRADC5_IRQ_EN (1 << 21)
70#define LRADC_CTRL1_LRADC4_IRQ_EN (1 << 20)
71#define LRADC_CTRL1_LRADC3_IRQ_EN (1 << 19)
72#define LRADC_CTRL1_LRADC2_IRQ_EN (1 << 18)
73#define LRADC_CTRL1_LRADC1_IRQ_EN (1 << 17)
74#define LRADC_CTRL1_LRADC0_IRQ_EN (1 << 16)
75#define LRADC_CTRL1_BUTTON1_DETECT_IRQ (1 << 12)
76#define LRADC_CTRL1_BUTTON0_DETECT_IRQ (1 << 11)
77#define LRADC_CTRL1_THRESHOLD1_DETECT_IRQ (1 << 10)
78#define LRADC_CTRL1_THRESHOLD0_DETECT_IRQ (1 << 9)
79#define LRADC_CTRL1_TOUCH_DETECT_IRQ (1 << 8)
80#define LRADC_CTRL1_LRADC7_IRQ (1 << 7)
81#define LRADC_CTRL1_LRADC6_IRQ (1 << 6)
82#define LRADC_CTRL1_LRADC5_IRQ (1 << 5)
83#define LRADC_CTRL1_LRADC4_IRQ (1 << 4)
84#define LRADC_CTRL1_LRADC3_IRQ (1 << 3)
85#define LRADC_CTRL1_LRADC2_IRQ (1 << 2)
86#define LRADC_CTRL1_LRADC1_IRQ (1 << 1)
87#define LRADC_CTRL1_LRADC0_IRQ (1 << 0)
88
89#define LRADC_CTRL2_DIVIDE_BY_TWO_MASK (0xff << 24)
90#define LRADC_CTRL2_DIVIDE_BY_TWO_OFFSET 24
91#define LRADC_CTRL2_TEMPSENSE_PWD (1 << 15)
92#define LRADC_CTRL2_VTHSENSE_MASK (0x3 << 13)
93#define LRADC_CTRL2_VTHSENSE_OFFSET 13
94#define LRADC_CTRL2_DISABLE_MUXAMP_BYPASS (1 << 12)
95#define LRADC_CTRL2_TEMP_SENSOR_IENABLE1 (1 << 9)
96#define LRADC_CTRL2_TEMP_SENSOR_IENABLE0 (1 << 8)
97#define LRADC_CTRL2_TEMP_ISRC1_MASK (0xf << 4)
98#define LRADC_CTRL2_TEMP_ISRC1_OFFSET 4
99#define LRADC_CTRL2_TEMP_ISRC1_300 (0xf << 4)
100#define LRADC_CTRL2_TEMP_ISRC1_280 (0xe << 4)
101#define LRADC_CTRL2_TEMP_ISRC1_260 (0xd << 4)
102#define LRADC_CTRL2_TEMP_ISRC1_240 (0xc << 4)
103#define LRADC_CTRL2_TEMP_ISRC1_220 (0xb << 4)
104#define LRADC_CTRL2_TEMP_ISRC1_200 (0xa << 4)
105#define LRADC_CTRL2_TEMP_ISRC1_180 (0x9 << 4)
106#define LRADC_CTRL2_TEMP_ISRC1_160 (0x8 << 4)
107#define LRADC_CTRL2_TEMP_ISRC1_140 (0x7 << 4)
108#define LRADC_CTRL2_TEMP_ISRC1_120 (0x6 << 4)
109#define LRADC_CTRL2_TEMP_ISRC1_100 (0x5 << 4)
110#define LRADC_CTRL2_TEMP_ISRC1_80 (0x4 << 4)
111#define LRADC_CTRL2_TEMP_ISRC1_60 (0x3 << 4)
112#define LRADC_CTRL2_TEMP_ISRC1_40 (0x2 << 4)
113#define LRADC_CTRL2_TEMP_ISRC1_20 (0x1 << 4)
114#define LRADC_CTRL2_TEMP_ISRC1_ZERO (0x0 << 4)
115#define LRADC_CTRL2_TEMP_ISRC0_MASK (0xf << 0)
116#define LRADC_CTRL2_TEMP_ISRC0_OFFSET 0
117#define LRADC_CTRL2_TEMP_ISRC0_300 (0xf << 0)
118#define LRADC_CTRL2_TEMP_ISRC0_280 (0xe << 0)
119#define LRADC_CTRL2_TEMP_ISRC0_260 (0xd << 0)
120#define LRADC_CTRL2_TEMP_ISRC0_240 (0xc << 0)
121#define LRADC_CTRL2_TEMP_ISRC0_220 (0xb << 0)
122#define LRADC_CTRL2_TEMP_ISRC0_200 (0xa << 0)
123#define LRADC_CTRL2_TEMP_ISRC0_180 (0x9 << 0)
124#define LRADC_CTRL2_TEMP_ISRC0_160 (0x8 << 0)
125#define LRADC_CTRL2_TEMP_ISRC0_140 (0x7 << 0)
126#define LRADC_CTRL2_TEMP_ISRC0_120 (0x6 << 0)
127#define LRADC_CTRL2_TEMP_ISRC0_100 (0x5 << 0)
128#define LRADC_CTRL2_TEMP_ISRC0_80 (0x4 << 0)
129#define LRADC_CTRL2_TEMP_ISRC0_60 (0x3 << 0)
130#define LRADC_CTRL2_TEMP_ISRC0_40 (0x2 << 0)
131#define LRADC_CTRL2_TEMP_ISRC0_20 (0x1 << 0)
132#define LRADC_CTRL2_TEMP_ISRC0_ZERO (0x0 << 0)
133
134#define LRADC_CTRL3_DISCARD_MASK (0x3 << 24)
135#define LRADC_CTRL3_DISCARD_OFFSET 24
136#define LRADC_CTRL3_DISCARD_1_SAMPLE (0x1 << 24)
137#define LRADC_CTRL3_DISCARD_2_SAMPLES (0x2 << 24)
138#define LRADC_CTRL3_DISCARD_3_SAMPLES (0x3 << 24)
139#define LRADC_CTRL3_FORCE_ANALOG_PWUP (1 << 23)
140#define LRADC_CTRL3_FORCE_ANALOG_PWDN (1 << 22)
141#define LRADC_CTRL3_CYCLE_TIME_MASK (0x3 << 8)
142#define LRADC_CTRL3_CYCLE_TIME_OFFSET 8
143#define LRADC_CTRL3_CYCLE_TIME_6MHZ (0x0 << 8)
144#define LRADC_CTRL3_CYCLE_TIME_4MHZ (0x1 << 8)
145#define LRADC_CTRL3_CYCLE_TIME_3MHZ (0x2 << 8)
146#define LRADC_CTRL3_CYCLE_TIME_2MHZ (0x3 << 8)
147#define LRADC_CTRL3_HIGH_TIME_MASK (0x3 << 4)
148#define LRADC_CTRL3_HIGH_TIME_OFFSET 4
149#define LRADC_CTRL3_HIGH_TIME_42NS (0x0 << 4)
150#define LRADC_CTRL3_HIGH_TIME_83NS (0x1 << 4)
151#define LRADC_CTRL3_HIGH_TIME_125NS (0x2 << 4)
152#define LRADC_CTRL3_HIGH_TIME_250NS (0x3 << 4)
153#define LRADC_CTRL3_DELAY_CLOCK (1 << 1)
154#define LRADC_CTRL3_INVERT_CLOCK (1 << 0)
155
156#define LRADC_STATUS_BUTTON1_PRESENT (1 << 28)
157#define LRADC_STATUS_BUTTON0_PRESENT (1 << 27)
158#define LRADC_STATUS_TEMP1_PRESENT (1 << 26)
159#define LRADC_STATUS_TEMP0_PRESENT (1 << 25)
160#define LRADC_STATUS_TOUCH_PANEL_PRESENT (1 << 24)
161#define LRADC_STATUS_CHANNEL7_PRESENT (1 << 23)
162#define LRADC_STATUS_CHANNEL6_PRESENT (1 << 22)
163#define LRADC_STATUS_CHANNEL5_PRESENT (1 << 21)
164#define LRADC_STATUS_CHANNEL4_PRESENT (1 << 20)
165#define LRADC_STATUS_CHANNEL3_PRESENT (1 << 19)
166#define LRADC_STATUS_CHANNEL2_PRESENT (1 << 18)
167#define LRADC_STATUS_CHANNEL1_PRESENT (1 << 17)
168#define LRADC_STATUS_CHANNEL0_PRESENT (1 << 16)
169#define LRADC_STATUS_BUTTON1_DETECT_RAW (1 << 2)
170#define LRADC_STATUS_BUTTON0_DETECT_RAW (1 << 1)
171#define LRADC_STATUS_TOUCH_DETECT_RAW (1 << 0)
172
173#define LRADC_CH_TOGGLE (1 << 31)
174#define LRADC_CH7_TESTMODE_TOGGLE (1 << 30)
175#define LRADC_CH_ACCUMULATE (1 << 29)
176#define LRADC_CH_NUM_SAMPLES_MASK (0x1f << 24)
177#define LRADC_CH_NUM_SAMPLES_OFFSET 24
178#define LRADC_CH_VALUE_MASK 0x3ffff
179#define LRADC_CH_VALUE_OFFSET 0
180
181#define LRADC_DELAY_TRIGGER_LRADCS_MASK (0xff << 24)
182#define LRADC_DELAY_TRIGGER_LRADCS_OFFSET 24
183#define LRADC_DELAY_KICK (1 << 20)
184#define LRADC_DELAY_TRIGGER_DELAYS_MASK (0xf << 16)
185#define LRADC_DELAY_TRIGGER_DELAYS_OFFSET 16
186#define LRADC_DELAY_LOOP_COUNT_MASK (0x1f << 11)
187#define LRADC_DELAY_LOOP_COUNT_OFFSET 11
188#define LRADC_DELAY_DELAY_MASK 0x7ff
189#define LRADC_DELAY_DELAY_OFFSET 0
190
191#define LRADC_DEBUG0_READONLY_MASK (0xffff << 16)
192#define LRADC_DEBUG0_READONLY_OFFSET 16
193#define LRADC_DEBUG0_STATE_MASK (0xfff << 0)
194#define LRADC_DEBUG0_STATE_OFFSET 0
195
196#define LRADC_DEBUG1_REQUEST_MASK (0xff << 16)
197#define LRADC_DEBUG1_REQUEST_OFFSET 16
198#define LRADC_DEBUG1_TESTMODE_COUNT_MASK (0x1f << 8)
199#define LRADC_DEBUG1_TESTMODE_COUNT_OFFSET 8
200#define LRADC_DEBUG1_TESTMODE6 (1 << 2)
201#define LRADC_DEBUG1_TESTMODE5 (1 << 1)
202#define LRADC_DEBUG1_TESTMODE (1 << 0)
203
204#define LRADC_CONVERSION_AUTOMATIC (1 << 20)
205#define LRADC_CONVERSION_SCALE_FACTOR_MASK (0x3 << 16)
206#define LRADC_CONVERSION_SCALE_FACTOR_OFFSET 16
207#define LRADC_CONVERSION_SCALE_FACTOR_NIMH (0x0 << 16)
208#define LRADC_CONVERSION_SCALE_FACTOR_DUAL_NIMH (0x1 << 16)
209#define LRADC_CONVERSION_SCALE_FACTOR_LI_ION (0x2 << 16)
210#define LRADC_CONVERSION_SCALE_FACTOR_ALT_LI_ION (0x3 << 16)
211#define LRADC_CONVERSION_SCALED_BATT_VOLTAGE_MASK 0x3ff
212#define LRADC_CONVERSION_SCALED_BATT_VOLTAGE_OFFSET 0
213
214#define LRADC_CTRL4_LRADC7SELECT_MASK (0xf << 28)
215#define LRADC_CTRL4_LRADC7SELECT_OFFSET 28
216#define LRADC_CTRL4_LRADC7SELECT_CHANNEL0 (0x0 << 28)
217#define LRADC_CTRL4_LRADC7SELECT_CHANNEL1 (0x1 << 28)
218#define LRADC_CTRL4_LRADC7SELECT_CHANNEL2 (0x2 << 28)
219#define LRADC_CTRL4_LRADC7SELECT_CHANNEL3 (0x3 << 28)
220#define LRADC_CTRL4_LRADC7SELECT_CHANNEL4 (0x4 << 28)
221#define LRADC_CTRL4_LRADC7SELECT_CHANNEL5 (0x5 << 28)
222#define LRADC_CTRL4_LRADC7SELECT_CHANNEL6 (0x6 << 28)
223#define LRADC_CTRL4_LRADC7SELECT_CHANNEL7 (0x7 << 28)
224#define LRADC_CTRL4_LRADC7SELECT_CHANNEL8 (0x8 << 28)
225#define LRADC_CTRL4_LRADC7SELECT_CHANNEL9 (0x9 << 28)
226#define LRADC_CTRL4_LRADC7SELECT_CHANNEL10 (0xa << 28)
227#define LRADC_CTRL4_LRADC7SELECT_CHANNEL11 (0xb << 28)
228#define LRADC_CTRL4_LRADC7SELECT_CHANNEL12 (0xc << 28)
229#define LRADC_CTRL4_LRADC7SELECT_CHANNEL13 (0xd << 28)
230#define LRADC_CTRL4_LRADC7SELECT_CHANNEL14 (0xe << 28)
231#define LRADC_CTRL4_LRADC7SELECT_CHANNEL15 (0xf << 28)
232#define LRADC_CTRL4_LRADC6SELECT_MASK (0xf << 24)
233#define LRADC_CTRL4_LRADC6SELECT_OFFSET 24
234#define LRADC_CTRL4_LRADC6SELECT_CHANNEL0 (0x0 << 24)
235#define LRADC_CTRL4_LRADC6SELECT_CHANNEL1 (0x1 << 24)
236#define LRADC_CTRL4_LRADC6SELECT_CHANNEL2 (0x2 << 24)
237#define LRADC_CTRL4_LRADC6SELECT_CHANNEL3 (0x3 << 24)
238#define LRADC_CTRL4_LRADC6SELECT_CHANNEL4 (0x4 << 24)
239#define LRADC_CTRL4_LRADC6SELECT_CHANNEL5 (0x5 << 24)
240#define LRADC_CTRL4_LRADC6SELECT_CHANNEL6 (0x6 << 24)
241#define LRADC_CTRL4_LRADC6SELECT_CHANNEL7 (0x7 << 24)
242#define LRADC_CTRL4_LRADC6SELECT_CHANNEL8 (0x8 << 24)
243#define LRADC_CTRL4_LRADC6SELECT_CHANNEL9 (0x9 << 24)
244#define LRADC_CTRL4_LRADC6SELECT_CHANNEL10 (0xa << 24)
245#define LRADC_CTRL4_LRADC6SELECT_CHANNEL11 (0xb << 24)
246#define LRADC_CTRL4_LRADC6SELECT_CHANNEL12 (0xc << 24)
247#define LRADC_CTRL4_LRADC6SELECT_CHANNEL13 (0xd << 24)
248#define LRADC_CTRL4_LRADC6SELECT_CHANNEL14 (0xe << 24)
249#define LRADC_CTRL4_LRADC6SELECT_CHANNEL15 (0xf << 24)
250#define LRADC_CTRL4_LRADC5SELECT_MASK (0xf << 20)
251#define LRADC_CTRL4_LRADC5SELECT_OFFSET 20
252#define LRADC_CTRL4_LRADC5SELECT_CHANNEL0 (0x0 << 20)
253#define LRADC_CTRL4_LRADC5SELECT_CHANNEL1 (0x1 << 20)
254#define LRADC_CTRL4_LRADC5SELECT_CHANNEL2 (0x2 << 20)
255#define LRADC_CTRL4_LRADC5SELECT_CHANNEL3 (0x3 << 20)
256#define LRADC_CTRL4_LRADC5SELECT_CHANNEL4 (0x4 << 20)
257#define LRADC_CTRL4_LRADC5SELECT_CHANNEL5 (0x5 << 20)
258#define LRADC_CTRL4_LRADC5SELECT_CHANNEL6 (0x6 << 20)
259#define LRADC_CTRL4_LRADC5SELECT_CHANNEL7 (0x7 << 20)
260#define LRADC_CTRL4_LRADC5SELECT_CHANNEL8 (0x8 << 20)
261#define LRADC_CTRL4_LRADC5SELECT_CHANNEL9 (0x9 << 20)
262#define LRADC_CTRL4_LRADC5SELECT_CHANNEL10 (0xa << 20)
263#define LRADC_CTRL4_LRADC5SELECT_CHANNEL11 (0xb << 20)
264#define LRADC_CTRL4_LRADC5SELECT_CHANNEL12 (0xc << 20)
265#define LRADC_CTRL4_LRADC5SELECT_CHANNEL13 (0xd << 20)
266#define LRADC_CTRL4_LRADC5SELECT_CHANNEL14 (0xe << 20)
267#define LRADC_CTRL4_LRADC5SELECT_CHANNEL15 (0xf << 20)
268#define LRADC_CTRL4_LRADC4SELECT_MASK (0xf << 16)
269#define LRADC_CTRL4_LRADC4SELECT_OFFSET 16
270#define LRADC_CTRL4_LRADC4SELECT_CHANNEL0 (0x0 << 16)
271#define LRADC_CTRL4_LRADC4SELECT_CHANNEL1 (0x1 << 16)
272#define LRADC_CTRL4_LRADC4SELECT_CHANNEL2 (0x2 << 16)
273#define LRADC_CTRL4_LRADC4SELECT_CHANNEL3 (0x3 << 16)
274#define LRADC_CTRL4_LRADC4SELECT_CHANNEL4 (0x4 << 16)
275#define LRADC_CTRL4_LRADC4SELECT_CHANNEL5 (0x5 << 16)
276#define LRADC_CTRL4_LRADC4SELECT_CHANNEL6 (0x6 << 16)
277#define LRADC_CTRL4_LRADC4SELECT_CHANNEL7 (0x7 << 16)
278#define LRADC_CTRL4_LRADC4SELECT_CHANNEL8 (0x8 << 16)
279#define LRADC_CTRL4_LRADC4SELECT_CHANNEL9 (0x9 << 16)
280#define LRADC_CTRL4_LRADC4SELECT_CHANNEL10 (0xa << 16)
281#define LRADC_CTRL4_LRADC4SELECT_CHANNEL11 (0xb << 16)
282#define LRADC_CTRL4_LRADC4SELECT_CHANNEL12 (0xc << 16)
283#define LRADC_CTRL4_LRADC4SELECT_CHANNEL13 (0xd << 16)
284#define LRADC_CTRL4_LRADC4SELECT_CHANNEL14 (0xe << 16)
285#define LRADC_CTRL4_LRADC4SELECT_CHANNEL15 (0xf << 16)
286#define LRADC_CTRL4_LRADC3SELECT_MASK (0xf << 12)
287#define LRADC_CTRL4_LRADC3SELECT_OFFSET 12
288#define LRADC_CTRL4_LRADC3SELECT_CHANNEL0 (0x0 << 12)
289#define LRADC_CTRL4_LRADC3SELECT_CHANNEL1 (0x1 << 12)
290#define LRADC_CTRL4_LRADC3SELECT_CHANNEL2 (0x2 << 12)
291#define LRADC_CTRL4_LRADC3SELECT_CHANNEL3 (0x3 << 12)
292#define LRADC_CTRL4_LRADC3SELECT_CHANNEL4 (0x4 << 12)
293#define LRADC_CTRL4_LRADC3SELECT_CHANNEL5 (0x5 << 12)
294#define LRADC_CTRL4_LRADC3SELECT_CHANNEL6 (0x6 << 12)
295#define LRADC_CTRL4_LRADC3SELECT_CHANNEL7 (0x7 << 12)
296#define LRADC_CTRL4_LRADC3SELECT_CHANNEL8 (0x8 << 12)
297#define LRADC_CTRL4_LRADC3SELECT_CHANNEL9 (0x9 << 12)
298#define LRADC_CTRL4_LRADC3SELECT_CHANNEL10 (0xa << 12)
299#define LRADC_CTRL4_LRADC3SELECT_CHANNEL11 (0xb << 12)
300#define LRADC_CTRL4_LRADC3SELECT_CHANNEL12 (0xc << 12)
301#define LRADC_CTRL4_LRADC3SELECT_CHANNEL13 (0xd << 12)
302#define LRADC_CTRL4_LRADC3SELECT_CHANNEL14 (0xe << 12)
303#define LRADC_CTRL4_LRADC3SELECT_CHANNEL15 (0xf << 12)
304#define LRADC_CTRL4_LRADC2SELECT_MASK (0xf << 8)
305#define LRADC_CTRL4_LRADC2SELECT_OFFSET 8
306#define LRADC_CTRL4_LRADC2SELECT_CHANNEL0 (0x0 << 8)
307#define LRADC_CTRL4_LRADC2SELECT_CHANNEL1 (0x1 << 8)
308#define LRADC_CTRL4_LRADC2SELECT_CHANNEL2 (0x2 << 8)
309#define LRADC_CTRL4_LRADC2SELECT_CHANNEL3 (0x3 << 8)
310#define LRADC_CTRL4_LRADC2SELECT_CHANNEL4 (0x4 << 8)
311#define LRADC_CTRL4_LRADC2SELECT_CHANNEL5 (0x5 << 8)
312#define LRADC_CTRL4_LRADC2SELECT_CHANNEL6 (0x6 << 8)
313#define LRADC_CTRL4_LRADC2SELECT_CHANNEL7 (0x7 << 8)
314#define LRADC_CTRL4_LRADC2SELECT_CHANNEL8 (0x8 << 8)
315#define LRADC_CTRL4_LRADC2SELECT_CHANNEL9 (0x9 << 8)
316#define LRADC_CTRL4_LRADC2SELECT_CHANNEL10 (0xa << 8)
317#define LRADC_CTRL4_LRADC2SELECT_CHANNEL11 (0xb << 8)
318#define LRADC_CTRL4_LRADC2SELECT_CHANNEL12 (0xc << 8)
319#define LRADC_CTRL4_LRADC2SELECT_CHANNEL13 (0xd << 8)
320#define LRADC_CTRL4_LRADC2SELECT_CHANNEL14 (0xe << 8)
321#define LRADC_CTRL4_LRADC2SELECT_CHANNEL15 (0xf << 8)
322#define LRADC_CTRL4_LRADC1SELECT_MASK (0xf << 4)
323#define LRADC_CTRL4_LRADC1SELECT_OFFSET 4
324#define LRADC_CTRL4_LRADC1SELECT_CHANNEL0 (0x0 << 4)
325#define LRADC_CTRL4_LRADC1SELECT_CHANNEL1 (0x1 << 4)
326#define LRADC_CTRL4_LRADC1SELECT_CHANNEL2 (0x2 << 4)
327#define LRADC_CTRL4_LRADC1SELECT_CHANNEL3 (0x3 << 4)
328#define LRADC_CTRL4_LRADC1SELECT_CHANNEL4 (0x4 << 4)
329#define LRADC_CTRL4_LRADC1SELECT_CHANNEL5 (0x5 << 4)
330#define LRADC_CTRL4_LRADC1SELECT_CHANNEL6 (0x6 << 4)
331#define LRADC_CTRL4_LRADC1SELECT_CHANNEL7 (0x7 << 4)
332#define LRADC_CTRL4_LRADC1SELECT_CHANNEL8 (0x8 << 4)
333#define LRADC_CTRL4_LRADC1SELECT_CHANNEL9 (0x9 << 4)
334#define LRADC_CTRL4_LRADC1SELECT_CHANNEL10 (0xa << 4)
335#define LRADC_CTRL4_LRADC1SELECT_CHANNEL11 (0xb << 4)
336#define LRADC_CTRL4_LRADC1SELECT_CHANNEL12 (0xc << 4)
337#define LRADC_CTRL4_LRADC1SELECT_CHANNEL13 (0xd << 4)
338#define LRADC_CTRL4_LRADC1SELECT_CHANNEL14 (0xe << 4)
339#define LRADC_CTRL4_LRADC1SELECT_CHANNEL15 (0xf << 4)
340#define LRADC_CTRL4_LRADC0SELECT_MASK 0xf
341#define LRADC_CTRL4_LRADC0SELECT_CHANNEL0 (0x0 << 0)
342#define LRADC_CTRL4_LRADC0SELECT_CHANNEL1 (0x1 << 0)
343#define LRADC_CTRL4_LRADC0SELECT_CHANNEL2 (0x2 << 0)
344#define LRADC_CTRL4_LRADC0SELECT_CHANNEL3 (0x3 << 0)
345#define LRADC_CTRL4_LRADC0SELECT_CHANNEL4 (0x4 << 0)
346#define LRADC_CTRL4_LRADC0SELECT_CHANNEL5 (0x5 << 0)
347#define LRADC_CTRL4_LRADC0SELECT_CHANNEL6 (0x6 << 0)
348#define LRADC_CTRL4_LRADC0SELECT_CHANNEL7 (0x7 << 0)
349#define LRADC_CTRL4_LRADC0SELECT_CHANNEL8 (0x8 << 0)
350#define LRADC_CTRL4_LRADC0SELECT_CHANNEL9 (0x9 << 0)
351#define LRADC_CTRL4_LRADC0SELECT_CHANNEL10 (0xa << 0)
352#define LRADC_CTRL4_LRADC0SELECT_CHANNEL11 (0xb << 0)
353#define LRADC_CTRL4_LRADC0SELECT_CHANNEL12 (0xc << 0)
354#define LRADC_CTRL4_LRADC0SELECT_CHANNEL13 (0xd << 0)
355#define LRADC_CTRL4_LRADC0SELECT_CHANNEL14 (0xe << 0)
356#define LRADC_CTRL4_LRADC0SELECT_CHANNEL15 (0xf << 0)
357
358#define LRADC_THRESHOLD_ENABLE (1 << 24)
359#define LRADC_THRESHOLD_BATTCHRG_DISABLE (1 << 23)
360#define LRADC_THRESHOLD_CHANNEL_SEL_MASK (0x7 << 20)
361#define LRADC_THRESHOLD_CHANNEL_SEL_OFFSET 20
362#define LRADC_THRESHOLD_CHANNEL_SEL_CHANNEL0 (0x0 << 20)
363#define LRADC_THRESHOLD_CHANNEL_SEL_CHANNEL1 (0x1 << 20)
364#define LRADC_THRESHOLD_CHANNEL_SEL_CHANNEL2 (0x2 << 20)
365#define LRADC_THRESHOLD_CHANNEL_SEL_CHANNEL3 (0x3 << 20)
366#define LRADC_THRESHOLD_CHANNEL_SEL_CHANNEL4 (0x4 << 20)
367#define LRADC_THRESHOLD_CHANNEL_SEL_CHANNEL5 (0x5 << 20)
368#define LRADC_THRESHOLD_CHANNEL_SEL_CHANNEL6 (0x6 << 20)
369#define LRADC_THRESHOLD_CHANNEL_SEL_CHANNEL7 (0x7 << 20)
370#define LRADC_THRESHOLD_SETTING_MASK (0x3 << 18)
371#define LRADC_THRESHOLD_SETTING_OFFSET 18
372#define LRADC_THRESHOLD_SETTING_NO_COMPARE (0x0 << 18)
373#define LRADC_THRESHOLD_SETTING_DETECT_LOW (0x1 << 18)
374#define LRADC_THRESHOLD_SETTING_DETECT_HIGH (0x2 << 18)
375#define LRADC_THRESHOLD_SETTING_RESERVED (0x3 << 18)
376#define LRADC_THRESHOLD_VALUE_MASK 0x3ffff
377#define LRADC_THRESHOLD_VALUE_OFFSET 0
378
379#define LRADC_VERSION_MAJOR_MASK (0xff << 24)
380#define LRADC_VERSION_MAJOR_OFFSET 24
381#define LRADC_VERSION_MINOR_MASK (0xff << 16)
382#define LRADC_VERSION_MINOR_OFFSET 16
383#define LRADC_VERSION_STEP_MASK 0xffff
384#define LRADC_VERSION_STEP_OFFSET 0
385
386#endif /* __MX28_REGS_LRADC_H__ */