/* linux/mfd/tps65010.h * * Functions to access TPS65010 power management device. * * Copyright (C) 2004 Dirk Behme <[email protected]> * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2 of the License, or (at your * option) any later version. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef __LINUX_I2C_TPS65010_H #define __LINUX_I2C_TPS65010_H struct gpio_chip; /* * ---------------------------------------------------------------------------- * Registers, all 8 bits * ---------------------------------------------------------------------------- */ #define TPS_CHGSTATUS … #define TPS_CHG_USB … #define TPS_CHG_AC … #define TPS_CHG_THERM … #define TPS_CHG_TERM … #define TPS_CHG_TAPER_TMO … #define TPS_CHG_CHG_TMO … #define TPS_CHG_PRECHG_TMO … #define TPS_CHG_TEMP_ERR … #define TPS_REGSTATUS … #define TPS_REG_ONOFF … #define TPS_REG_COVER … #define TPS_REG_UVLO … #define TPS_REG_NO_CHG … #define TPS_REG_PG_LD02 … #define TPS_REG_PG_LD01 … #define TPS_REG_PG_MAIN … #define TPS_REG_PG_CORE … #define TPS_MASK1 … #define TPS_MASK2 … #define TPS_ACKINT1 … #define TPS_ACKINT2 … #define TPS_CHGCONFIG … #define TPS_CHARGE_POR … #define TPS65013_AUA … #define TPS_CHARGE_RESET … #define TPS_CHARGE_FAST … #define TPS_CHARGE_CURRENT … #define TPS_VBUS_500MA … #define TPS_VBUS_CHARGING … #define TPS_CHARGE_ENABLE … #define TPS_LED1_ON … #define TPS_LED1_PER … #define TPS_LED2_ON … #define TPS_LED2_PER … #define TPS_VDCDC1 … #define TPS_ENABLE_LP … #define TPS_VDCDC2 … #define TPS_LP_COREOFF … #define TPS_VCORE_1_8V … #define TPS_VCORE_1_5V … #define TPS_VCORE_1_4V … #define TPS_VCORE_1_3V … #define TPS_VCORE_1_2V … #define TPS_VCORE_1_1V … #define TPS_VCORE_1_0V … #define TPS_VCORE_0_85V … #define TPS_VCORE_LP_1_2V … #define TPS_VCORE_LP_1_1V … #define TPS_VCORE_LP_1_0V … #define TPS_VCORE_LP_0_85V … #define TPS_VIB … #define TPS_VCORE_DISCH … #define TPS_VREGS1 … #define TPS_LDO2_ENABLE … #define TPS_LDO2_OFF … #define TPS_VLDO2_3_0V … #define TPS_VLDO2_2_75V … #define TPS_VLDO2_2_5V … #define TPS_VLDO2_1_8V … #define TPS_LDO1_ENABLE … #define TPS_LDO1_OFF … #define TPS_VLDO1_3_0V … #define TPS_VLDO1_2_75V … #define TPS_VLDO1_2_5V … #define TPS_VLDO1_ADJ … #define TPS_MASK3 … #define TPS_DEFGPIO … /* * ---------------------------------------------------------------------------- * Macros used by exported functions * ---------------------------------------------------------------------------- */ #define LED1 … #define LED2 … #define OFF … #define ON … #define BLINK … #define GPIO1 … #define GPIO2 … #define GPIO3 … #define GPIO4 … #define LOW … #define HIGH … /* * ---------------------------------------------------------------------------- * Exported functions * ---------------------------------------------------------------------------- */ /* Draw from VBUS: * 0 mA -- DON'T DRAW (might supply power instead) * 100 mA -- usb unit load (slowest charge rate) * 500 mA -- usb high power (fast battery charge) */ extern int tps65010_set_vbus_draw(unsigned mA); /* tps65010_set_gpio_out_value parameter: * gpio: GPIO1, GPIO2, GPIO3 or GPIO4 * value: LOW or HIGH */ extern int tps65010_set_gpio_out_value(unsigned gpio, unsigned value); /* tps65010_set_led parameter: * led: LED1 or LED2 * mode: ON, OFF or BLINK */ extern int tps65010_set_led(unsigned led, unsigned mode); /* tps65010_set_vib parameter: * value: ON or OFF */ extern int tps65010_set_vib(unsigned value); /* tps65010_set_low_pwr parameter: * mode: ON or OFF */ extern int tps65010_set_low_pwr(unsigned mode); /* tps65010_config_vregs1 parameter: * value to be written to VREGS1 register * Note: The complete register is written, set all bits you need */ extern int tps65010_config_vregs1(unsigned value); /* tps65013_set_low_pwr parameter: * mode: ON or OFF */ extern int tps65013_set_low_pwr(unsigned mode); /* tps65010_set_vdcdc2 * value to be written to VDCDC2 */ extern int tps65010_config_vdcdc2(unsigned value); struct i2c_client; /** * struct tps65010_board - packages GPIO and LED lines * @outmask: bit (N-1) is set to allow GPIO-N to be used as an * (open drain) output * @setup: optional callback issued once the GPIOs are valid * @teardown: optional callback issued before the GPIOs are invalidated * * Board data may be used to package the GPIO (and LED) lines for use * in by the generic GPIO and LED frameworks. The first four GPIOs * starting at gpio_base are GPIO1..GPIO4. The next two are LED1/nPG * and LED2 (with hardware blinking capability, not currently exposed). * * The @setup callback may be used with the kind of board-specific glue * which hands the (now-valid) GPIOs to other drivers, or which puts * devices in their initial states using these GPIOs. */ struct tps65010_board { … }; #endif /* __LINUX_I2C_TPS65010_H */