diff options
Diffstat (limited to 'include/linux/mfd/ab8500.h')
-rw-r--r-- | include/linux/mfd/ab8500.h | 137 |
1 files changed, 105 insertions, 32 deletions
diff --git a/include/linux/mfd/ab8500.h b/include/linux/mfd/ab8500.h index f5cec4500f38..b31843075198 100644 --- a/include/linux/mfd/ab8500.h +++ b/include/linux/mfd/ab8500.h | |||
@@ -10,6 +10,29 @@ | |||
10 | #include <linux/device.h> | 10 | #include <linux/device.h> |
11 | 11 | ||
12 | /* | 12 | /* |
13 | * AB8500 bank addresses | ||
14 | */ | ||
15 | #define AB8500_SYS_CTRL1_BLOCK 0x1 | ||
16 | #define AB8500_SYS_CTRL2_BLOCK 0x2 | ||
17 | #define AB8500_REGU_CTRL1 0x3 | ||
18 | #define AB8500_REGU_CTRL2 0x4 | ||
19 | #define AB8500_USB 0x5 | ||
20 | #define AB8500_TVOUT 0x6 | ||
21 | #define AB8500_DBI 0x7 | ||
22 | #define AB8500_ECI_AV_ACC 0x8 | ||
23 | #define AB8500_RESERVED 0x9 | ||
24 | #define AB8500_GPADC 0xA | ||
25 | #define AB8500_CHARGER 0xB | ||
26 | #define AB8500_GAS_GAUGE 0xC | ||
27 | #define AB8500_AUDIO 0xD | ||
28 | #define AB8500_INTERRUPT 0xE | ||
29 | #define AB8500_RTC 0xF | ||
30 | #define AB8500_MISC 0x10 | ||
31 | #define AB8500_DEBUG 0x12 | ||
32 | #define AB8500_PROD_TEST 0x13 | ||
33 | #define AB8500_OTP_EMUL 0x15 | ||
34 | |||
35 | /* | ||
13 | * Interrupts | 36 | * Interrupts |
14 | */ | 37 | */ |
15 | 38 | ||
@@ -51,40 +74,84 @@ | |||
51 | #define AB8500_INT_ACC_DETECT_21DB_F 37 | 74 | #define AB8500_INT_ACC_DETECT_21DB_F 37 |
52 | #define AB8500_INT_ACC_DETECT_21DB_R 38 | 75 | #define AB8500_INT_ACC_DETECT_21DB_R 38 |
53 | #define AB8500_INT_GP_SW_ADC_CONV_END 39 | 76 | #define AB8500_INT_GP_SW_ADC_CONV_END 39 |
54 | #define AB8500_INT_BTEMP_LOW 72 | 77 | #define AB8500_INT_ACC_DETECT_1DB_F 33 |
55 | #define AB8500_INT_BTEMP_LOW_MEDIUM 73 | 78 | #define AB8500_INT_ACC_DETECT_1DB_R 34 |
56 | #define AB8500_INT_BTEMP_MEDIUM_HIGH 74 | 79 | #define AB8500_INT_ACC_DETECT_22DB_F 35 |
57 | #define AB8500_INT_BTEMP_HIGH 75 | 80 | #define AB8500_INT_ACC_DETECT_22DB_R 36 |
58 | #define AB8500_INT_USB_CHARGER_NOT_OK 81 | 81 | #define AB8500_INT_ACC_DETECT_21DB_F 37 |
59 | #define AB8500_INT_ID_WAKEUP_R 82 | 82 | #define AB8500_INT_ACC_DETECT_21DB_R 38 |
60 | #define AB8500_INT_ID_DET_R1R 84 | 83 | #define AB8500_INT_GP_SW_ADC_CONV_END 39 |
61 | #define AB8500_INT_ID_DET_R2R 85 | 84 | #define AB8500_INT_GPIO6R 40 |
62 | #define AB8500_INT_ID_DET_R3R 86 | 85 | #define AB8500_INT_GPIO7R 41 |
63 | #define AB8500_INT_ID_DET_R4R 87 | 86 | #define AB8500_INT_GPIO8R 42 |
64 | #define AB8500_INT_ID_WAKEUP_F 88 | 87 | #define AB8500_INT_GPIO9R 43 |
65 | #define AB8500_INT_ID_DET_R1F 90 | 88 | #define AB8500_INT_GPIO10R 44 |
66 | #define AB8500_INT_ID_DET_R2F 91 | 89 | #define AB8500_INT_GPIO11R 45 |
67 | #define AB8500_INT_ID_DET_R3F 92 | 90 | #define AB8500_INT_GPIO12R 46 |
68 | #define AB8500_INT_ID_DET_R4F 93 | 91 | #define AB8500_INT_GPIO13R 47 |
69 | #define AB8500_INT_USB_CHG_DET_DONE 94 | 92 | #define AB8500_INT_GPIO24R 48 |
70 | #define AB8500_INT_USB_CH_TH_PROT_F 96 | 93 | #define AB8500_INT_GPIO25R 49 |
71 | #define AB8500_INT_USB_CH_TH_PROP_R 97 | 94 | #define AB8500_INT_GPIO36R 50 |
72 | #define AB8500_INT_MAIN_CH_TH_PROP_F 98 | 95 | #define AB8500_INT_GPIO37R 51 |
73 | #define AB8500_INT_MAIN_CH_TH_PROT_R 99 | 96 | #define AB8500_INT_GPIO38R 52 |
74 | #define AB8500_INT_USB_CHARGER_NOT_OKF 103 | 97 | #define AB8500_INT_GPIO39R 53 |
75 | 98 | #define AB8500_INT_GPIO40R 54 | |
76 | #define AB8500_NR_IRQS 104 | 99 | #define AB8500_INT_GPIO41R 55 |
77 | #define AB8500_NUM_IRQ_REGS 13 | 100 | #define AB8500_INT_GPIO6F 56 |
101 | #define AB8500_INT_GPIO7F 57 | ||
102 | #define AB8500_INT_GPIO8F 58 | ||
103 | #define AB8500_INT_GPIO9F 59 | ||
104 | #define AB8500_INT_GPIO10F 60 | ||
105 | #define AB8500_INT_GPIO11F 61 | ||
106 | #define AB8500_INT_GPIO12F 62 | ||
107 | #define AB8500_INT_GPIO13F 63 | ||
108 | #define AB8500_INT_GPIO24F 64 | ||
109 | #define AB8500_INT_GPIO25F 65 | ||
110 | #define AB8500_INT_GPIO36F 66 | ||
111 | #define AB8500_INT_GPIO37F 67 | ||
112 | #define AB8500_INT_GPIO38F 68 | ||
113 | #define AB8500_INT_GPIO39F 69 | ||
114 | #define AB8500_INT_GPIO40F 70 | ||
115 | #define AB8500_INT_GPIO41F 71 | ||
116 | #define AB8500_INT_ADP_SOURCE_ERROR 72 | ||
117 | #define AB8500_INT_ADP_SINK_ERROR 73 | ||
118 | #define AB8500_INT_ADP_PROBE_PLUG 74 | ||
119 | #define AB8500_INT_ADP_PROBE_UNPLUG 75 | ||
120 | #define AB8500_INT_ADP_SENSE_OFF 76 | ||
121 | #define AB8500_INT_USB_PHY_POWER_ERR 78 | ||
122 | #define AB8500_INT_USB_LINK_STATUS 79 | ||
123 | #define AB8500_INT_BTEMP_LOW 80 | ||
124 | #define AB8500_INT_BTEMP_LOW_MEDIUM 81 | ||
125 | #define AB8500_INT_BTEMP_MEDIUM_HIGH 82 | ||
126 | #define AB8500_INT_BTEMP_HIGH 83 | ||
127 | #define AB8500_INT_USB_CHARGER_NOT_OK 89 | ||
128 | #define AB8500_INT_ID_WAKEUP_R 90 | ||
129 | #define AB8500_INT_ID_DET_R1R 92 | ||
130 | #define AB8500_INT_ID_DET_R2R 93 | ||
131 | #define AB8500_INT_ID_DET_R3R 94 | ||
132 | #define AB8500_INT_ID_DET_R4R 95 | ||
133 | #define AB8500_INT_ID_WAKEUP_F 96 | ||
134 | #define AB8500_INT_ID_DET_R1F 98 | ||
135 | #define AB8500_INT_ID_DET_R2F 99 | ||
136 | #define AB8500_INT_ID_DET_R3F 100 | ||
137 | #define AB8500_INT_ID_DET_R4F 101 | ||
138 | #define AB8500_INT_USB_CHG_DET_DONE 102 | ||
139 | #define AB8500_INT_USB_CH_TH_PROT_F 104 | ||
140 | #define AB8500_INT_USB_CH_TH_PROT_R 105 | ||
141 | #define AB8500_INT_MAIN_CH_TH_PROT_F 106 | ||
142 | #define AB8500_INT_MAIN_CH_TH_PROT_R 107 | ||
143 | #define AB8500_INT_USB_CHARGER_NOT_OKF 111 | ||
78 | 144 | ||
79 | #define AB8500_NUM_REGULATORS 15 | 145 | #define AB8500_NR_IRQS 112 |
146 | #define AB8500_NUM_IRQ_REGS 14 | ||
80 | 147 | ||
81 | /** | 148 | /** |
82 | * struct ab8500 - ab8500 internal structure | 149 | * struct ab8500 - ab8500 internal structure |
83 | * @dev: parent device | 150 | * @dev: parent device |
84 | * @lock: read/write operations lock | 151 | * @lock: read/write operations lock |
85 | * @irq_lock: genirq bus lock | 152 | * @irq_lock: genirq bus lock |
86 | * @revision: chip revision | ||
87 | * @irq: irq line | 153 | * @irq: irq line |
154 | * @chip_id: chip revision id | ||
88 | * @write: register write | 155 | * @write: register write |
89 | * @read: register read | 156 | * @read: register read |
90 | * @rx_buf: rx buf for SPI | 157 | * @rx_buf: rx buf for SPI |
@@ -96,9 +163,10 @@ struct ab8500 { | |||
96 | struct device *dev; | 163 | struct device *dev; |
97 | struct mutex lock; | 164 | struct mutex lock; |
98 | struct mutex irq_lock; | 165 | struct mutex irq_lock; |
99 | int revision; | 166 | |
100 | int irq_base; | 167 | int irq_base; |
101 | int irq; | 168 | int irq; |
169 | u8 chip_id; | ||
102 | 170 | ||
103 | int (*write) (struct ab8500 *a8500, u16 addr, u8 data); | 171 | int (*write) (struct ab8500 *a8500, u16 addr, u8 data); |
104 | int (*read) (struct ab8500 *a8500, u16 addr); | 172 | int (*read) (struct ab8500 *a8500, u16 addr); |
@@ -110,24 +178,29 @@ struct ab8500 { | |||
110 | u8 oldmask[AB8500_NUM_IRQ_REGS]; | 178 | u8 oldmask[AB8500_NUM_IRQ_REGS]; |
111 | }; | 179 | }; |
112 | 180 | ||
181 | struct regulator_reg_init; | ||
113 | struct regulator_init_data; | 182 | struct regulator_init_data; |
183 | struct ab8500_gpio_platform_data; | ||
114 | 184 | ||
115 | /** | 185 | /** |
116 | * struct ab8500_platform_data - AB8500 platform data | 186 | * struct ab8500_platform_data - AB8500 platform data |
117 | * @irq_base: start of AB8500 IRQs, AB8500_NR_IRQS will be used | 187 | * @irq_base: start of AB8500 IRQs, AB8500_NR_IRQS will be used |
118 | * @init: board-specific initialization after detection of ab8500 | 188 | * @init: board-specific initialization after detection of ab8500 |
189 | * @num_regulator_reg_init: number of regulator init registers | ||
190 | * @regulator_reg_init: regulator init registers | ||
191 | * @num_regulator: number of regulators | ||
119 | * @regulator: machine-specific constraints for regulators | 192 | * @regulator: machine-specific constraints for regulators |
120 | */ | 193 | */ |
121 | struct ab8500_platform_data { | 194 | struct ab8500_platform_data { |
122 | int irq_base; | 195 | int irq_base; |
123 | void (*init) (struct ab8500 *); | 196 | void (*init) (struct ab8500 *); |
124 | struct regulator_init_data *regulator[AB8500_NUM_REGULATORS]; | 197 | int num_regulator_reg_init; |
198 | struct ab8500_regulator_reg_init *regulator_reg_init; | ||
199 | int num_regulator; | ||
200 | struct regulator_init_data *regulator; | ||
201 | struct ab8500_gpio_platform_data *gpio; | ||
125 | }; | 202 | }; |
126 | 203 | ||
127 | extern int ab8500_write(struct ab8500 *a8500, u16 addr, u8 data); | ||
128 | extern int ab8500_read(struct ab8500 *a8500, u16 addr); | ||
129 | extern int ab8500_set_bits(struct ab8500 *a8500, u16 addr, u8 mask, u8 data); | ||
130 | |||
131 | extern int __devinit ab8500_init(struct ab8500 *ab8500); | 204 | extern int __devinit ab8500_init(struct ab8500 *ab8500); |
132 | extern int __devexit ab8500_exit(struct ab8500 *ab8500); | 205 | extern int __devexit ab8500_exit(struct ab8500 *ab8500); |
133 | 206 | ||