diff options
author | Uwe Kleine-König <u.kleine-koenig@pengutronix.de> | 2010-09-28 10:37:20 -0400 |
---|---|---|
committer | Samuel Ortiz <sameo@linux.intel.com> | 2010-10-28 18:29:57 -0400 |
commit | 8e00593557c3c5a7bc6f636412a1cadcf4624232 (patch) | |
tree | 5d2872ae1cc0f39ebc0e29114864d12acdee292d /include/linux/mfd/mc13783.h | |
parent | b4e017e332b873133602f47ae8cacfae64ab82c5 (diff) |
mfd: Add mc13892 support to mc13xxx
mc13892 is the companion PMIC for Freescale's i.MX51. It's similar enough
to mc13782 to support it in a single driver.
This patch introduces enough compatibility cruft to keep all users of the
superseded mc13783 driver unchanged.
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
Diffstat (limited to 'include/linux/mfd/mc13783.h')
-rw-r--r-- | include/linux/mfd/mc13783.h | 247 |
1 files changed, 111 insertions, 136 deletions
diff --git a/include/linux/mfd/mc13783.h b/include/linux/mfd/mc13783.h index 5f6aff55eeb7..b4c741e352c2 100644 --- a/include/linux/mfd/mc13783.h +++ b/include/linux/mfd/mc13783.h | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright 2009 Pengutronix | 2 | * Copyright 2009-2010 Pengutronix |
3 | * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> | 3 | * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de> |
4 | * | 4 | * |
5 | * This program is free software; you can redistribute it and/or modify it under | 5 | * This program is free software; you can redistribute it and/or modify it under |
@@ -9,31 +9,84 @@ | |||
9 | #ifndef __LINUX_MFD_MC13783_H | 9 | #ifndef __LINUX_MFD_MC13783_H |
10 | #define __LINUX_MFD_MC13783_H | 10 | #define __LINUX_MFD_MC13783_H |
11 | 11 | ||
12 | #include <linux/interrupt.h> | 12 | #include <linux/mfd/mc13xxx.h> |
13 | 13 | ||
14 | struct mc13783; | 14 | struct mc13783; |
15 | 15 | ||
16 | void mc13783_lock(struct mc13783 *mc13783); | 16 | struct mc13xxx *mc13783_to_mc13xxx(struct mc13783 *mc13783); |
17 | void mc13783_unlock(struct mc13783 *mc13783); | 17 | |
18 | 18 | static inline void mc13783_lock(struct mc13783 *mc13783) | |
19 | int mc13783_reg_read(struct mc13783 *mc13783, unsigned int offset, u32 *val); | 19 | { |
20 | int mc13783_reg_write(struct mc13783 *mc13783, unsigned int offset, u32 val); | 20 | mc13xxx_lock(mc13783_to_mc13xxx(mc13783)); |
21 | int mc13783_reg_rmw(struct mc13783 *mc13783, unsigned int offset, | 21 | } |
22 | u32 mask, u32 val); | 22 | |
23 | 23 | static inline void mc13783_unlock(struct mc13783 *mc13783) | |
24 | int mc13783_get_flags(struct mc13783 *mc13783); | 24 | { |
25 | 25 | mc13xxx_unlock(mc13783_to_mc13xxx(mc13783)); | |
26 | int mc13783_irq_request(struct mc13783 *mc13783, int irq, | 26 | } |
27 | irq_handler_t handler, const char *name, void *dev); | 27 | |
28 | int mc13783_irq_request_nounmask(struct mc13783 *mc13783, int irq, | 28 | static inline int mc13783_reg_read(struct mc13783 *mc13783, |
29 | irq_handler_t handler, const char *name, void *dev); | 29 | unsigned int offset, u32 *val) |
30 | int mc13783_irq_free(struct mc13783 *mc13783, int irq, void *dev); | 30 | { |
31 | 31 | return mc13xxx_reg_read(mc13783_to_mc13xxx(mc13783), offset, val); | |
32 | int mc13783_irq_mask(struct mc13783 *mc13783, int irq); | 32 | } |
33 | int mc13783_irq_unmask(struct mc13783 *mc13783, int irq); | 33 | |
34 | int mc13783_irq_status(struct mc13783 *mc13783, int irq, | 34 | static inline int mc13783_reg_write(struct mc13783 *mc13783, |
35 | int *enabled, int *pending); | 35 | unsigned int offset, u32 val) |
36 | int mc13783_irq_ack(struct mc13783 *mc13783, int irq); | 36 | { |
37 | return mc13xxx_reg_write(mc13783_to_mc13xxx(mc13783), offset, val); | ||
38 | } | ||
39 | |||
40 | static inline int mc13783_reg_rmw(struct mc13783 *mc13783, | ||
41 | unsigned int offset, u32 mask, u32 val) | ||
42 | { | ||
43 | return mc13xxx_reg_rmw(mc13783_to_mc13xxx(mc13783), offset, mask, val); | ||
44 | } | ||
45 | |||
46 | static inline int mc13783_get_flags(struct mc13783 *mc13783) | ||
47 | { | ||
48 | return mc13xxx_get_flags(mc13783_to_mc13xxx(mc13783)); | ||
49 | } | ||
50 | |||
51 | static inline int mc13783_irq_request(struct mc13783 *mc13783, int irq, | ||
52 | irq_handler_t handler, const char *name, void *dev) | ||
53 | { | ||
54 | return mc13xxx_irq_request(mc13783_to_mc13xxx(mc13783), irq, | ||
55 | handler, name, dev); | ||
56 | } | ||
57 | |||
58 | static inline int mc13783_irq_request_nounmask(struct mc13783 *mc13783, int irq, | ||
59 | irq_handler_t handler, const char *name, void *dev) | ||
60 | { | ||
61 | return mc13xxx_irq_request_nounmask(mc13783_to_mc13xxx(mc13783), irq, | ||
62 | handler, name, dev); | ||
63 | } | ||
64 | |||
65 | static inline int mc13783_irq_free(struct mc13783 *mc13783, int irq, void *dev) | ||
66 | { | ||
67 | return mc13xxx_irq_free(mc13783_to_mc13xxx(mc13783), irq, dev); | ||
68 | } | ||
69 | |||
70 | static inline int mc13783_irq_mask(struct mc13783 *mc13783, int irq) | ||
71 | { | ||
72 | return mc13xxx_irq_mask(mc13783_to_mc13xxx(mc13783), irq); | ||
73 | } | ||
74 | |||
75 | static inline int mc13783_irq_unmask(struct mc13783 *mc13783, int irq) | ||
76 | { | ||
77 | return mc13xxx_irq_unmask(mc13783_to_mc13xxx(mc13783), irq); | ||
78 | } | ||
79 | static inline int mc13783_irq_status(struct mc13783 *mc13783, int irq, | ||
80 | int *enabled, int *pending) | ||
81 | { | ||
82 | return mc13xxx_irq_status(mc13783_to_mc13xxx(mc13783), | ||
83 | irq, enabled, pending); | ||
84 | } | ||
85 | |||
86 | static inline int mc13783_irq_ack(struct mc13783 *mc13783, int irq) | ||
87 | { | ||
88 | return mc13xxx_irq_ack(mc13783_to_mc13xxx(mc13783), irq); | ||
89 | } | ||
37 | 90 | ||
38 | #define MC13783_ADC0 43 | 91 | #define MC13783_ADC0 43 |
39 | #define MC13783_ADC0_ADREFEN (1 << 10) | 92 | #define MC13783_ADC0_ADREFEN (1 << 10) |
@@ -48,96 +101,18 @@ int mc13783_irq_ack(struct mc13783 *mc13783, int irq); | |||
48 | MC13783_ADC0_TSMOD1 | \ | 101 | MC13783_ADC0_TSMOD1 | \ |
49 | MC13783_ADC0_TSMOD2) | 102 | MC13783_ADC0_TSMOD2) |
50 | 103 | ||
51 | struct mc13783_led_platform_data { | 104 | #define mc13783_regulator_init_data mc13xxx_regulator_init_data |
52 | #define MC13783_LED_MD 0 | 105 | #define mc13783_regulator_platform_data mc13xxx_regulator_platform_data |
53 | #define MC13783_LED_AD 1 | 106 | #define mc13783_led_platform_data mc13xxx_led_platform_data |
54 | #define MC13783_LED_KP 2 | 107 | #define mc13783_leds_platform_data mc13xxx_leds_platform_data |
55 | #define MC13783_LED_R1 3 | 108 | |
56 | #define MC13783_LED_G1 4 | 109 | #define mc13783_platform_data mc13xxx_platform_data |
57 | #define MC13783_LED_B1 5 | 110 | #define MC13783_USE_TOUCHSCREEN MC13XXX_USE_TOUCHSCREEN |
58 | #define MC13783_LED_R2 6 | 111 | #define MC13783_USE_CODEC MC13XXX_USE_CODEC |
59 | #define MC13783_LED_G2 7 | 112 | #define MC13783_USE_ADC MC13XXX_USE_ADC |
60 | #define MC13783_LED_B2 8 | 113 | #define MC13783_USE_RTC MC13XXX_USE_RTC |
61 | #define MC13783_LED_R3 9 | 114 | #define MC13783_USE_REGULATOR MC13XXX_USE_REGULATOR |
62 | #define MC13783_LED_G3 10 | 115 | #define MC13783_USE_LED MC13XXX_USE_LED |
63 | #define MC13783_LED_B3 11 | ||
64 | #define MC13783_LED_MAX MC13783_LED_B3 | ||
65 | int id; | ||
66 | const char *name; | ||
67 | const char *default_trigger; | ||
68 | |||
69 | /* Three or two bits current selection depending on the led */ | ||
70 | char max_current; | ||
71 | }; | ||
72 | |||
73 | struct mc13783_leds_platform_data { | ||
74 | int num_leds; | ||
75 | struct mc13783_led_platform_data *led; | ||
76 | |||
77 | #define MC13783_LED_TRIODE_MD (1 << 0) | ||
78 | #define MC13783_LED_TRIODE_AD (1 << 1) | ||
79 | #define MC13783_LED_TRIODE_KP (1 << 2) | ||
80 | #define MC13783_LED_BOOST_EN (1 << 3) | ||
81 | #define MC13783_LED_TC1HALF (1 << 4) | ||
82 | #define MC13783_LED_SLEWLIMTC (1 << 5) | ||
83 | #define MC13783_LED_SLEWLIMBL (1 << 6) | ||
84 | #define MC13783_LED_TRIODE_TC1 (1 << 7) | ||
85 | #define MC13783_LED_TRIODE_TC2 (1 << 8) | ||
86 | #define MC13783_LED_TRIODE_TC3 (1 << 9) | ||
87 | int flags; | ||
88 | |||
89 | #define MC13783_LED_AB_DISABLED 0 | ||
90 | #define MC13783_LED_AB_MD1 1 | ||
91 | #define MC13783_LED_AB_MD12 2 | ||
92 | #define MC13783_LED_AB_MD123 3 | ||
93 | #define MC13783_LED_AB_MD1234 4 | ||
94 | #define MC13783_LED_AB_MD1234_AD1 5 | ||
95 | #define MC13783_LED_AB_MD1234_AD12 6 | ||
96 | #define MC13783_LED_AB_MD1_AD 7 | ||
97 | char abmode; | ||
98 | |||
99 | #define MC13783_LED_ABREF_200MV 0 | ||
100 | #define MC13783_LED_ABREF_400MV 1 | ||
101 | #define MC13783_LED_ABREF_600MV 2 | ||
102 | #define MC13783_LED_ABREF_800MV 3 | ||
103 | char abref; | ||
104 | |||
105 | #define MC13783_LED_PERIOD_10MS 0 | ||
106 | #define MC13783_LED_PERIOD_100MS 1 | ||
107 | #define MC13783_LED_PERIOD_500MS 2 | ||
108 | #define MC13783_LED_PERIOD_2S 3 | ||
109 | char bl_period; | ||
110 | char tc1_period; | ||
111 | char tc2_period; | ||
112 | char tc3_period; | ||
113 | }; | ||
114 | |||
115 | /* to be cleaned up */ | ||
116 | struct regulator_init_data; | ||
117 | |||
118 | struct mc13783_regulator_init_data { | ||
119 | int id; | ||
120 | struct regulator_init_data *init_data; | ||
121 | }; | ||
122 | |||
123 | struct mc13783_regulator_platform_data { | ||
124 | int num_regulators; | ||
125 | struct mc13783_regulator_init_data *regulators; | ||
126 | }; | ||
127 | |||
128 | struct mc13783_platform_data { | ||
129 | int num_regulators; | ||
130 | struct mc13783_regulator_init_data *regulators; | ||
131 | struct mc13783_leds_platform_data *leds; | ||
132 | |||
133 | #define MC13783_USE_TOUCHSCREEN (1 << 0) | ||
134 | #define MC13783_USE_CODEC (1 << 1) | ||
135 | #define MC13783_USE_ADC (1 << 2) | ||
136 | #define MC13783_USE_RTC (1 << 3) | ||
137 | #define MC13783_USE_REGULATOR (1 << 4) | ||
138 | #define MC13783_USE_LED (1 << 5) | ||
139 | unsigned int flags; | ||
140 | }; | ||
141 | 116 | ||
142 | #define MC13783_ADC_MODE_TS 1 | 117 | #define MC13783_ADC_MODE_TS 1 |
143 | #define MC13783_ADC_MODE_SINGLE_CHAN 2 | 118 | #define MC13783_ADC_MODE_SINGLE_CHAN 2 |
@@ -181,46 +156,46 @@ int mc13783_adc_do_conversion(struct mc13783 *mc13783, unsigned int mode, | |||
181 | #define MC13783_REGU_PWGT1SPI 31 | 156 | #define MC13783_REGU_PWGT1SPI 31 |
182 | #define MC13783_REGU_PWGT2SPI 32 | 157 | #define MC13783_REGU_PWGT2SPI 32 |
183 | 158 | ||
184 | #define MC13783_IRQ_ADCDONE 0 | 159 | #define MC13783_IRQ_ADCDONE MC13XXX_IRQ_ADCDONE |
185 | #define MC13783_IRQ_ADCBISDONE 1 | 160 | #define MC13783_IRQ_ADCBISDONE MC13XXX_IRQ_ADCBISDONE |
186 | #define MC13783_IRQ_TS 2 | 161 | #define MC13783_IRQ_TS MC13XXX_IRQ_TS |
187 | #define MC13783_IRQ_WHIGH 3 | 162 | #define MC13783_IRQ_WHIGH 3 |
188 | #define MC13783_IRQ_WLOW 4 | 163 | #define MC13783_IRQ_WLOW 4 |
189 | #define MC13783_IRQ_CHGDET 6 | 164 | #define MC13783_IRQ_CHGDET MC13XXX_IRQ_CHGDET |
190 | #define MC13783_IRQ_CHGOV 7 | 165 | #define MC13783_IRQ_CHGOV 7 |
191 | #define MC13783_IRQ_CHGREV 8 | 166 | #define MC13783_IRQ_CHGREV MC13XXX_IRQ_CHGREV |
192 | #define MC13783_IRQ_CHGSHORT 9 | 167 | #define MC13783_IRQ_CHGSHORT MC13XXX_IRQ_CHGSHORT |
193 | #define MC13783_IRQ_CCCV 10 | 168 | #define MC13783_IRQ_CCCV MC13XXX_IRQ_CCCV |
194 | #define MC13783_IRQ_CHGCURR 11 | 169 | #define MC13783_IRQ_CHGCURR MC13XXX_IRQ_CHGCURR |
195 | #define MC13783_IRQ_BPON 12 | 170 | #define MC13783_IRQ_BPON MC13XXX_IRQ_BPON |
196 | #define MC13783_IRQ_LOBATL 13 | 171 | #define MC13783_IRQ_LOBATL MC13XXX_IRQ_LOBATL |
197 | #define MC13783_IRQ_LOBATH 14 | 172 | #define MC13783_IRQ_LOBATH MC13XXX_IRQ_LOBATH |
198 | #define MC13783_IRQ_UDP 15 | 173 | #define MC13783_IRQ_UDP 15 |
199 | #define MC13783_IRQ_USB 16 | 174 | #define MC13783_IRQ_USB 16 |
200 | #define MC13783_IRQ_ID 19 | 175 | #define MC13783_IRQ_ID 19 |
201 | #define MC13783_IRQ_SE1 21 | 176 | #define MC13783_IRQ_SE1 21 |
202 | #define MC13783_IRQ_CKDET 22 | 177 | #define MC13783_IRQ_CKDET 22 |
203 | #define MC13783_IRQ_UDM 23 | 178 | #define MC13783_IRQ_UDM 23 |
204 | #define MC13783_IRQ_1HZ 24 | 179 | #define MC13783_IRQ_1HZ MC13XXX_IRQ_1HZ |
205 | #define MC13783_IRQ_TODA 25 | 180 | #define MC13783_IRQ_TODA MC13XXX_IRQ_TODA |
206 | #define MC13783_IRQ_ONOFD1 27 | 181 | #define MC13783_IRQ_ONOFD1 27 |
207 | #define MC13783_IRQ_ONOFD2 28 | 182 | #define MC13783_IRQ_ONOFD2 28 |
208 | #define MC13783_IRQ_ONOFD3 29 | 183 | #define MC13783_IRQ_ONOFD3 29 |
209 | #define MC13783_IRQ_SYSRST 30 | 184 | #define MC13783_IRQ_SYSRST MC13XXX_IRQ_SYSRST |
210 | #define MC13783_IRQ_RTCRST 31 | 185 | #define MC13783_IRQ_RTCRST MC13XXX_IRQ_RTCRST |
211 | #define MC13783_IRQ_PC 32 | 186 | #define MC13783_IRQ_PC MC13XXX_IRQ_PC |
212 | #define MC13783_IRQ_WARM 33 | 187 | #define MC13783_IRQ_WARM MC13XXX_IRQ_WARM |
213 | #define MC13783_IRQ_MEMHLD 34 | 188 | #define MC13783_IRQ_MEMHLD MC13XXX_IRQ_MEMHLD |
214 | #define MC13783_IRQ_PWRRDY 35 | 189 | #define MC13783_IRQ_PWRRDY 35 |
215 | #define MC13783_IRQ_THWARNL 36 | 190 | #define MC13783_IRQ_THWARNL MC13XXX_IRQ_THWARNL |
216 | #define MC13783_IRQ_THWARNH 37 | 191 | #define MC13783_IRQ_THWARNH MC13XXX_IRQ_THWARNH |
217 | #define MC13783_IRQ_CLK 38 | 192 | #define MC13783_IRQ_CLK MC13XXX_IRQ_CLK |
218 | #define MC13783_IRQ_SEMAF 39 | 193 | #define MC13783_IRQ_SEMAF 39 |
219 | #define MC13783_IRQ_MC2B 41 | 194 | #define MC13783_IRQ_MC2B 41 |
220 | #define MC13783_IRQ_HSDET 42 | 195 | #define MC13783_IRQ_HSDET 42 |
221 | #define MC13783_IRQ_HSL 43 | 196 | #define MC13783_IRQ_HSL 43 |
222 | #define MC13783_IRQ_ALSPTH 44 | 197 | #define MC13783_IRQ_ALSPTH 44 |
223 | #define MC13783_IRQ_AHSSHORT 45 | 198 | #define MC13783_IRQ_AHSSHORT 45 |
224 | #define MC13783_NUM_IRQ 46 | 199 | #define MC13783_NUM_IRQ MC13XXX_NUM_IRQ |
225 | 200 | ||
226 | #endif /* __LINUX_MFD_MC13783_H */ | 201 | #endif /* ifndef __LINUX_MFD_MC13783_H */ |