|
@@ -299,3 +299,111 @@ ab8500_regulator_reg_init[AB8500_NUM_REGULATOR_REGISTERS] = {
|
|
|
|
|
|
/* AB8500 regulators */
|
|
|
struct regulator_init_data ab8500_regulators[AB8500_NUM_REGULATORS] = {
|
|
|
+ /* supplies to the display/camera */
|
|
|
+ [AB8500_LDO_AUX1] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-DISPLAY",
|
|
|
+ .min_uV = 2500000,
|
|
|
+ .max_uV = 2900000,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
|
|
|
+ REGULATOR_CHANGE_STATUS,
|
|
|
+ .boot_on = 1, /* display is on at boot */
|
|
|
+ /*
|
|
|
+ * This voltage cannot be disabled right now because
|
|
|
+ * it is somehow affecting the external MMC
|
|
|
+ * functionality, though that typically will use
|
|
|
+ * AUX3.
|
|
|
+ */
|
|
|
+ .always_on = 1,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux1_consumers),
|
|
|
+ .consumer_supplies = ab8500_vaux1_consumers,
|
|
|
+ },
|
|
|
+ /* supplies to the on-board eMMC */
|
|
|
+ [AB8500_LDO_AUX2] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-eMMC1",
|
|
|
+ .min_uV = 1100000,
|
|
|
+ .max_uV = 3300000,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
|
|
|
+ REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux2_consumers),
|
|
|
+ .consumer_supplies = ab8500_vaux2_consumers,
|
|
|
+ },
|
|
|
+ /* supply for VAUX3, supplies to SDcard slots */
|
|
|
+ [AB8500_LDO_AUX3] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-MMC-SD",
|
|
|
+ .min_uV = 1100000,
|
|
|
+ .max_uV = 3300000,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
|
|
|
+ REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux3_consumers),
|
|
|
+ .consumer_supplies = ab8500_vaux3_consumers,
|
|
|
+ },
|
|
|
+ /* supply for tvout, gpadc, TVOUT LDO */
|
|
|
+ [AB8500_LDO_TVOUT] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-TVOUT",
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vtvout_consumers),
|
|
|
+ .consumer_supplies = ab8500_vtvout_consumers,
|
|
|
+ },
|
|
|
+ /* supply for ab8500-vaudio, VAUDIO LDO */
|
|
|
+ [AB8500_LDO_AUDIO] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-AUD",
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vaud_consumers),
|
|
|
+ .consumer_supplies = ab8500_vaud_consumers,
|
|
|
+ },
|
|
|
+ /* supply for v-anamic1 VAMic1-LDO */
|
|
|
+ [AB8500_LDO_ANAMIC1] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-AMIC1",
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic1_consumers),
|
|
|
+ .consumer_supplies = ab8500_vamic1_consumers,
|
|
|
+ },
|
|
|
+ /* supply for v-amic2, VAMIC2 LDO, reuse constants for AMIC1 */
|
|
|
+ [AB8500_LDO_ANAMIC2] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-AMIC2",
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic2_consumers),
|
|
|
+ .consumer_supplies = ab8500_vamic2_consumers,
|
|
|
+ },
|
|
|
+ /* supply for v-dmic, VDMIC LDO */
|
|
|
+ [AB8500_LDO_DMIC] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-DMIC",
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vdmic_consumers),
|
|
|
+ .consumer_supplies = ab8500_vdmic_consumers,
|
|
|
+ },
|
|
|
+ /* supply for v-intcore12, VINTCORE12 LDO */
|
|
|
+ [AB8500_LDO_INTCORE] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-INTCORE",
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vintcore_consumers),
|
|
|
+ .consumer_supplies = ab8500_vintcore_consumers,
|
|
|
+ },
|
|
|
+ /* supply for U8500 CSI/DSI, VANA LDO */
|
|
|
+ [AB8500_LDO_ANA] = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "V-CSI/DSI",
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(ab8500_vana_consumers),
|
|
|
+ .consumer_supplies = ab8500_vana_consumers,
|
|
|
+ },
|
|
|
+};
|