max77686.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /*
  2. * max77686.h - Driver for the Maxim 77686
  3. *
  4. * Copyright (C) 2012 Samsung Electrnoics
  5. * Chiwoong Byun <woong.byun@samsung.com>
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  20. *
  21. * This driver is based on max8997.h
  22. *
  23. * MAX77686 has PMIC, RTC devices.
  24. * The devices share the same I2C bus and included in
  25. * this mfd driver.
  26. */
  27. #ifndef __LINUX_MFD_MAX77686_H
  28. #define __LINUX_MFD_MAX77686_H
  29. #include <linux/regulator/consumer.h>
  30. /* MAX77686 regulator IDs */
  31. enum max77686_regulators {
  32. MAX77686_LDO1 = 0,
  33. MAX77686_LDO2,
  34. MAX77686_LDO3,
  35. MAX77686_LDO4,
  36. MAX77686_LDO5,
  37. MAX77686_LDO6,
  38. MAX77686_LDO7,
  39. MAX77686_LDO8,
  40. MAX77686_LDO9,
  41. MAX77686_LDO10,
  42. MAX77686_LDO11,
  43. MAX77686_LDO12,
  44. MAX77686_LDO13,
  45. MAX77686_LDO14,
  46. MAX77686_LDO15,
  47. MAX77686_LDO16,
  48. MAX77686_LDO17,
  49. MAX77686_LDO18,
  50. MAX77686_LDO19,
  51. MAX77686_LDO20,
  52. MAX77686_LDO21,
  53. MAX77686_LDO22,
  54. MAX77686_LDO23,
  55. MAX77686_LDO24,
  56. MAX77686_LDO25,
  57. MAX77686_LDO26,
  58. MAX77686_BUCK1,
  59. MAX77686_BUCK2,
  60. MAX77686_BUCK3,
  61. MAX77686_BUCK4,
  62. MAX77686_BUCK5,
  63. MAX77686_BUCK6,
  64. MAX77686_BUCK7,
  65. MAX77686_BUCK8,
  66. MAX77686_BUCK9,
  67. MAX77686_REG_MAX,
  68. };
  69. struct max77686_regulator_data {
  70. int id;
  71. struct regulator_init_data *initdata;
  72. struct device_node *of_node;
  73. };
  74. enum max77686_opmode {
  75. MAX77686_OPMODE_NORMAL,
  76. MAX77686_OPMODE_LP,
  77. MAX77686_OPMODE_STANDBY,
  78. };
  79. struct max77686_opmode_data {
  80. int id;
  81. int mode;
  82. };
  83. struct max77686_platform_data {
  84. /* IRQ */
  85. int irq_gpio;
  86. int ono;
  87. int wakeup;
  88. /* ---- PMIC ---- */
  89. struct max77686_regulator_data *regulators;
  90. int num_regulators;
  91. struct max77686_opmode_data *opmode_data;
  92. /*
  93. * GPIO-DVS feature is not enabled with the current version of
  94. * MAX77686 driver. Buck2/3/4_voltages[0] is used as the default
  95. * voltage at probe. DVS/SELB gpios are set as OUTPUT-LOW.
  96. */
  97. int buck234_gpio_dvs[3]; /* GPIO of [0]DVS1, [1]DVS2, [2]DVS3 */
  98. int buck234_gpio_selb[3]; /* [0]SELB2, [1]SELB3, [2]SELB4 */
  99. unsigned int buck2_voltage[8]; /* buckx_voltage in uV */
  100. unsigned int buck3_voltage[8];
  101. unsigned int buck4_voltage[8];
  102. };
  103. #endif /* __LINUX_MFD_MAX77686_H */