xref: /OK3568_Linux_fs/kernel/include/linux/mfd/tps65010.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* linux/mfd/tps65010.h
2*4882a593Smuzhiyun  *
3*4882a593Smuzhiyun  * Functions to access TPS65010 power management device.
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * Copyright (C) 2004 Dirk Behme <dirk.behme@de.bosch.com>
6*4882a593Smuzhiyun  *
7*4882a593Smuzhiyun  * This program is free software; you can redistribute it and/or modify it
8*4882a593Smuzhiyun  * under the terms of the GNU General Public License as published by the
9*4882a593Smuzhiyun  * Free Software Foundation; either version 2 of the License, or (at your
10*4882a593Smuzhiyun  * option) any later version.
11*4882a593Smuzhiyun  *
12*4882a593Smuzhiyun  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
13*4882a593Smuzhiyun  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
14*4882a593Smuzhiyun  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN
15*4882a593Smuzhiyun  * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
16*4882a593Smuzhiyun  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
17*4882a593Smuzhiyun  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
18*4882a593Smuzhiyun  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
19*4882a593Smuzhiyun  * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
20*4882a593Smuzhiyun  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
21*4882a593Smuzhiyun  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
22*4882a593Smuzhiyun  *
23*4882a593Smuzhiyun  * You should have received a copy of the  GNU General Public License along
24*4882a593Smuzhiyun  * with this program; if not, write  to the Free Software Foundation, Inc.,
25*4882a593Smuzhiyun  * 675 Mass Ave, Cambridge, MA 02139, USA.
26*4882a593Smuzhiyun  */
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun #ifndef __LINUX_I2C_TPS65010_H
29*4882a593Smuzhiyun #define __LINUX_I2C_TPS65010_H
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun /*
32*4882a593Smuzhiyun  * ----------------------------------------------------------------------------
33*4882a593Smuzhiyun  * Registers, all 8 bits
34*4882a593Smuzhiyun  * ----------------------------------------------------------------------------
35*4882a593Smuzhiyun  */
36*4882a593Smuzhiyun 
37*4882a593Smuzhiyun #define	TPS_CHGSTATUS		0x01
38*4882a593Smuzhiyun #	define	TPS_CHG_USB		(1 << 7)
39*4882a593Smuzhiyun #	define	TPS_CHG_AC		(1 << 6)
40*4882a593Smuzhiyun #	define	TPS_CHG_THERM		(1 << 5)
41*4882a593Smuzhiyun #	define	TPS_CHG_TERM		(1 << 4)
42*4882a593Smuzhiyun #	define	TPS_CHG_TAPER_TMO	(1 << 3)
43*4882a593Smuzhiyun #	define	TPS_CHG_CHG_TMO		(1 << 2)
44*4882a593Smuzhiyun #	define	TPS_CHG_PRECHG_TMO	(1 << 1)
45*4882a593Smuzhiyun #	define	TPS_CHG_TEMP_ERR	(1 << 0)
46*4882a593Smuzhiyun #define	TPS_REGSTATUS		0x02
47*4882a593Smuzhiyun #	define	TPS_REG_ONOFF		(1 << 7)
48*4882a593Smuzhiyun #	define	TPS_REG_COVER		(1 << 6)
49*4882a593Smuzhiyun #	define	TPS_REG_UVLO		(1 << 5)
50*4882a593Smuzhiyun #	define	TPS_REG_NO_CHG		(1 << 4)	/* tps65013 */
51*4882a593Smuzhiyun #	define	TPS_REG_PG_LD02		(1 << 3)
52*4882a593Smuzhiyun #	define	TPS_REG_PG_LD01		(1 << 2)
53*4882a593Smuzhiyun #	define	TPS_REG_PG_MAIN		(1 << 1)
54*4882a593Smuzhiyun #	define	TPS_REG_PG_CORE		(1 << 0)
55*4882a593Smuzhiyun #define	TPS_MASK1		0x03
56*4882a593Smuzhiyun #define	TPS_MASK2		0x04
57*4882a593Smuzhiyun #define	TPS_ACKINT1		0x05
58*4882a593Smuzhiyun #define	TPS_ACKINT2		0x06
59*4882a593Smuzhiyun #define	TPS_CHGCONFIG		0x07
60*4882a593Smuzhiyun #	define	TPS_CHARGE_POR		(1 << 7)	/* 65010/65012 */
61*4882a593Smuzhiyun #	define	TPS65013_AUA		(1 << 7)	/* 65011/65013 */
62*4882a593Smuzhiyun #	define	TPS_CHARGE_RESET	(1 << 6)
63*4882a593Smuzhiyun #	define	TPS_CHARGE_FAST		(1 << 5)
64*4882a593Smuzhiyun #	define	TPS_CHARGE_CURRENT	(3 << 3)
65*4882a593Smuzhiyun #	define	TPS_VBUS_500MA		(1 << 2)
66*4882a593Smuzhiyun #	define	TPS_VBUS_CHARGING	(1 << 1)
67*4882a593Smuzhiyun #	define	TPS_CHARGE_ENABLE	(1 << 0)
68*4882a593Smuzhiyun #define	TPS_LED1_ON		0x08
69*4882a593Smuzhiyun #define	TPS_LED1_PER		0x09
70*4882a593Smuzhiyun #define	TPS_LED2_ON		0x0a
71*4882a593Smuzhiyun #define	TPS_LED2_PER		0x0b
72*4882a593Smuzhiyun #define	TPS_VDCDC1		0x0c
73*4882a593Smuzhiyun #	define	TPS_ENABLE_LP		(1 << 3)
74*4882a593Smuzhiyun #define	TPS_VDCDC2		0x0d
75*4882a593Smuzhiyun #	define	TPS_LP_COREOFF	(1 << 7)
76*4882a593Smuzhiyun #	define 	TPS_VCORE_1_8V	(7<<4)
77*4882a593Smuzhiyun #	define 	TPS_VCORE_1_5V	(6 << 4)
78*4882a593Smuzhiyun #	define 	TPS_VCORE_1_4V	(5 << 4)
79*4882a593Smuzhiyun #	define 	TPS_VCORE_1_3V	(4 << 4)
80*4882a593Smuzhiyun #	define 	TPS_VCORE_1_2V	(3 << 4)
81*4882a593Smuzhiyun #	define 	TPS_VCORE_1_1V	(2 << 4)
82*4882a593Smuzhiyun #	define 	TPS_VCORE_1_0V	(1 << 4)
83*4882a593Smuzhiyun #	define 	TPS_VCORE_0_85V	(0 << 4)
84*4882a593Smuzhiyun #	define	TPS_VCORE_LP_1_2V (3 << 2)
85*4882a593Smuzhiyun #	define	TPS_VCORE_LP_1_1V (2 << 2)
86*4882a593Smuzhiyun #	define	TPS_VCORE_LP_1_0V (1 << 2)
87*4882a593Smuzhiyun #	define	TPS_VCORE_LP_0_85V (0 << 2)
88*4882a593Smuzhiyun #	define	TPS_VIB		(1 << 1)
89*4882a593Smuzhiyun #	define	TPS_VCORE_DISCH	(1 << 0)
90*4882a593Smuzhiyun #define	TPS_VREGS1		0x0e
91*4882a593Smuzhiyun #	define	TPS_LDO2_ENABLE	(1 << 7)
92*4882a593Smuzhiyun #	define	TPS_LDO2_OFF	(1 << 6)
93*4882a593Smuzhiyun #	define	TPS_VLDO2_3_0V	(3 << 4)
94*4882a593Smuzhiyun #	define	TPS_VLDO2_2_75V	(2 << 4)
95*4882a593Smuzhiyun #	define	TPS_VLDO2_2_5V	(1 << 4)
96*4882a593Smuzhiyun #	define	TPS_VLDO2_1_8V	(0 << 4)
97*4882a593Smuzhiyun #	define	TPS_LDO1_ENABLE	(1 << 3)
98*4882a593Smuzhiyun #	define	TPS_LDO1_OFF	(1 << 2)
99*4882a593Smuzhiyun #	define	TPS_VLDO1_3_0V	(3 << 0)
100*4882a593Smuzhiyun #	define	TPS_VLDO1_2_75V	(2 << 0)
101*4882a593Smuzhiyun #	define	TPS_VLDO1_2_5V	(1 << 0)
102*4882a593Smuzhiyun #	define	TPS_VLDO1_ADJ	(0 << 0)
103*4882a593Smuzhiyun #define	TPS_MASK3		0x0f
104*4882a593Smuzhiyun #define	TPS_DEFGPIO		0x10
105*4882a593Smuzhiyun 
106*4882a593Smuzhiyun /*
107*4882a593Smuzhiyun  * ----------------------------------------------------------------------------
108*4882a593Smuzhiyun  * Macros used by exported functions
109*4882a593Smuzhiyun  * ----------------------------------------------------------------------------
110*4882a593Smuzhiyun  */
111*4882a593Smuzhiyun 
112*4882a593Smuzhiyun #define LED1  1
113*4882a593Smuzhiyun #define LED2  2
114*4882a593Smuzhiyun #define OFF   0
115*4882a593Smuzhiyun #define ON    1
116*4882a593Smuzhiyun #define BLINK 2
117*4882a593Smuzhiyun #define GPIO1 1
118*4882a593Smuzhiyun #define GPIO2 2
119*4882a593Smuzhiyun #define GPIO3 3
120*4882a593Smuzhiyun #define GPIO4 4
121*4882a593Smuzhiyun #define LOW   0
122*4882a593Smuzhiyun #define HIGH  1
123*4882a593Smuzhiyun 
124*4882a593Smuzhiyun /*
125*4882a593Smuzhiyun  * ----------------------------------------------------------------------------
126*4882a593Smuzhiyun  * Exported functions
127*4882a593Smuzhiyun  * ----------------------------------------------------------------------------
128*4882a593Smuzhiyun  */
129*4882a593Smuzhiyun 
130*4882a593Smuzhiyun /* Draw from VBUS:
131*4882a593Smuzhiyun  *   0 mA -- DON'T DRAW (might supply power instead)
132*4882a593Smuzhiyun  * 100 mA -- usb unit load (slowest charge rate)
133*4882a593Smuzhiyun  * 500 mA -- usb high power (fast battery charge)
134*4882a593Smuzhiyun  */
135*4882a593Smuzhiyun extern int tps65010_set_vbus_draw(unsigned mA);
136*4882a593Smuzhiyun 
137*4882a593Smuzhiyun /* tps65010_set_gpio_out_value parameter:
138*4882a593Smuzhiyun  * gpio:  GPIO1, GPIO2, GPIO3 or GPIO4
139*4882a593Smuzhiyun  * value: LOW or HIGH
140*4882a593Smuzhiyun  */
141*4882a593Smuzhiyun extern int tps65010_set_gpio_out_value(unsigned gpio, unsigned value);
142*4882a593Smuzhiyun 
143*4882a593Smuzhiyun /* tps65010_set_led parameter:
144*4882a593Smuzhiyun  * led:  LED1 or LED2
145*4882a593Smuzhiyun  * mode: ON, OFF or BLINK
146*4882a593Smuzhiyun  */
147*4882a593Smuzhiyun extern int tps65010_set_led(unsigned led, unsigned mode);
148*4882a593Smuzhiyun 
149*4882a593Smuzhiyun /* tps65010_set_vib parameter:
150*4882a593Smuzhiyun  * value: ON or OFF
151*4882a593Smuzhiyun  */
152*4882a593Smuzhiyun extern int tps65010_set_vib(unsigned value);
153*4882a593Smuzhiyun 
154*4882a593Smuzhiyun /* tps65010_set_low_pwr parameter:
155*4882a593Smuzhiyun  * mode: ON or OFF
156*4882a593Smuzhiyun  */
157*4882a593Smuzhiyun extern int tps65010_set_low_pwr(unsigned mode);
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun /* tps65010_config_vregs1 parameter:
160*4882a593Smuzhiyun  * value to be written to VREGS1 register
161*4882a593Smuzhiyun  * Note: The complete register is written, set all bits you need
162*4882a593Smuzhiyun  */
163*4882a593Smuzhiyun extern int tps65010_config_vregs1(unsigned value);
164*4882a593Smuzhiyun 
165*4882a593Smuzhiyun /* tps65013_set_low_pwr parameter:
166*4882a593Smuzhiyun  * mode: ON or OFF
167*4882a593Smuzhiyun  */
168*4882a593Smuzhiyun extern int tps65013_set_low_pwr(unsigned mode);
169*4882a593Smuzhiyun 
170*4882a593Smuzhiyun /* tps65010_set_vdcdc2
171*4882a593Smuzhiyun  *  value to be written to VDCDC2
172*4882a593Smuzhiyun  */
173*4882a593Smuzhiyun extern int tps65010_config_vdcdc2(unsigned value);
174*4882a593Smuzhiyun 
175*4882a593Smuzhiyun struct i2c_client;
176*4882a593Smuzhiyun 
177*4882a593Smuzhiyun /**
178*4882a593Smuzhiyun  * struct tps65010_board - packages GPIO and LED lines
179*4882a593Smuzhiyun  * @base: the GPIO number to assign to GPIO-1
180*4882a593Smuzhiyun  * @outmask: bit (N-1) is set to allow GPIO-N to be used as an
181*4882a593Smuzhiyun  *	(open drain) output
182*4882a593Smuzhiyun  * @setup: optional callback issued once the GPIOs are valid
183*4882a593Smuzhiyun  * @teardown: optional callback issued before the GPIOs are invalidated
184*4882a593Smuzhiyun  * @context: optional parameter passed to setup() and teardown()
185*4882a593Smuzhiyun  *
186*4882a593Smuzhiyun  * Board data may be used to package the GPIO (and LED) lines for use
187*4882a593Smuzhiyun  * in by the generic GPIO and LED frameworks.  The first four GPIOs
188*4882a593Smuzhiyun  * starting at gpio_base are GPIO1..GPIO4.  The next two are LED1/nPG
189*4882a593Smuzhiyun  * and LED2 (with hardware blinking capability, not currently exposed).
190*4882a593Smuzhiyun  *
191*4882a593Smuzhiyun  * The @setup callback may be used with the kind of board-specific glue
192*4882a593Smuzhiyun  * which hands the (now-valid) GPIOs to other drivers, or which puts
193*4882a593Smuzhiyun  * devices in their initial states using these GPIOs.
194*4882a593Smuzhiyun  */
195*4882a593Smuzhiyun struct tps65010_board {
196*4882a593Smuzhiyun 	int				base;
197*4882a593Smuzhiyun 	unsigned			outmask;
198*4882a593Smuzhiyun 
199*4882a593Smuzhiyun 	int		(*setup)(struct i2c_client *client, void *context);
200*4882a593Smuzhiyun 	int		(*teardown)(struct i2c_client *client, void *context);
201*4882a593Smuzhiyun 	void		*context;
202*4882a593Smuzhiyun };
203*4882a593Smuzhiyun 
204*4882a593Smuzhiyun #endif /*  __LINUX_I2C_TPS65010_H */
205*4882a593Smuzhiyun 
206