|
@@ -215,3 +215,177 @@ void __init omap3_pmic_get_config(struct twl4030_platform_data *pmic_data,
|
|
|
if (pdata_flags & TWL_COMMON_PDATA_USB && !pmic_data->usb)
|
|
|
pmic_data->usb = &omap3_usb_pdata;
|
|
|
|
|
|
+ if (pdata_flags & TWL_COMMON_PDATA_BCI && !pmic_data->bci)
|
|
|
+ pmic_data->bci = &omap3_bci_pdata;
|
|
|
+
|
|
|
+ if (pdata_flags & TWL_COMMON_PDATA_MADC && !pmic_data->madc)
|
|
|
+ pmic_data->madc = &omap3_madc_pdata;
|
|
|
+
|
|
|
+ if (pdata_flags & TWL_COMMON_PDATA_AUDIO && !pmic_data->audio)
|
|
|
+ pmic_data->audio = &omap3_audio_pdata;
|
|
|
+
|
|
|
+ /* Common regulator configurations */
|
|
|
+ if (regulators_flags & TWL_COMMON_REGULATOR_VDAC && !pmic_data->vdac)
|
|
|
+ pmic_data->vdac = &omap3_vdac_idata;
|
|
|
+
|
|
|
+ if (regulators_flags & TWL_COMMON_REGULATOR_VPLL2 && !pmic_data->vpll2)
|
|
|
+ pmic_data->vpll2 = &omap3_vpll2_idata;
|
|
|
+}
|
|
|
+#endif /* CONFIG_ARCH_OMAP3 */
|
|
|
+
|
|
|
+#if defined(CONFIG_ARCH_OMAP4)
|
|
|
+static struct twl4030_usb_data omap4_usb_pdata = {
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_consumer_supply omap4_vdda_hdmi_dac_supplies[] = {
|
|
|
+ REGULATOR_SUPPLY("vdda_hdmi_dac", "omapdss_hdmi"),
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_vdac_idata = {
|
|
|
+ .constraints = {
|
|
|
+ .min_uV = 1800000,
|
|
|
+ .max_uV = 1800000,
|
|
|
+ .valid_modes_mask = REGULATOR_MODE_NORMAL
|
|
|
+ | REGULATOR_MODE_STANDBY,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_MODE
|
|
|
+ | REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(omap4_vdda_hdmi_dac_supplies),
|
|
|
+ .consumer_supplies = omap4_vdda_hdmi_dac_supplies,
|
|
|
+ .supply_regulator = "V2V1",
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_vaux2_idata = {
|
|
|
+ .constraints = {
|
|
|
+ .min_uV = 1200000,
|
|
|
+ .max_uV = 2800000,
|
|
|
+ .apply_uV = true,
|
|
|
+ .valid_modes_mask = REGULATOR_MODE_NORMAL
|
|
|
+ | REGULATOR_MODE_STANDBY,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE
|
|
|
+ | REGULATOR_CHANGE_MODE
|
|
|
+ | REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_vaux3_idata = {
|
|
|
+ .constraints = {
|
|
|
+ .min_uV = 1000000,
|
|
|
+ .max_uV = 3000000,
|
|
|
+ .apply_uV = true,
|
|
|
+ .valid_modes_mask = REGULATOR_MODE_NORMAL
|
|
|
+ | REGULATOR_MODE_STANDBY,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE
|
|
|
+ | REGULATOR_CHANGE_MODE
|
|
|
+ | REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_consumer_supply omap4_vmmc_supply[] = {
|
|
|
+ REGULATOR_SUPPLY("vmmc", "omap_hsmmc.0"),
|
|
|
+};
|
|
|
+
|
|
|
+/* VMMC1 for MMC1 card */
|
|
|
+static struct regulator_init_data omap4_vmmc_idata = {
|
|
|
+ .constraints = {
|
|
|
+ .min_uV = 1200000,
|
|
|
+ .max_uV = 3000000,
|
|
|
+ .apply_uV = true,
|
|
|
+ .valid_modes_mask = REGULATOR_MODE_NORMAL
|
|
|
+ | REGULATOR_MODE_STANDBY,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE
|
|
|
+ | REGULATOR_CHANGE_MODE
|
|
|
+ | REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(omap4_vmmc_supply),
|
|
|
+ .consumer_supplies = omap4_vmmc_supply,
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_vpp_idata = {
|
|
|
+ .constraints = {
|
|
|
+ .min_uV = 1800000,
|
|
|
+ .max_uV = 2500000,
|
|
|
+ .apply_uV = true,
|
|
|
+ .valid_modes_mask = REGULATOR_MODE_NORMAL
|
|
|
+ | REGULATOR_MODE_STANDBY,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE
|
|
|
+ | REGULATOR_CHANGE_MODE
|
|
|
+ | REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_vana_idata = {
|
|
|
+ .constraints = {
|
|
|
+ .min_uV = 2100000,
|
|
|
+ .max_uV = 2100000,
|
|
|
+ .valid_modes_mask = REGULATOR_MODE_NORMAL
|
|
|
+ | REGULATOR_MODE_STANDBY,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_MODE
|
|
|
+ | REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_consumer_supply omap4_vcxio_supply[] = {
|
|
|
+ REGULATOR_SUPPLY("vdds_dsi", "omapdss_dss"),
|
|
|
+ REGULATOR_SUPPLY("vdds_dsi", "omapdss_dsi.0"),
|
|
|
+ REGULATOR_SUPPLY("vdds_dsi", "omapdss_dsi.1"),
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_vcxio_idata = {
|
|
|
+ .constraints = {
|
|
|
+ .min_uV = 1800000,
|
|
|
+ .max_uV = 1800000,
|
|
|
+ .valid_modes_mask = REGULATOR_MODE_NORMAL
|
|
|
+ | REGULATOR_MODE_STANDBY,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_MODE
|
|
|
+ | REGULATOR_CHANGE_STATUS,
|
|
|
+ .always_on = true,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(omap4_vcxio_supply),
|
|
|
+ .consumer_supplies = omap4_vcxio_supply,
|
|
|
+ .supply_regulator = "V2V1",
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_vusb_idata = {
|
|
|
+ .constraints = {
|
|
|
+ .min_uV = 3300000,
|
|
|
+ .max_uV = 3300000,
|
|
|
+ .valid_modes_mask = REGULATOR_MODE_NORMAL
|
|
|
+ | REGULATOR_MODE_STANDBY,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_MODE
|
|
|
+ | REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_clk32kg_idata = {
|
|
|
+ .constraints = {
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_STATUS,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_consumer_supply omap4_vdd1_supply[] = {
|
|
|
+ REGULATOR_SUPPLY("vcc", "cpu0"),
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_consumer_supply omap4_vdd2_supply[] = {
|
|
|
+ REGULATOR_SUPPLY("vcc", "iva.0"),
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_consumer_supply omap4_vdd3_supply[] = {
|
|
|
+ REGULATOR_SUPPLY("vcc", "l3_main.0"),
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_vdd1 = {
|
|
|
+ .constraints = {
|
|
|
+ .name = "vdd_mpu",
|
|
|
+ .min_uV = 500000,
|
|
|
+ .max_uV = 1500000,
|
|
|
+ .valid_modes_mask = REGULATOR_MODE_NORMAL,
|
|
|
+ .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
|
|
|
+ },
|
|
|
+ .num_consumer_supplies = ARRAY_SIZE(omap4_vdd1_supply),
|
|
|
+ .consumer_supplies = omap4_vdd1_supply,
|
|
|
+};
|
|
|
+
|
|
|
+static struct regulator_init_data omap4_vdd2 = {
|
|
|
+ .constraints = {
|