diff options
Diffstat (limited to 'include')
| -rw-r--r-- | include/linux/mfd/wm831x/core.h | 247 | ||||
| -rw-r--r-- | include/linux/mfd/wm831x/pdata.h | 107 |
2 files changed, 354 insertions, 0 deletions
diff --git a/include/linux/mfd/wm831x/core.h b/include/linux/mfd/wm831x/core.h new file mode 100644 index 000000000000..d90e693053ba --- /dev/null +++ b/include/linux/mfd/wm831x/core.h | |||
| @@ -0,0 +1,247 @@ | |||
| 1 | /* | ||
| 2 | * include/linux/mfd/wm831x/core.h -- Core interface for WM831x | ||
| 3 | * | ||
| 4 | * Copyright 2009 Wolfson Microelectronics PLC. | ||
| 5 | * | ||
| 6 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify it | ||
| 9 | * under the terms of the GNU General Public License as published by the | ||
| 10 | * Free Software Foundation; either version 2 of the License, or (at your | ||
| 11 | * option) any later version. | ||
| 12 | * | ||
| 13 | */ | ||
| 14 | |||
| 15 | #ifndef __MFD_WM831X_CORE_H__ | ||
| 16 | #define __MFD_WM831X_CORE_H__ | ||
| 17 | |||
| 18 | /* | ||
| 19 | * Register values. | ||
| 20 | */ | ||
| 21 | #define WM831X_RESET_ID 0x00 | ||
| 22 | #define WM831X_REVISION 0x01 | ||
| 23 | #define WM831X_PARENT_ID 0x4000 | ||
| 24 | #define WM831X_SYSVDD_CONTROL 0x4001 | ||
| 25 | #define WM831X_THERMAL_MONITORING 0x4002 | ||
| 26 | #define WM831X_POWER_STATE 0x4003 | ||
| 27 | #define WM831X_WATCHDOG 0x4004 | ||
| 28 | #define WM831X_ON_PIN_CONTROL 0x4005 | ||
| 29 | #define WM831X_RESET_CONTROL 0x4006 | ||
| 30 | #define WM831X_CONTROL_INTERFACE 0x4007 | ||
| 31 | #define WM831X_SECURITY_KEY 0x4008 | ||
| 32 | #define WM831X_SOFTWARE_SCRATCH 0x4009 | ||
| 33 | #define WM831X_OTP_CONTROL 0x400A | ||
| 34 | #define WM831X_GPIO_LEVEL 0x400C | ||
| 35 | #define WM831X_SYSTEM_STATUS 0x400D | ||
| 36 | #define WM831X_ON_SOURCE 0x400E | ||
| 37 | #define WM831X_OFF_SOURCE 0x400F | ||
| 38 | #define WM831X_SYSTEM_INTERRUPTS 0x4010 | ||
| 39 | #define WM831X_INTERRUPT_STATUS_1 0x4011 | ||
| 40 | #define WM831X_INTERRUPT_STATUS_2 0x4012 | ||
| 41 | #define WM831X_INTERRUPT_STATUS_3 0x4013 | ||
| 42 | #define WM831X_INTERRUPT_STATUS_4 0x4014 | ||
| 43 | #define WM831X_INTERRUPT_STATUS_5 0x4015 | ||
| 44 | #define WM831X_IRQ_CONFIG 0x4017 | ||
| 45 | #define WM831X_SYSTEM_INTERRUPTS_MASK 0x4018 | ||
| 46 | #define WM831X_INTERRUPT_STATUS_1_MASK 0x4019 | ||
| 47 | #define WM831X_INTERRUPT_STATUS_2_MASK 0x401A | ||
| 48 | #define WM831X_INTERRUPT_STATUS_3_MASK 0x401B | ||
| 49 | #define WM831X_INTERRUPT_STATUS_4_MASK 0x401C | ||
| 50 | #define WM831X_INTERRUPT_STATUS_5_MASK 0x401D | ||
| 51 | #define WM831X_RTC_WRITE_COUNTER 0x4020 | ||
| 52 | #define WM831X_RTC_TIME_1 0x4021 | ||
| 53 | #define WM831X_RTC_TIME_2 0x4022 | ||
| 54 | #define WM831X_RTC_ALARM_1 0x4023 | ||
| 55 | #define WM831X_RTC_ALARM_2 0x4024 | ||
| 56 | #define WM831X_RTC_CONTROL 0x4025 | ||
| 57 | #define WM831X_RTC_TRIM 0x4026 | ||
| 58 | #define WM831X_TOUCH_CONTROL_1 0x4028 | ||
| 59 | #define WM831X_TOUCH_CONTROL_2 0x4029 | ||
| 60 | #define WM831X_TOUCH_DATA_X 0x402A | ||
| 61 | #define WM831X_TOUCH_DATA_Y 0x402B | ||
| 62 | #define WM831X_TOUCH_DATA_Z 0x402C | ||
| 63 | #define WM831X_AUXADC_DATA 0x402D | ||
| 64 | #define WM831X_AUXADC_CONTROL 0x402E | ||
| 65 | #define WM831X_AUXADC_SOURCE 0x402F | ||
| 66 | #define WM831X_COMPARATOR_CONTROL 0x4030 | ||
| 67 | #define WM831X_COMPARATOR_1 0x4031 | ||
| 68 | #define WM831X_COMPARATOR_2 0x4032 | ||
| 69 | #define WM831X_COMPARATOR_3 0x4033 | ||
| 70 | #define WM831X_COMPARATOR_4 0x4034 | ||
| 71 | #define WM831X_GPIO1_CONTROL 0x4038 | ||
| 72 | #define WM831X_GPIO2_CONTROL 0x4039 | ||
| 73 | #define WM831X_GPIO3_CONTROL 0x403A | ||
| 74 | #define WM831X_GPIO4_CONTROL 0x403B | ||
| 75 | #define WM831X_GPIO5_CONTROL 0x403C | ||
| 76 | #define WM831X_GPIO6_CONTROL 0x403D | ||
| 77 | #define WM831X_GPIO7_CONTROL 0x403E | ||
| 78 | #define WM831X_GPIO8_CONTROL 0x403F | ||
| 79 | #define WM831X_GPIO9_CONTROL 0x4040 | ||
| 80 | #define WM831X_GPIO10_CONTROL 0x4041 | ||
| 81 | #define WM831X_GPIO11_CONTROL 0x4042 | ||
| 82 | #define WM831X_GPIO12_CONTROL 0x4043 | ||
| 83 | #define WM831X_GPIO13_CONTROL 0x4044 | ||
| 84 | #define WM831X_GPIO14_CONTROL 0x4045 | ||
| 85 | #define WM831X_GPIO15_CONTROL 0x4046 | ||
| 86 | #define WM831X_GPIO16_CONTROL 0x4047 | ||
| 87 | #define WM831X_CHARGER_CONTROL_1 0x4048 | ||
| 88 | #define WM831X_CHARGER_CONTROL_2 0x4049 | ||
| 89 | #define WM831X_CHARGER_STATUS 0x404A | ||
| 90 | #define WM831X_BACKUP_CHARGER_CONTROL 0x404B | ||
| 91 | #define WM831X_STATUS_LED_1 0x404C | ||
| 92 | #define WM831X_STATUS_LED_2 0x404D | ||
| 93 | #define WM831X_CURRENT_SINK_1 0x404E | ||
| 94 | #define WM831X_CURRENT_SINK_2 0x404F | ||
| 95 | #define WM831X_DCDC_ENABLE 0x4050 | ||
| 96 | #define WM831X_LDO_ENABLE 0x4051 | ||
| 97 | #define WM831X_DCDC_STATUS 0x4052 | ||
| 98 | #define WM831X_LDO_STATUS 0x4053 | ||
| 99 | #define WM831X_DCDC_UV_STATUS 0x4054 | ||
| 100 | #define WM831X_LDO_UV_STATUS 0x4055 | ||
| 101 | #define WM831X_DC1_CONTROL_1 0x4056 | ||
| 102 | #define WM831X_DC1_CONTROL_2 0x4057 | ||
| 103 | #define WM831X_DC1_ON_CONFIG 0x4058 | ||
| 104 | #define WM831X_DC1_SLEEP_CONTROL 0x4059 | ||
| 105 | #define WM831X_DC1_DVS_CONTROL 0x405A | ||
| 106 | #define WM831X_DC2_CONTROL_1 0x405B | ||
| 107 | #define WM831X_DC2_CONTROL_2 0x405C | ||
| 108 | #define WM831X_DC2_ON_CONFIG 0x405D | ||
| 109 | #define WM831X_DC2_SLEEP_CONTROL 0x405E | ||
| 110 | #define WM831X_DC2_DVS_CONTROL 0x405F | ||
| 111 | #define WM831X_DC3_CONTROL_1 0x4060 | ||
| 112 | #define WM831X_DC3_CONTROL_2 0x4061 | ||
| 113 | #define WM831X_DC3_ON_CONFIG 0x4062 | ||
| 114 | #define WM831X_DC3_SLEEP_CONTROL 0x4063 | ||
| 115 | #define WM831X_DC4_CONTROL 0x4064 | ||
| 116 | #define WM831X_DC4_SLEEP_CONTROL 0x4065 | ||
| 117 | #define WM831X_EPE1_CONTROL 0x4066 | ||
| 118 | #define WM831X_EPE2_CONTROL 0x4067 | ||
| 119 | #define WM831X_LDO1_CONTROL 0x4068 | ||
| 120 | #define WM831X_LDO1_ON_CONTROL 0x4069 | ||
| 121 | #define WM831X_LDO1_SLEEP_CONTROL 0x406A | ||
| 122 | #define WM831X_LDO2_CONTROL 0x406B | ||
| 123 | #define WM831X_LDO2_ON_CONTROL 0x406C | ||
| 124 | #define WM831X_LDO2_SLEEP_CONTROL 0x406D | ||
| 125 | #define WM831X_LDO3_CONTROL 0x406E | ||
| 126 | #define WM831X_LDO3_ON_CONTROL 0x406F | ||
| 127 | #define WM831X_LDO3_SLEEP_CONTROL 0x4070 | ||
| 128 | #define WM831X_LDO4_CONTROL 0x4071 | ||
| 129 | #define WM831X_LDO4_ON_CONTROL 0x4072 | ||
| 130 | #define WM831X_LDO4_SLEEP_CONTROL 0x4073 | ||
| 131 | #define WM831X_LDO5_CONTROL 0x4074 | ||
| 132 | #define WM831X_LDO5_ON_CONTROL 0x4075 | ||
| 133 | #define WM831X_LDO5_SLEEP_CONTROL 0x4076 | ||
| 134 | #define WM831X_LDO6_CONTROL 0x4077 | ||
| 135 | #define WM831X_LDO6_ON_CONTROL 0x4078 | ||
| 136 | #define WM831X_LDO6_SLEEP_CONTROL 0x4079 | ||
| 137 | #define WM831X_LDO7_CONTROL 0x407A | ||
| 138 | #define WM831X_LDO7_ON_CONTROL 0x407B | ||
| 139 | #define WM831X_LDO7_SLEEP_CONTROL 0x407C | ||
| 140 | #define WM831X_LDO8_CONTROL 0x407D | ||
| 141 | #define WM831X_LDO8_ON_CONTROL 0x407E | ||
| 142 | #define WM831X_LDO8_SLEEP_CONTROL 0x407F | ||
| 143 | #define WM831X_LDO9_CONTROL 0x4080 | ||
| 144 | #define WM831X_LDO9_ON_CONTROL 0x4081 | ||
| 145 | #define WM831X_LDO9_SLEEP_CONTROL 0x4082 | ||
| 146 | #define WM831X_LDO10_CONTROL 0x4083 | ||
| 147 | #define WM831X_LDO10_ON_CONTROL 0x4084 | ||
| 148 | #define WM831X_LDO10_SLEEP_CONTROL 0x4085 | ||
| 149 | #define WM831X_LDO11_ON_CONTROL 0x4087 | ||
| 150 | #define WM831X_LDO11_SLEEP_CONTROL 0x4088 | ||
| 151 | #define WM831X_POWER_GOOD_SOURCE_1 0x408E | ||
| 152 | #define WM831X_POWER_GOOD_SOURCE_2 0x408F | ||
| 153 | #define WM831X_CLOCK_CONTROL_1 0x4090 | ||
| 154 | #define WM831X_CLOCK_CONTROL_2 0x4091 | ||
| 155 | #define WM831X_FLL_CONTROL_1 0x4092 | ||
| 156 | #define WM831X_FLL_CONTROL_2 0x4093 | ||
| 157 | #define WM831X_FLL_CONTROL_3 0x4094 | ||
| 158 | #define WM831X_FLL_CONTROL_4 0x4095 | ||
| 159 | #define WM831X_FLL_CONTROL_5 0x4096 | ||
| 160 | #define WM831X_UNIQUE_ID_1 0x7800 | ||
| 161 | #define WM831X_UNIQUE_ID_2 0x7801 | ||
| 162 | #define WM831X_UNIQUE_ID_3 0x7802 | ||
| 163 | #define WM831X_UNIQUE_ID_4 0x7803 | ||
| 164 | #define WM831X_UNIQUE_ID_5 0x7804 | ||
| 165 | #define WM831X_UNIQUE_ID_6 0x7805 | ||
| 166 | #define WM831X_UNIQUE_ID_7 0x7806 | ||
| 167 | #define WM831X_UNIQUE_ID_8 0x7807 | ||
| 168 | #define WM831X_FACTORY_OTP_ID 0x7808 | ||
| 169 | #define WM831X_FACTORY_OTP_1 0x7809 | ||
| 170 | #define WM831X_FACTORY_OTP_2 0x780A | ||
| 171 | #define WM831X_FACTORY_OTP_3 0x780B | ||
| 172 | #define WM831X_FACTORY_OTP_4 0x780C | ||
| 173 | #define WM831X_FACTORY_OTP_5 0x780D | ||
| 174 | #define WM831X_CUSTOMER_OTP_ID 0x7810 | ||
| 175 | #define WM831X_DC1_OTP_CONTROL 0x7811 | ||
| 176 | #define WM831X_DC2_OTP_CONTROL 0x7812 | ||
| 177 | #define WM831X_DC3_OTP_CONTROL 0x7813 | ||
| 178 | #define WM831X_LDO1_2_OTP_CONTROL 0x7814 | ||
| 179 | #define WM831X_LDO3_4_OTP_CONTROL 0x7815 | ||
| 180 | #define WM831X_LDO5_6_OTP_CONTROL 0x7816 | ||
| 181 | #define WM831X_LDO7_8_OTP_CONTROL 0x7817 | ||
| 182 | #define WM831X_LDO9_10_OTP_CONTROL 0x7818 | ||
| 183 | #define WM831X_LDO11_EPE_CONTROL 0x7819 | ||
| 184 | #define WM831X_GPIO1_OTP_CONTROL 0x781A | ||
| 185 | #define WM831X_GPIO2_OTP_CONTROL 0x781B | ||
| 186 | #define WM831X_GPIO3_OTP_CONTROL 0x781C | ||
| 187 | #define WM831X_GPIO4_OTP_CONTROL 0x781D | ||
| 188 | #define WM831X_GPIO5_OTP_CONTROL 0x781E | ||
| 189 | #define WM831X_GPIO6_OTP_CONTROL 0x781F | ||
| 190 | #define WM831X_DBE_CHECK_DATA 0x7827 | ||
| 191 | |||
| 192 | /* | ||
| 193 | * R0 (0x00) - Reset ID | ||
| 194 | */ | ||
| 195 | #define WM831X_CHIP_ID_MASK 0xFFFF /* CHIP_ID - [15:0] */ | ||
| 196 | #define WM831X_CHIP_ID_SHIFT 0 /* CHIP_ID - [15:0] */ | ||
| 197 | #define WM831X_CHIP_ID_WIDTH 16 /* CHIP_ID - [15:0] */ | ||
| 198 | |||
| 199 | /* | ||
| 200 | * R1 (0x01) - Revision | ||
| 201 | */ | ||
| 202 | #define WM831X_PARENT_REV_MASK 0xFF00 /* PARENT_REV - [15:8] */ | ||
| 203 | #define WM831X_PARENT_REV_SHIFT 8 /* PARENT_REV - [15:8] */ | ||
| 204 | #define WM831X_PARENT_REV_WIDTH 8 /* PARENT_REV - [15:8] */ | ||
| 205 | #define WM831X_CHILD_REV_MASK 0x00FF /* CHILD_REV - [7:0] */ | ||
| 206 | #define WM831X_CHILD_REV_SHIFT 0 /* CHILD_REV - [7:0] */ | ||
| 207 | #define WM831X_CHILD_REV_WIDTH 8 /* CHILD_REV - [7:0] */ | ||
| 208 | |||
| 209 | /* | ||
| 210 | * R16384 (0x4000) - Parent ID | ||
| 211 | */ | ||
| 212 | #define WM831X_PARENT_ID_MASK 0xFFFF /* PARENT_ID - [15:0] */ | ||
| 213 | #define WM831X_PARENT_ID_SHIFT 0 /* PARENT_ID - [15:0] */ | ||
| 214 | #define WM831X_PARENT_ID_WIDTH 16 /* PARENT_ID - [15:0] */ | ||
| 215 | |||
| 216 | struct wm831x { | ||
| 217 | struct mutex io_lock; | ||
| 218 | |||
| 219 | struct device *dev; | ||
| 220 | int (*read_dev)(struct wm831x *wm831x, unsigned short reg, | ||
| 221 | int bytes, void *dest); | ||
| 222 | int (*write_dev)(struct wm831x *wm831x, unsigned short reg, | ||
| 223 | int bytes, void *src); | ||
| 224 | |||
| 225 | void *control_data; | ||
| 226 | |||
| 227 | /* The WM831x has a security key blocking access to certain | ||
| 228 | * registers. The mutex is taken by the accessors for locking | ||
| 229 | * and unlocking the security key, locked is used to fail | ||
| 230 | * writes if the lock is held. | ||
| 231 | */ | ||
| 232 | struct mutex key_lock; | ||
| 233 | unsigned int locked:1; | ||
| 234 | }; | ||
| 235 | |||
| 236 | /* Device I/O API */ | ||
| 237 | int wm831x_reg_read(struct wm831x *wm831x, unsigned short reg); | ||
| 238 | int wm831x_reg_write(struct wm831x *wm831x, unsigned short reg, | ||
| 239 | unsigned short val); | ||
| 240 | void wm831x_reg_lock(struct wm831x *wm831x); | ||
| 241 | int wm831x_reg_unlock(struct wm831x *wm831x); | ||
| 242 | int wm831x_set_bits(struct wm831x *wm831x, unsigned short reg, | ||
| 243 | unsigned short mask, unsigned short val); | ||
| 244 | int wm831x_bulk_read(struct wm831x *wm831x, unsigned short reg, | ||
| 245 | int count, u16 *buf); | ||
| 246 | |||
| 247 | #endif | ||
diff --git a/include/linux/mfd/wm831x/pdata.h b/include/linux/mfd/wm831x/pdata.h new file mode 100644 index 000000000000..571e60136264 --- /dev/null +++ b/include/linux/mfd/wm831x/pdata.h | |||
| @@ -0,0 +1,107 @@ | |||
| 1 | /* | ||
| 2 | * include/linux/mfd/wm831x/pdata.h -- Platform data for WM831x | ||
| 3 | * | ||
| 4 | * Copyright 2009 Wolfson Microelectronics PLC. | ||
| 5 | * | ||
| 6 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify it | ||
| 9 | * under the terms of the GNU General Public License as published by the | ||
| 10 | * Free Software Foundation; either version 2 of the License, or (at your | ||
| 11 | * option) any later version. | ||
| 12 | * | ||
| 13 | */ | ||
| 14 | |||
| 15 | #ifndef __MFD_WM831X_PDATA_H__ | ||
| 16 | #define __MFD_WM831X_PDATA_H__ | ||
| 17 | |||
| 18 | struct wm831x; | ||
| 19 | struct regulator_init_data; | ||
| 20 | |||
| 21 | struct wm831x_backup_pdata { | ||
| 22 | int charger_enable; | ||
| 23 | int no_constant_voltage; /** Disable constant voltage charging */ | ||
| 24 | int vlim; /** Voltage limit in milivolts */ | ||
| 25 | int ilim; /** Current limit in microamps */ | ||
| 26 | }; | ||
| 27 | |||
| 28 | struct wm831x_battery_pdata { | ||
| 29 | int enable; /** Enable charging */ | ||
| 30 | int fast_enable; /** Enable fast charging */ | ||
| 31 | int off_mask; /** Mask OFF while charging */ | ||
| 32 | int trickle_ilim; /** Trickle charge current limit, in mA */ | ||
| 33 | int vsel; /** Target voltage, in mV */ | ||
| 34 | int eoc_iterm; /** End of trickle charge current, in mA */ | ||
| 35 | int fast_ilim; /** Fast charge current limit, in mA */ | ||
| 36 | int timeout; /** Charge cycle timeout, in minutes */ | ||
| 37 | }; | ||
| 38 | |||
| 39 | /* Sources for status LED configuration. Values are register values | ||
| 40 | * plus 1 to allow for a zero default for preserve. | ||
| 41 | */ | ||
| 42 | enum wm831x_status_src { | ||
| 43 | WM831X_STATUS_PRESERVE = 0, /* Keep the current hardware setting */ | ||
| 44 | WM831X_STATUS_OTP = 1, | ||
| 45 | WM831X_STATUS_POWER = 2, | ||
| 46 | WM831X_STATUS_CHARGER = 3, | ||
| 47 | WM831X_STATUS_MANUAL = 4, | ||
| 48 | }; | ||
| 49 | |||
| 50 | struct wm831x_status_pdata { | ||
| 51 | enum wm831x_status_src default_src; | ||
| 52 | const char *name; | ||
| 53 | const char *default_trigger; | ||
| 54 | }; | ||
| 55 | |||
| 56 | struct wm831x_touch_pdata { | ||
| 57 | int fivewire; /** 1 for five wire mode, 0 for 4 wire */ | ||
| 58 | int isel; /** Current for pen down (uA) */ | ||
| 59 | int rpu; /** Pen down sensitivity resistor divider */ | ||
| 60 | int pressure; /** Report pressure (boolean) */ | ||
| 61 | int data_irq; /** Touch data ready IRQ */ | ||
| 62 | }; | ||
| 63 | |||
| 64 | enum wm831x_watchdog_action { | ||
| 65 | WM831X_WDOG_NONE = 0, | ||
| 66 | WM831X_WDOG_INTERRUPT = 1, | ||
| 67 | WM831X_WDOG_RESET = 2, | ||
| 68 | WM831X_WDOG_WAKE = 3, | ||
| 69 | }; | ||
| 70 | |||
| 71 | struct wm831x_watchdog_pdata { | ||
| 72 | enum wm831x_watchdog_action primary, secondary; | ||
| 73 | int update_gpio; | ||
| 74 | unsigned int software:1; | ||
| 75 | }; | ||
| 76 | |||
| 77 | #define WM831X_MAX_STATUS 2 | ||
| 78 | #define WM831X_MAX_DCDC 4 | ||
| 79 | #define WM831X_MAX_EPE 2 | ||
| 80 | #define WM831X_MAX_LDO 11 | ||
| 81 | #define WM831X_MAX_ISINK 2 | ||
| 82 | |||
| 83 | struct wm831x_pdata { | ||
| 84 | /** Called before subdevices are set up */ | ||
| 85 | int (*pre_init)(struct wm831x *wm831x); | ||
| 86 | /** Called after subdevices are set up */ | ||
| 87 | int (*post_init)(struct wm831x *wm831x); | ||
| 88 | |||
| 89 | int gpio_base; | ||
| 90 | struct wm831x_backup_pdata *backup; | ||
| 91 | struct wm831x_battery_pdata *battery; | ||
| 92 | struct wm831x_touch_pdata *touch; | ||
| 93 | struct wm831x_watchdog_pdata *watchdog; | ||
| 94 | |||
| 95 | /** LED1 = 0 and so on */ | ||
| 96 | struct wm831x_status_pdata *status[WM831X_MAX_STATUS]; | ||
| 97 | /** DCDC1 = 0 and so on */ | ||
| 98 | struct regulator_init_data *dcdc[WM831X_MAX_DCDC]; | ||
| 99 | /** EPE1 = 0 and so on */ | ||
| 100 | struct regulator_init_data *epe[WM831X_MAX_EPE]; | ||
| 101 | /** LDO1 = 0 and so on */ | ||
| 102 | struct regulator_init_data *ldo[WM831X_MAX_LDO]; | ||
| 103 | /** ISINK1 = 0 and so on*/ | ||
| 104 | struct regulator_init_data *isink[WM831X_MAX_ISINK]; | ||
| 105 | }; | ||
| 106 | |||
| 107 | #endif | ||
