sandbox_pmic.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. /*
  2. * Copyright (C) 2015 Samsung Electronics
  3. * Przemyslaw Marczak <p.marczak@samsung.com>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #ifndef _SANDBOX_PMIC_H_
  8. #define _SANDBOX_PMIC_H_
  9. #define SANDBOX_LDO_DRIVER "sandbox_ldo"
  10. #define SANDBOX_OF_LDO_PREFIX "ldo"
  11. #define SANDBOX_BUCK_DRIVER "sandbox_buck"
  12. #define SANDBOX_OF_BUCK_PREFIX "buck"
  13. #define SANDBOX_BUCK_COUNT 2
  14. #define SANDBOX_LDO_COUNT 2
  15. /*
  16. * Sandbox PMIC registers:
  17. * We have only 12 significant registers, but we alloc 16 for padding.
  18. */
  19. enum {
  20. SANDBOX_PMIC_REG_BUCK1_UV = 0,
  21. SANDBOX_PMIC_REG_BUCK1_UA,
  22. SANDBOX_PMIC_REG_BUCK1_OM,
  23. SANDBOX_PMIC_REG_BUCK2_UV,
  24. SANDBOX_PMIC_REG_BUCK2_UA,
  25. SANDBOX_PMIC_REG_BUCK2_OM,
  26. SANDBOX_PMIC_REG_LDO_OFFSET,
  27. SANDBOX_PMIC_REG_LDO1_UV = SANDBOX_PMIC_REG_LDO_OFFSET,
  28. SANDBOX_PMIC_REG_LDO1_UA,
  29. SANDBOX_PMIC_REG_LDO1_OM,
  30. SANDBOX_PMIC_REG_LDO2_UV,
  31. SANDBOX_PMIC_REG_LDO2_UA,
  32. SANDBOX_PMIC_REG_LDO2_OM,
  33. SANDBOX_PMIC_REG_COUNT = 16,
  34. };
  35. /* Register offset for output: micro Volts, micro Amps, Operation Mode */
  36. enum {
  37. OUT_REG_UV = 0,
  38. OUT_REG_UA,
  39. OUT_REG_OM,
  40. OUT_REG_COUNT,
  41. };
  42. /* Buck operation modes */
  43. enum {
  44. BUCK_OM_OFF = 0,
  45. BUCK_OM_ON,
  46. BUCK_OM_PWM,
  47. BUCK_OM_COUNT,
  48. };
  49. /* Ldo operation modes */
  50. enum {
  51. LDO_OM_OFF = 0,
  52. LDO_OM_ON,
  53. LDO_OM_SLEEP,
  54. LDO_OM_STANDBY,
  55. LDO_OM_COUNT,
  56. };
  57. /* BUCK1 Voltage: min: 0.8V, step: 25mV, max 2.4V */
  58. #define OUT_BUCK1_UV_MIN 800000
  59. #define OUT_BUCK1_UV_MAX 2400000
  60. #define OUT_BUCK1_UV_STEP 25000
  61. /* BUCK1 Amperage: min: 150mA, step: 25mA, max: 250mA */
  62. #define OUT_BUCK1_UA_MIN 150000
  63. #define OUT_BUCK1_UA_MAX 250000
  64. #define OUT_BUCK1_UA_STEP 25000
  65. /* BUCK2 Voltage: min: 0.75V, step: 50mV, max 3.95V */
  66. #define OUT_BUCK2_UV_MIN 750000
  67. #define OUT_BUCK2_UV_MAX 3950000
  68. #define OUT_BUCK2_UV_STEP 50000
  69. /* LDO1 Voltage: min: 0.8V, step: 25mV, max 2.4V */
  70. #define OUT_LDO1_UV_MIN 800000
  71. #define OUT_LDO1_UV_MAX 2400000
  72. #define OUT_LDO1_UV_STEP 25000
  73. /* LDO1 Amperage: min: 100mA, step: 50mA, max: 200mA */
  74. #define OUT_LDO1_UA_MIN 100000
  75. #define OUT_LDO1_UA_MAX 200000
  76. #define OUT_LDO1_UA_STEP 50000
  77. /* LDO2 Voltage: min: 0.75V, step: 50mV, max 3.95V */
  78. #define OUT_LDO2_UV_MIN 750000
  79. #define OUT_LDO2_UV_MAX 3950000
  80. #define OUT_LDO2_UV_STEP 50000
  81. /* register <-> value conversion */
  82. #define REG2VAL(min, step, reg) ((min) + ((step) * (reg)))
  83. #define VAL2REG(min, step, val) (((val) - (min)) / (step))
  84. /* Operation mode id -> register value conversion */
  85. #define OM2REG(x) (x)
  86. /* Test data for: test/dm/power.c */
  87. /* BUCK names */
  88. #define SANDBOX_BUCK1_DEVNAME "buck1"
  89. #define SANDBOX_BUCK1_PLATNAME "SUPPLY_1.2V"
  90. #define SANDBOX_BUCK2_DEVNAME "buck2"
  91. #define SANDBOX_BUCK2_PLATNAME "SUPPLY_3.3V"
  92. /* LDO names */
  93. #define SANDBOX_LDO1_DEVNAME "ldo1"
  94. #define SANDBOX_LDO1_PLATNAME "VDD_EMMC_1.8V"
  95. #define SANDBOX_LDO2_DEVNAME "ldo2"
  96. #define SANDBOX_LDO2_PLATNAME "VDD_LCD_3.3V"
  97. /*
  98. * Expected regulators setup after call of:
  99. * - regulator_autoset_by_name()
  100. * - regulator_list_autoset()
  101. */
  102. /* BUCK1: for testing regulator_autoset_by_name() */
  103. #define SANDBOX_BUCK1_AUTOSET_EXPECTED_UV 1200000
  104. #define SANDBOX_BUCK1_AUTOSET_EXPECTED_UA 200000
  105. #define SANDBOX_BUCK1_AUTOSET_EXPECTED_ENABLE true
  106. /* BUCK2: for testing sandbox ADC's supply */
  107. #define SANDBOX_BUCK2_INITIAL_EXPECTED_UV 3000000
  108. #define SANDBOX_BUCK2_SET_UV 3300000
  109. /* LDO1/2 for testing regulator_list_autoset() */
  110. #define SANDBOX_LDO1_AUTOSET_EXPECTED_UV 1800000
  111. #define SANDBOX_LDO1_AUTOSET_EXPECTED_UA 100000
  112. #define SANDBOX_LDO1_AUTOSET_EXPECTED_ENABLE true
  113. #define SANDBOX_LDO2_AUTOSET_EXPECTED_UV 3000000
  114. #define SANDBOX_LDO2_AUTOSET_EXPECTED_UA -ENOSYS
  115. #define SANDBOX_LDO2_AUTOSET_EXPECTED_ENABLE false
  116. #endif