xref: /OK3568_Linux_fs/kernel/include/linux/mfd/tps6507x.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* linux/mfd/tps6507x.h
2*4882a593Smuzhiyun  *
3*4882a593Smuzhiyun  * Functions to access TPS65070 power management chip.
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * Copyright (c) 2009 RidgeRun (todd.fischer@ridgerun.com)
6*4882a593Smuzhiyun  *
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  *  For licencing details see kernel-base/COPYING
9*4882a593Smuzhiyun  */
10*4882a593Smuzhiyun 
11*4882a593Smuzhiyun #ifndef __LINUX_MFD_TPS6507X_H
12*4882a593Smuzhiyun #define __LINUX_MFD_TPS6507X_H
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun /*
15*4882a593Smuzhiyun  * ----------------------------------------------------------------------------
16*4882a593Smuzhiyun  * Registers, all 8 bits
17*4882a593Smuzhiyun  * ----------------------------------------------------------------------------
18*4882a593Smuzhiyun  */
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun 
21*4882a593Smuzhiyun /* Register definitions */
22*4882a593Smuzhiyun #define	TPS6507X_REG_PPATH1			0X01
23*4882a593Smuzhiyun #define	TPS6507X_CHG_USB			BIT(7)
24*4882a593Smuzhiyun #define	TPS6507X_CHG_AC				BIT(6)
25*4882a593Smuzhiyun #define	TPS6507X_CHG_USB_PW_ENABLE		BIT(5)
26*4882a593Smuzhiyun #define	TPS6507X_CHG_AC_PW_ENABLE		BIT(4)
27*4882a593Smuzhiyun #define	TPS6507X_CHG_AC_CURRENT			BIT(2)
28*4882a593Smuzhiyun #define	TPS6507X_CHG_USB_CURRENT		BIT(0)
29*4882a593Smuzhiyun 
30*4882a593Smuzhiyun #define	TPS6507X_REG_INT			0X02
31*4882a593Smuzhiyun #define	TPS6507X_REG_MASK_AC_USB		BIT(7)
32*4882a593Smuzhiyun #define	TPS6507X_REG_MASK_TSC			BIT(6)
33*4882a593Smuzhiyun #define	TPS6507X_REG_MASK_PB_IN			BIT(5)
34*4882a593Smuzhiyun #define	TPS6507X_REG_TSC_INT			BIT(3)
35*4882a593Smuzhiyun #define	TPS6507X_REG_PB_IN_INT			BIT(2)
36*4882a593Smuzhiyun #define	TPS6507X_REG_AC_USB_APPLIED		BIT(1)
37*4882a593Smuzhiyun #define	TPS6507X_REG_AC_USB_REMOVED		BIT(0)
38*4882a593Smuzhiyun 
39*4882a593Smuzhiyun #define	TPS6507X_REG_CHGCONFIG0			0X03
40*4882a593Smuzhiyun 
41*4882a593Smuzhiyun #define	TPS6507X_REG_CHGCONFIG1			0X04
42*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_DCDC1_ENABLE		BIT(4)
43*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_DCDC2_ENABLE		BIT(3)
44*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_DCDC3_ENABLE		BIT(2)
45*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_LDO1_ENABLE		BIT(1)
46*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_LDO2_ENABLE		BIT(0)
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun #define	TPS6507X_REG_CHGCONFIG2			0X05
49*4882a593Smuzhiyun 
50*4882a593Smuzhiyun #define	TPS6507X_REG_CHGCONFIG3			0X06
51*4882a593Smuzhiyun 
52*4882a593Smuzhiyun #define	TPS6507X_REG_ADCONFIG			0X07
53*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_AD_ENABLE		BIT(7)
54*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_START_CONVERSION	BIT(6)
55*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_CONVERSION_DONE	BIT(5)
56*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_VREF_ENABLE		BIT(4)
57*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_AD_IN1		0
58*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_AD_IN2		1
59*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_AD_IN3		2
60*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_AD_IN4		3
61*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_TS_PIN		4
62*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_BAT_CURRENT	5
63*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_AC_VOLTAGE	6
64*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_SYS_VOLTAGE	7
65*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_CHARGER_VOLTAGE 8
66*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_BAT_VOLTAGE	9
67*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_THRESHOLD_VOLTAGE 10
68*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_ISET1_VOLTAGE	11
69*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_ISET2_VOLTAGE	12
70*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_REAL_TSC	14
71*4882a593Smuzhiyun #define	TPS6507X_ADCONFIG_INPUT_TSC		15
72*4882a593Smuzhiyun 
73*4882a593Smuzhiyun #define	TPS6507X_REG_TSCMODE			0X08
74*4882a593Smuzhiyun #define	TPS6507X_TSCMODE_X_POSITION		0
75*4882a593Smuzhiyun #define	TPS6507X_TSCMODE_Y_POSITION		1
76*4882a593Smuzhiyun #define	TPS6507X_TSCMODE_PRESSURE		2
77*4882a593Smuzhiyun #define	TPS6507X_TSCMODE_X_PLATE		3
78*4882a593Smuzhiyun #define	TPS6507X_TSCMODE_Y_PLATE		4
79*4882a593Smuzhiyun #define	TPS6507X_TSCMODE_STANDBY		5
80*4882a593Smuzhiyun #define	TPS6507X_TSCMODE_ADC_INPUT		6
81*4882a593Smuzhiyun #define	TPS6507X_TSCMODE_DISABLE		7
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun #define	TPS6507X_REG_ADRESULT_1			0X09
84*4882a593Smuzhiyun 
85*4882a593Smuzhiyun #define	TPS6507X_REG_ADRESULT_2			0X0A
86*4882a593Smuzhiyun #define	TPS6507X_REG_ADRESULT_2_MASK		(BIT(1) | BIT(0))
87*4882a593Smuzhiyun 
88*4882a593Smuzhiyun #define	TPS6507X_REG_PGOOD			0X0B
89*4882a593Smuzhiyun 
90*4882a593Smuzhiyun #define	TPS6507X_REG_PGOODMASK			0X0C
91*4882a593Smuzhiyun 
92*4882a593Smuzhiyun #define	TPS6507X_REG_CON_CTRL1			0X0D
93*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_DCDC1_ENABLE		BIT(4)
94*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_DCDC2_ENABLE		BIT(3)
95*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_DCDC3_ENABLE		BIT(2)
96*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_LDO1_ENABLE		BIT(1)
97*4882a593Smuzhiyun #define	TPS6507X_CON_CTRL1_LDO2_ENABLE		BIT(0)
98*4882a593Smuzhiyun 
99*4882a593Smuzhiyun #define	TPS6507X_REG_CON_CTRL2			0X0E
100*4882a593Smuzhiyun 
101*4882a593Smuzhiyun #define	TPS6507X_REG_CON_CTRL3			0X0F
102*4882a593Smuzhiyun 
103*4882a593Smuzhiyun #define	TPS6507X_REG_DEFDCDC1			0X10
104*4882a593Smuzhiyun #define TPS6507X_DEFDCDC1_DCDC1_EXT_ADJ_EN	BIT(7)
105*4882a593Smuzhiyun #define TPS6507X_DEFDCDC1_DCDC1_MASK		0X3F
106*4882a593Smuzhiyun 
107*4882a593Smuzhiyun #define	TPS6507X_REG_DEFDCDC2_LOW		0X11
108*4882a593Smuzhiyun #define TPS6507X_DEFDCDC2_LOW_DCDC2_MASK	0X3F
109*4882a593Smuzhiyun 
110*4882a593Smuzhiyun #define	TPS6507X_REG_DEFDCDC2_HIGH		0X12
111*4882a593Smuzhiyun #define TPS6507X_DEFDCDC2_HIGH_DCDC2_MASK	0X3F
112*4882a593Smuzhiyun 
113*4882a593Smuzhiyun #define	TPS6507X_REG_DEFDCDC3_LOW		0X13
114*4882a593Smuzhiyun #define TPS6507X_DEFDCDC3_LOW_DCDC3_MASK	0X3F
115*4882a593Smuzhiyun 
116*4882a593Smuzhiyun #define	TPS6507X_REG_DEFDCDC3_HIGH		0X14
117*4882a593Smuzhiyun #define TPS6507X_DEFDCDC3_HIGH_DCDC3_MASK	0X3F
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun #define	TPS6507X_REG_DEFSLEW			0X15
120*4882a593Smuzhiyun 
121*4882a593Smuzhiyun #define	TPS6507X_REG_LDO_CTRL1			0X16
122*4882a593Smuzhiyun #define TPS6507X_REG_LDO_CTRL1_LDO1_MASK	0X0F
123*4882a593Smuzhiyun 
124*4882a593Smuzhiyun #define	TPS6507X_REG_DEFLDO2			0X17
125*4882a593Smuzhiyun #define TPS6507X_REG_DEFLDO2_LDO2_MASK		0X3F
126*4882a593Smuzhiyun 
127*4882a593Smuzhiyun #define	TPS6507X_REG_WLED_CTRL1			0X18
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun #define	TPS6507X_REG_WLED_CTRL2			0X19
130*4882a593Smuzhiyun 
131*4882a593Smuzhiyun /* VDCDC MASK */
132*4882a593Smuzhiyun #define TPS6507X_DEFDCDCX_DCDC_MASK		0X3F
133*4882a593Smuzhiyun 
134*4882a593Smuzhiyun #define TPS6507X_MAX_REGISTER			0X19
135*4882a593Smuzhiyun 
136*4882a593Smuzhiyun /**
137*4882a593Smuzhiyun  * struct tps6507x_board - packages regulator and touchscreen init data
138*4882a593Smuzhiyun  * @tps6507x_regulator_data: regulator initialization values
139*4882a593Smuzhiyun  *
140*4882a593Smuzhiyun  * Board data may be used to initialize regulator and touchscreen.
141*4882a593Smuzhiyun  */
142*4882a593Smuzhiyun 
143*4882a593Smuzhiyun struct tps6507x_board {
144*4882a593Smuzhiyun 	struct regulator_init_data *tps6507x_pmic_init_data;
145*4882a593Smuzhiyun 	struct touchscreen_init_data *tps6507x_ts_init_data;
146*4882a593Smuzhiyun };
147*4882a593Smuzhiyun 
148*4882a593Smuzhiyun /**
149*4882a593Smuzhiyun  * struct tps6507x_dev - tps6507x sub-driver chip access routines
150*4882a593Smuzhiyun  * @read_dev() - I2C register read function
151*4882a593Smuzhiyun  * @write_dev() - I2C register write function
152*4882a593Smuzhiyun  *
153*4882a593Smuzhiyun  * Device data may be used to access the TPS6507x chip
154*4882a593Smuzhiyun  */
155*4882a593Smuzhiyun 
156*4882a593Smuzhiyun struct tps6507x_dev {
157*4882a593Smuzhiyun 	struct device *dev;
158*4882a593Smuzhiyun 	struct i2c_client *i2c_client;
159*4882a593Smuzhiyun 	int (*read_dev)(struct tps6507x_dev *tps6507x, char reg, int size,
160*4882a593Smuzhiyun 			void *dest);
161*4882a593Smuzhiyun 	int (*write_dev)(struct tps6507x_dev *tps6507x, char reg, int size,
162*4882a593Smuzhiyun 			 void *src);
163*4882a593Smuzhiyun 
164*4882a593Smuzhiyun 	/* Client devices */
165*4882a593Smuzhiyun 	struct tps6507x_pmic *pmic;
166*4882a593Smuzhiyun };
167*4882a593Smuzhiyun 
168*4882a593Smuzhiyun #endif /*  __LINUX_MFD_TPS6507X_H */
169