tps65090.h 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * Copyright (c) 2015 Google, Inc
  3. * Written by Simon Glass <sjg@chromium.org>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #ifndef __TPS65090_PMIC_H_
  8. #define __TPS65090_PMIC_H_
  9. /* I2C device address for TPS65090 PMU */
  10. #define TPS65090_I2C_ADDR 0x48
  11. /* TPS65090 register addresses */
  12. enum {
  13. REG_IRQ1 = 0,
  14. REG_CG_CTRL0 = 4,
  15. REG_CG_STATUS1 = 0xa,
  16. REG_FET_BASE = 0xe, /* Not a real register, FETs count from here */
  17. REG_FET1_CTRL,
  18. REG_FET2_CTRL,
  19. REG_FET3_CTRL,
  20. REG_FET4_CTRL,
  21. REG_FET5_CTRL,
  22. REG_FET6_CTRL,
  23. REG_FET7_CTRL,
  24. TPS65090_NUM_REGS,
  25. };
  26. enum {
  27. IRQ1_VBATG = 1 << 3,
  28. CG_CTRL0_ENC_MASK = 0x01,
  29. MAX_FET_NUM = 7,
  30. MAX_CTRL_READ_TRIES = 5,
  31. /* TPS65090 FET_CTRL register values */
  32. FET_CTRL_TOFET = 1 << 7, /* Timeout, startup, overload */
  33. FET_CTRL_PGFET = 1 << 4, /* Power good for FET status */
  34. FET_CTRL_WAIT = 3 << 2, /* Overcurrent timeout max */
  35. FET_CTRL_ADENFET = 1 << 1, /* Enable output auto discharge */
  36. FET_CTRL_ENFET = 1 << 0, /* Enable FET */
  37. };
  38. enum {
  39. /* Status register fields */
  40. TPS65090_ST1_OTC = 1 << 0,
  41. TPS65090_ST1_OCC = 1 << 1,
  42. TPS65090_ST1_STATE_SHIFT = 4,
  43. TPS65090_ST1_STATE_MASK = 0xf << TPS65090_ST1_STATE_SHIFT,
  44. };
  45. /* Drivers name */
  46. #define TPS65090_FET_DRIVER "tps65090_fet"
  47. #endif /* __TPS65090_PMIC_H_ */