blob: 24b65d081b69ffd7b6a0f21003505f4aad9df406 [file] [log] [blame]
Peter Ujfalusia53b8e32011-06-04 08:16:41 +03001#ifndef __OMAP_PMIC_COMMON__
2#define __OMAP_PMIC_COMMON__
3
Tony Lindgren7d7e1eb2012-08-27 17:43:01 -07004#include "common.h"
Kevin Hilman46232a32011-11-23 14:43:01 -08005
Peter Ujfalusib22f9542011-06-07 10:26:46 +03006#define TWL_COMMON_PDATA_USB (1 << 0)
Peter Ujfalusi827ed9a2011-06-07 10:28:54 +03007#define TWL_COMMON_PDATA_BCI (1 << 1)
8#define TWL_COMMON_PDATA_MADC (1 << 2)
9#define TWL_COMMON_PDATA_AUDIO (1 << 3)
Peter Ujfalusib22f9542011-06-07 10:26:46 +030010
11/* Common LDO regulators for TWL4030/TWL6030 */
12#define TWL_COMMON_REGULATOR_VDAC (1 << 0)
13#define TWL_COMMON_REGULATOR_VAUX1 (1 << 1)
14#define TWL_COMMON_REGULATOR_VAUX2 (1 << 2)
15#define TWL_COMMON_REGULATOR_VAUX3 (1 << 3)
16
17/* TWL6030 LDO regulators */
18#define TWL_COMMON_REGULATOR_VMMC (1 << 4)
19#define TWL_COMMON_REGULATOR_VPP (1 << 5)
20#define TWL_COMMON_REGULATOR_VUSIM (1 << 6)
21#define TWL_COMMON_REGULATOR_VANA (1 << 7)
22#define TWL_COMMON_REGULATOR_VCXIO (1 << 8)
23#define TWL_COMMON_REGULATOR_VUSB (1 << 9)
24#define TWL_COMMON_REGULATOR_CLK32KG (1 << 10)
Peter Ujfalusifde01902012-05-09 14:19:16 -070025#define TWL_COMMON_REGULATOR_V1V8 (1 << 11)
26#define TWL_COMMON_REGULATOR_V2V1 (1 << 12)
Peter Ujfalusib22f9542011-06-07 10:26:46 +030027
Peter Ujfalusib252b0ef2011-06-07 11:38:24 +030028/* TWL4030 LDO regulators */
29#define TWL_COMMON_REGULATOR_VPLL1 (1 << 4)
30#define TWL_COMMON_REGULATOR_VPLL2 (1 << 5)
31
32
Peter Ujfalusia53b8e32011-06-04 08:16:41 +030033struct twl4030_platform_data;
Peter Ujfalusi8eaeb932012-04-03 11:56:51 +030034struct twl6040_platform_data;
Peter Ujfalusi40234bf2012-12-05 14:45:23 +010035struct omap_tw4030_pdata;
Peter Ujfalusi9495d1e2012-09-24 12:24:48 +030036struct i2c_board_info;
Peter Ujfalusia53b8e32011-06-04 08:16:41 +030037
38void omap_pmic_init(int bus, u32 clkrate, const char *pmic_type, int pmic_irq,
39 struct twl4030_platform_data *pmic_data);
Kevin Hilman46232a32011-11-23 14:43:01 -080040void omap_pmic_late_init(void);
Peter Ujfalusia53b8e32011-06-04 08:16:41 +030041
42static inline void omap2_pmic_init(const char *pmic_type,
43 struct twl4030_platform_data *pmic_data)
44{
Tony Lindgren7d7e1eb2012-08-27 17:43:01 -070045 omap_pmic_init(2, 2600, pmic_type, 7 + OMAP_INTC_START, pmic_data);
Peter Ujfalusia53b8e32011-06-04 08:16:41 +030046}
47
48static inline void omap3_pmic_init(const char *pmic_type,
49 struct twl4030_platform_data *pmic_data)
50{
Tony Lindgren7d7e1eb2012-08-27 17:43:01 -070051 omap_pmic_init(1, 2600, pmic_type, 7 + OMAP_INTC_START, pmic_data);
Peter Ujfalusia53b8e32011-06-04 08:16:41 +030052}
53
Peter Ujfalusi8eaeb932012-04-03 11:56:51 +030054void omap4_pmic_init(const char *pmic_type,
55 struct twl4030_platform_data *pmic_data,
Peter Ujfalusi9495d1e2012-09-24 12:24:48 +030056 struct i2c_board_info *devices, int nr_devices);
Peter Ujfalusia53b8e32011-06-04 08:16:41 +030057
Peter Ujfalusi827ed9a2011-06-07 10:28:54 +030058void omap3_pmic_get_config(struct twl4030_platform_data *pmic_data,
59 u32 pdata_flags, u32 regulators_flags);
60
Peter Ujfalusib22f9542011-06-07 10:26:46 +030061void omap4_pmic_get_config(struct twl4030_platform_data *pmic_data,
62 u32 pdata_flags, u32 regulators_flags);
63
Peter Ujfalusi40234bf2012-12-05 14:45:23 +010064void omap_twl4030_audio_init(char *card_name, struct omap_tw4030_pdata *pdata);
Peter Ujfalusi552d9dc2012-08-14 12:07:57 +030065
Peter Ujfalusia53b8e32011-06-04 08:16:41 +030066#endif /* __OMAP_PMIC_COMMON__ */