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