tps65010.h 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. /* linux/i2c/tps65010.h
  2. *
  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. #ifndef __LINUX_I2C_TPS65010_H
  28. #define __LINUX_I2C_TPS65010_H
  29. /*
  30. * ----------------------------------------------------------------------------
  31. * Registers, all 8 bits
  32. * ----------------------------------------------------------------------------
  33. */
  34. #define TPS_CHGSTATUS 0x01
  35. # define TPS_CHG_USB (1 << 7)
  36. # define TPS_CHG_AC (1 << 6)
  37. # define TPS_CHG_THERM (1 << 5)
  38. # define TPS_CHG_TERM (1 << 4)
  39. # define TPS_CHG_TAPER_TMO (1 << 3)
  40. # define TPS_CHG_CHG_TMO (1 << 2)
  41. # define TPS_CHG_PRECHG_TMO (1 << 1)
  42. # define TPS_CHG_TEMP_ERR (1 << 0)
  43. #define TPS_REGSTATUS 0x02
  44. # define TPS_REG_ONOFF (1 << 7)
  45. # define TPS_REG_COVER (1 << 6)
  46. # define TPS_REG_UVLO (1 << 5)
  47. # define TPS_REG_NO_CHG (1 << 4) /* tps65013 */
  48. # define TPS_REG_PG_LD02 (1 << 3)
  49. # define TPS_REG_PG_LD01 (1 << 2)
  50. # define TPS_REG_PG_MAIN (1 << 1)
  51. # define TPS_REG_PG_CORE (1 << 0)
  52. #define TPS_MASK1 0x03
  53. #define TPS_MASK2 0x04
  54. #define TPS_ACKINT1 0x05
  55. #define TPS_ACKINT2 0x06
  56. #define TPS_CHGCONFIG 0x07
  57. # define TPS_CHARGE_POR (1 << 7) /* 65010/65012 */
  58. # define TPS65013_AUA (1 << 7) /* 65011/65013 */
  59. # define TPS_CHARGE_RESET (1 << 6)
  60. # define TPS_CHARGE_FAST (1 << 5)
  61. # define TPS_CHARGE_CURRENT (3 << 3)
  62. # define TPS_VBUS_500MA (1 << 2)
  63. # define TPS_VBUS_CHARGING (1 << 1)
  64. # define TPS_CHARGE_ENABLE (1 << 0)
  65. #define TPS_LED1_ON 0x08
  66. #define TPS_LED1_PER 0x09
  67. #define TPS_LED2_ON 0x0a
  68. #define TPS_LED2_PER 0x0b
  69. #define TPS_VDCDC1 0x0c
  70. # define TPS_ENABLE_LP (1 << 3)
  71. #define TPS_VDCDC2 0x0d
  72. # define TPS_LP_COREOFF (1 << 7)
  73. # define TPS_VCORE_1_8V (7<<4)
  74. # define TPS_VCORE_1_5V (6 << 4)
  75. # define TPS_VCORE_1_4V (5 << 4)
  76. # define TPS_VCORE_1_3V (4 << 4)
  77. # define TPS_VCORE_1_2V (3 << 4)
  78. # define TPS_VCORE_1_1V (2 << 4)
  79. # define TPS_VCORE_1_0V (1 << 4)
  80. # define TPS_VCORE_0_85V (0 << 4)
  81. # define TPS_VCORE_LP_1_2V (3 << 2)
  82. # define TPS_VCORE_LP_1_1V (2 << 2)
  83. # define TPS_VCORE_LP_1_0V (1 << 2)
  84. # define TPS_VCORE_LP_0_85V (0 << 2)
  85. # define TPS_VIB (1 << 1)
  86. # define TPS_VCORE_DISCH (1 << 0)
  87. #define TPS_VREGS1 0x0e
  88. # define TPS_LDO2_ENABLE (1 << 7)
  89. # define TPS_LDO2_OFF (1 << 6)
  90. # define TPS_VLDO2_3_0V (3 << 4)
  91. # define TPS_VLDO2_2_75V (2 << 4)
  92. # define TPS_VLDO2_2_5V (1 << 4)
  93. # define TPS_VLDO2_1_8V (0 << 4)
  94. # define TPS_LDO1_ENABLE (1 << 3)
  95. # define TPS_LDO1_OFF (1 << 2)
  96. # define TPS_VLDO1_3_0V (3 << 0)
  97. # define TPS_VLDO1_2_75V (2 << 0)
  98. # define TPS_VLDO1_2_5V (1 << 0)
  99. # define TPS_VLDO1_ADJ (0 << 0)
  100. #define TPS_MASK3 0x0f
  101. #define TPS_DEFGPIO 0x10
  102. /*
  103. * ----------------------------------------------------------------------------
  104. * Macros used by exported functions
  105. * ----------------------------------------------------------------------------
  106. */
  107. #define LED1 1
  108. #define LED2 2
  109. #define OFF 0
  110. #define ON 1
  111. #define BLINK 2
  112. #define GPIO1 1
  113. #define GPIO2 2
  114. #define GPIO3 3
  115. #define GPIO4 4
  116. #define LOW 0
  117. #define HIGH 1
  118. /*
  119. * ----------------------------------------------------------------------------
  120. * Exported functions
  121. * ----------------------------------------------------------------------------
  122. */
  123. /* Draw from VBUS:
  124. * 0 mA -- DON'T DRAW (might supply power instead)
  125. * 100 mA -- usb unit load (slowest charge rate)
  126. * 500 mA -- usb high power (fast battery charge)
  127. */
  128. extern int tps65010_set_vbus_draw(unsigned mA);
  129. /* tps65010_set_gpio_out_value parameter:
  130. * gpio: GPIO1, GPIO2, GPIO3 or GPIO4
  131. * value: LOW or HIGH
  132. */
  133. extern int tps65010_set_gpio_out_value(unsigned gpio, unsigned value);
  134. /* tps65010_set_led parameter:
  135. * led: LED1 or LED2
  136. * mode: ON, OFF or BLINK
  137. */
  138. extern int tps65010_set_led(unsigned led, unsigned mode);
  139. /* tps65010_set_vib parameter:
  140. * value: ON or OFF
  141. */
  142. extern int tps65010_set_vib(unsigned value);
  143. /* tps65010_set_low_pwr parameter:
  144. * mode: ON or OFF
  145. */
  146. extern int tps65010_set_low_pwr(unsigned mode);
  147. /* tps65010_config_vregs1 parameter:
  148. * value to be written to VREGS1 register
  149. * Note: The complete register is written, set all bits you need
  150. */
  151. extern int tps65010_config_vregs1(unsigned value);
  152. /* tps65013_set_low_pwr parameter:
  153. * mode: ON or OFF
  154. */
  155. extern int tps65013_set_low_pwr(unsigned mode);
  156. /* tps65010_set_vdcdc2
  157. * value to be written to VDCDC2
  158. */
  159. extern int tps65010_config_vdcdc2(unsigned value);
  160. struct i2c_client;
  161. /**
  162. * struct tps65010_board - packages GPIO and LED lines
  163. * @base: the GPIO number to assign to GPIO-1
  164. * @outmask: bit (N-1) is set to allow GPIO-N to be used as an
  165. * (open drain) output
  166. * @setup: optional callback issued once the GPIOs are valid
  167. * @teardown: optional callback issued before the GPIOs are invalidated
  168. * @context: optional parameter passed to setup() and teardown()
  169. *
  170. * Board data may be used to package the GPIO (and LED) lines for use
  171. * in by the generic GPIO and LED frameworks. The first four GPIOs
  172. * starting at gpio_base are GPIO1..GPIO4. The next two are LED1/nPG
  173. * and LED2 (with hardware blinking capability, not currently exposed).
  174. *
  175. * The @setup callback may be used with the kind of board-specific glue
  176. * which hands the (now-valid) GPIOs to other drivers, or which puts
  177. * devices in their initial states using these GPIOs.
  178. */
  179. struct tps65010_board {
  180. int base;
  181. unsigned outmask;
  182. int (*setup)(struct i2c_client *client, void *context);
  183. int (*teardown)(struct i2c_client *client, void *context);
  184. void *context;
  185. };
  186. #endif /* __LINUX_I2C_TPS65010_H */