lp8788.h 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. /*
  2. * TI LP8788 MFD Device
  3. *
  4. * Copyright 2012 Texas Instruments
  5. *
  6. * Author: Milo(Woogyom) Kim <milo.kim@ti.com>
  7. *
  8. * This program is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License version 2 as
  10. * published by the Free Software Foundation.
  11. *
  12. */
  13. #ifndef __MFD_LP8788_H__
  14. #define __MFD_LP8788_H__
  15. #include <linux/gpio.h>
  16. #include <linux/irqdomain.h>
  17. #include <linux/pwm.h>
  18. #include <linux/regmap.h>
  19. #define LP8788_DEV_BUCK "lp8788-buck"
  20. #define LP8788_DEV_DLDO "lp8788-dldo"
  21. #define LP8788_DEV_ALDO "lp8788-aldo"
  22. #define LP8788_DEV_CHARGER "lp8788-charger"
  23. #define LP8788_DEV_RTC "lp8788-rtc"
  24. #define LP8788_DEV_BACKLIGHT "lp8788-backlight"
  25. #define LP8788_DEV_VIBRATOR "lp8788-vibrator"
  26. #define LP8788_DEV_KEYLED "lp8788-keyled"
  27. #define LP8788_DEV_ADC "lp8788-adc"
  28. #define LP8788_NUM_BUCKS 4
  29. #define LP8788_NUM_DLDOS 12
  30. #define LP8788_NUM_ALDOS 10
  31. #define LP8788_NUM_BUCK2_DVS 2
  32. #define LP8788_CHG_IRQ "CHG_IRQ"
  33. #define LP8788_PRSW_IRQ "PRSW_IRQ"
  34. #define LP8788_BATT_IRQ "BATT_IRQ"
  35. #define LP8788_ALM_IRQ "ALARM_IRQ"
  36. enum lp8788_int_id {
  37. /* interrup register 1 : Addr 00h */
  38. LP8788_INT_TSDL,
  39. LP8788_INT_TSDH,
  40. LP8788_INT_UVLO,
  41. LP8788_INT_FLAGMON,
  42. LP8788_INT_PWRON_TIME,
  43. LP8788_INT_PWRON,
  44. LP8788_INT_COMP1,
  45. LP8788_INT_COMP2,
  46. /* interrupt register 2 : Addr 01h */
  47. LP8788_INT_CHG_INPUT_STATE,
  48. LP8788_INT_CHG_STATE,
  49. LP8788_INT_EOC,
  50. LP8788_INT_CHG_RESTART,
  51. LP8788_INT_RESTART_TIMEOUT,
  52. LP8788_INT_FULLCHG_TIMEOUT,
  53. LP8788_INT_PRECHG_TIMEOUT,
  54. /* interrupt register 3 : Addr 02h */
  55. LP8788_INT_RTC_ALARM1 = 17,
  56. LP8788_INT_RTC_ALARM2,
  57. LP8788_INT_ENTER_SYS_SUPPORT,
  58. LP8788_INT_EXIT_SYS_SUPPORT,
  59. LP8788_INT_BATT_LOW,
  60. LP8788_INT_NO_BATT,
  61. LP8788_INT_MAX = 24,
  62. };
  63. enum lp8788_dvs_sel {
  64. DVS_SEL_V0,
  65. DVS_SEL_V1,
  66. DVS_SEL_V2,
  67. DVS_SEL_V3,
  68. };
  69. enum lp8788_ext_ldo_en_id {
  70. EN_ALDO1,
  71. EN_ALDO234,
  72. EN_ALDO5,
  73. EN_ALDO7,
  74. EN_DLDO7,
  75. EN_DLDO911,
  76. EN_LDOS_MAX,
  77. };
  78. enum lp8788_charger_event {
  79. NO_CHARGER,
  80. CHARGER_DETECTED,
  81. };
  82. enum lp8788_bl_ctrl_mode {
  83. LP8788_BL_REGISTER_ONLY,
  84. LP8788_BL_COMB_PWM_BASED, /* PWM + I2C, changed by PWM input */
  85. LP8788_BL_COMB_REGISTER_BASED, /* PWM + I2C, changed by I2C */
  86. };
  87. enum lp8788_bl_dim_mode {
  88. LP8788_DIM_EXPONENTIAL,
  89. LP8788_DIM_LINEAR,
  90. };
  91. enum lp8788_bl_full_scale_current {
  92. LP8788_FULLSCALE_5000uA,
  93. LP8788_FULLSCALE_8500uA,
  94. LP8788_FULLSCALE_1200uA,
  95. LP8788_FULLSCALE_1550uA,
  96. LP8788_FULLSCALE_1900uA,
  97. LP8788_FULLSCALE_2250uA,
  98. LP8788_FULLSCALE_2600uA,
  99. LP8788_FULLSCALE_2950uA,
  100. };
  101. enum lp8788_bl_ramp_step {
  102. LP8788_RAMP_8us,
  103. LP8788_RAMP_1024us,
  104. LP8788_RAMP_2048us,
  105. LP8788_RAMP_4096us,
  106. LP8788_RAMP_8192us,
  107. LP8788_RAMP_16384us,
  108. LP8788_RAMP_32768us,
  109. LP8788_RAMP_65538us,
  110. };
  111. enum lp8788_isink_scale {
  112. LP8788_ISINK_SCALE_100mA,
  113. LP8788_ISINK_SCALE_120mA,
  114. };
  115. enum lp8788_isink_number {
  116. LP8788_ISINK_1,
  117. LP8788_ISINK_2,
  118. LP8788_ISINK_3,
  119. };
  120. enum lp8788_alarm_sel {
  121. LP8788_ALARM_1,
  122. LP8788_ALARM_2,
  123. LP8788_ALARM_MAX,
  124. };
  125. enum lp8788_adc_id {
  126. LPADC_VBATT_5P5,
  127. LPADC_VIN_CHG,
  128. LPADC_IBATT,
  129. LPADC_IC_TEMP,
  130. LPADC_VBATT_6P0,
  131. LPADC_VBATT_5P0,
  132. LPADC_ADC1,
  133. LPADC_ADC2,
  134. LPADC_VDD,
  135. LPADC_VCOIN,
  136. LPADC_VDD_LDO,
  137. LPADC_ADC3,
  138. LPADC_ADC4,
  139. LPADC_MAX,
  140. };
  141. struct lp8788;
  142. /*
  143. * lp8788_buck1_dvs
  144. * @gpio : gpio pin number for dvs control
  145. * @vsel : dvs selector for buck v1 register
  146. */
  147. struct lp8788_buck1_dvs {
  148. int gpio;
  149. enum lp8788_dvs_sel vsel;
  150. };
  151. /*
  152. * lp8788_buck2_dvs
  153. * @gpio : two gpio pin numbers are used for dvs
  154. * @vsel : dvs selector for buck v2 register
  155. */
  156. struct lp8788_buck2_dvs {
  157. int gpio[LP8788_NUM_BUCK2_DVS];
  158. enum lp8788_dvs_sel vsel;
  159. };
  160. /*
  161. * struct lp8788_ldo_enable_pin
  162. *
  163. * Basically, all LDOs are enabled through the I2C commands.
  164. * But ALDO 1 ~ 5, 7, DLDO 7, 9, 11 can be enabled by external gpio pins.
  165. *
  166. * @gpio : gpio number which is used for enabling ldos
  167. * @init_state : initial gpio state (ex. GPIOF_OUT_INIT_LOW)
  168. */
  169. struct lp8788_ldo_enable_pin {
  170. int gpio;
  171. int init_state;
  172. };
  173. /*
  174. * struct lp8788_chg_param
  175. * @addr : charging control register address (range : 0x11 ~ 0x1C)
  176. * @val : charging parameter value
  177. */
  178. struct lp8788_chg_param {
  179. u8 addr;
  180. u8 val;
  181. };
  182. /*
  183. * struct lp8788_charger_platform_data
  184. * @adc_vbatt : adc channel name for battery voltage
  185. * @adc_batt_temp : adc channel name for battery temperature
  186. * @max_vbatt_mv : used for calculating battery capacity
  187. * @chg_params : initial charging parameters
  188. * @num_chg_params : numbers of charging parameters
  189. * @charger_event : the charger event can be reported to the platform side
  190. */
  191. struct lp8788_charger_platform_data {
  192. const char *adc_vbatt;
  193. const char *adc_batt_temp;
  194. unsigned int max_vbatt_mv;
  195. struct lp8788_chg_param *chg_params;
  196. int num_chg_params;
  197. void (*charger_event) (struct lp8788 *lp,
  198. enum lp8788_charger_event event);
  199. };
  200. /*
  201. * struct lp8788_backlight_platform_data
  202. * @name : backlight driver name. (default: "lcd-backlight")
  203. * @initial_brightness : initial value of backlight brightness
  204. * @bl_mode : brightness control by pwm or lp8788 register
  205. * @dim_mode : dimming mode selection
  206. * @full_scale : full scale current setting
  207. * @rise_time : brightness ramp up step time
  208. * @fall_time : brightness ramp down step time
  209. * @pwm_pol : pwm polarity setting when bl_mode is pwm based
  210. * @period_ns : platform specific pwm period value. unit is nano.
  211. Only valid when bl_mode is LP8788_BL_COMB_PWM_BASED
  212. */
  213. struct lp8788_backlight_platform_data {
  214. char *name;
  215. int initial_brightness;
  216. enum lp8788_bl_ctrl_mode bl_mode;
  217. enum lp8788_bl_dim_mode dim_mode;
  218. enum lp8788_bl_full_scale_current full_scale;
  219. enum lp8788_bl_ramp_step rise_time;
  220. enum lp8788_bl_ramp_step fall_time;
  221. enum pwm_polarity pwm_pol;
  222. unsigned int period_ns;
  223. };
  224. /*
  225. * struct lp8788_led_platform_data
  226. * @name : led driver name. (default: "keyboard-backlight")
  227. * @scale : current scale
  228. * @num : current sink number
  229. * @iout_code : current output value (Addr 9Ah ~ 9Bh)
  230. */
  231. struct lp8788_led_platform_data {
  232. char *name;
  233. enum lp8788_isink_scale scale;
  234. enum lp8788_isink_number num;
  235. int iout_code;
  236. };
  237. /*
  238. * struct lp8788_vib_platform_data
  239. * @name : vibrator driver name
  240. * @scale : current scale
  241. * @num : current sink number
  242. * @iout_code : current output value (Addr 9Ah ~ 9Bh)
  243. * @pwm_code : PWM code value (Addr 9Ch ~ 9Eh)
  244. */
  245. struct lp8788_vib_platform_data {
  246. char *name;
  247. enum lp8788_isink_scale scale;
  248. enum lp8788_isink_number num;
  249. int iout_code;
  250. int pwm_code;
  251. };
  252. /*
  253. * struct lp8788_platform_data
  254. * @init_func : used for initializing registers
  255. * before mfd driver is registered
  256. * @buck_data : regulator initial data for buck
  257. * @dldo_data : regulator initial data for digital ldo
  258. * @aldo_data : regulator initial data for analog ldo
  259. * @buck1_dvs : gpio configurations for buck1 dvs
  260. * @buck2_dvs : gpio configurations for buck2 dvs
  261. * @ldo_pin : gpio configurations for enabling LDOs
  262. * @chg_pdata : platform data for charger driver
  263. * @alarm_sel : rtc alarm selection (1 or 2)
  264. * @bl_pdata : configurable data for backlight driver
  265. * @led_pdata : configurable data for led driver
  266. * @vib_pdata : configurable data for vibrator driver
  267. * @adc_pdata : iio map data for adc driver
  268. */
  269. struct lp8788_platform_data {
  270. /* general system information */
  271. int (*init_func) (struct lp8788 *lp);
  272. /* regulators */
  273. struct regulator_init_data *buck_data[LP8788_NUM_BUCKS];
  274. struct regulator_init_data *dldo_data[LP8788_NUM_DLDOS];
  275. struct regulator_init_data *aldo_data[LP8788_NUM_ALDOS];
  276. struct lp8788_buck1_dvs *buck1_dvs;
  277. struct lp8788_buck2_dvs *buck2_dvs;
  278. struct lp8788_ldo_enable_pin *ldo_pin[EN_LDOS_MAX];
  279. /* charger */
  280. struct lp8788_charger_platform_data *chg_pdata;
  281. /* rtc alarm */
  282. enum lp8788_alarm_sel alarm_sel;
  283. /* backlight */
  284. struct lp8788_backlight_platform_data *bl_pdata;
  285. /* current sinks */
  286. struct lp8788_led_platform_data *led_pdata;
  287. struct lp8788_vib_platform_data *vib_pdata;
  288. /* adc iio map data */
  289. struct iio_map *adc_pdata;
  290. };
  291. /*
  292. * struct lp8788
  293. * @dev : parent device pointer
  294. * @regmap : used for i2c communcation on accessing registers
  295. * @irqdm : interrupt domain for handling nested interrupt
  296. * @irq : pin number of IRQ_N
  297. * @pdata : lp8788 platform specific data
  298. */
  299. struct lp8788 {
  300. struct device *dev;
  301. struct regmap *regmap;
  302. struct irq_domain *irqdm;
  303. int irq;
  304. struct lp8788_platform_data *pdata;
  305. };
  306. int lp8788_irq_init(struct lp8788 *lp, int chip_irq);
  307. void lp8788_irq_exit(struct lp8788 *lp);
  308. int lp8788_read_byte(struct lp8788 *lp, u8 reg, u8 *data);
  309. int lp8788_read_multi_bytes(struct lp8788 *lp, u8 reg, u8 *data, size_t count);
  310. int lp8788_write_byte(struct lp8788 *lp, u8 reg, u8 data);
  311. int lp8788_update_bits(struct lp8788 *lp, u8 reg, u8 mask, u8 data);
  312. #endif