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