diff options
author | Pradeep Goudagunta <pgoudagunta@nvidia.com> | 2011-05-04 16:37:43 +0530 |
---|---|---|
committer | Varun Colbert <vcolbert@nvidia.com> | 2011-05-13 19:06:19 -0700 |
commit | 376fcd862f9a5885581e4da95b83fff0d2448aaa (patch) | |
tree | dc8ad8871a9881ba12f85e0aa82dfd06f761c977 | |
parent | afbfeaceca091ae338c3dccede18b5e0deaba232 (diff) |
ARM: tegra: power: PM269: Add GPIO_REG
Adding GPIO_REG for power rails of PM269 board.
Bug 823160
Change-Id: Idbb889420e033780900b1b1b700637017640414e
Reviewed-on: http://git-master/r/30366
Reviewed-by: Raymond Poudrier <rapoudrier@nvidia.com>
Reviewed-by: Varun Colbert <vcolbert@nvidia.com>
Tested-by: Varun Colbert <vcolbert@nvidia.com>
-rw-r--r-- | arch/arm/mach-tegra/board-cardhu-power.c | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/arch/arm/mach-tegra/board-cardhu-power.c b/arch/arm/mach-tegra/board-cardhu-power.c index cda6c9b158c5..9063753ea0f6 100644 --- a/arch/arm/mach-tegra/board-cardhu-power.c +++ b/arch/arm/mach-tegra/board-cardhu-power.c @@ -598,6 +598,21 @@ GREG_INIT(11, en_vdd_sdmmc1, en_vdd_sdmmc1, "vdd_3v3_devices", TEGRA_GPIO_PD7, GREG_INIT(12, en_3v3_pex_hvdd, en_3v3_pex_hvdd, "vdd_3v3_devices", TEGRA_GPIO_PL7, false, 0, 0, 0, 0); GREG_INIT(13, en_1v8_cam, en_1v8_cam, "vdd_gen1v8", TEGRA_GPIO_PBB4, false, 0, 0, 0, 0); +/*Specific to pm269*/ +GREG_INIT(4, en_vdd_bl_p269, en_vdd_bl, NULL, + TEGRA_GPIO_PH3, false, 1, 0, 0, 0); +GREG_INIT(6, en_vdd_pnl1_pm269, en_vdd_pnl1, "vdd_3v3_devices", + TEGRA_GPIO_PW1, false, 1, 0, 0, 0); +GREG_INIT(9, en_3v3_fuse_pm269, en_3v3_fuse, "vdd_3v3_devices", + TEGRA_GPIO_PC1, false, 0, 0, 0, 0); +GREG_INIT(11, en_vdd_sdmmc1_pm269, en_vdd_sdmmc1, "vdd_3v3_devices", + TEGRA_GPIO_PP1, false, 1, 0, 0, 0); +GREG_INIT(12, en_3v3_pex_hvdd_pm269, en_3v3_pex_hvdd, "vdd_3v3_devices", + TEGRA_GPIO_PC6, false, 0, 0, 0, 0); +GREG_INIT(17, en_vddio_vid_oc_pm269, en_vddio_vid_oc, "vdd_5v0_sys", + TEGRA_GPIO_PP2, false, 0, TEGRA_PINGROUP_VI_PCLK, + enable_load_switch_rail, disable_load_switch_rail); + /* Specific to E1187/E1186 */ GREG_INIT(14, dis_5v_switch_e118x, dis_5v_switch, "vdd_5v0_sys", TEGRA_GPIO_PX2, true, 0, 0, 0, 0); @@ -658,6 +673,26 @@ GREG_INIT(22, en_vbrtr, en_vbrtr, "vdd_3v3_devices", PMU_TCA6416_GPIO_PORT12, f ADD_GPIO_REG(en_3v3_pex_hvdd), \ ADD_GPIO_REG(en_1v8_cam), +#define PM269_GPIO_REG \ + ADD_GPIO_REG(en_5v_cp), \ + ADD_GPIO_REG(en_5v0), \ + ADD_GPIO_REG(en_ddr), \ + ADD_GPIO_REG(en_vdd_bl), \ + ADD_GPIO_REG(en_3v3_sys), \ + ADD_GPIO_REG(en_3v3_modem), \ + ADD_GPIO_REG(en_vdd_pnl1), \ + ADD_GPIO_REG(cam3_ldo_en), \ + ADD_GPIO_REG(en_vdd_com), \ + ADD_GPIO_REG(en_3v3_fuse_pm269), \ + ADD_GPIO_REG(en_3v3_emmc), \ + ADD_GPIO_REG(en_vdd_sdmmc1_pm269), \ + ADD_GPIO_REG(en_3v3_pex_hvdd_pm269), \ + ADD_GPIO_REG(en_1v8_cam), \ + ADD_GPIO_REG(dis_5v_switch_e118x), \ + ADD_GPIO_REG(en_usb1_vbus_oc_e118x), \ + ADD_GPIO_REG(en_usb3_vbus_oc_e118x), \ + ADD_GPIO_REG(en_vddio_vid_oc_pm269), + #define E118x_GPIO_REG \ ADD_GPIO_REG(en_vdd_bl), \ ADD_GPIO_REG(dis_5v_switch_e118x), \ @@ -697,6 +732,11 @@ static struct gpio_switch_regulator_subdev_data *gswitch_subdevs_e1198[] = { E1198_GPIO_REG }; +/* Gpio switch regulator platform data for PM269*/ +static struct gpio_switch_regulator_subdev_data *gswitch_subdevs_pm269[] = { + PM269_GPIO_REG +}; + /* Gpio switch regulator platform data for E1291 A03*/ static struct gpio_switch_regulator_subdev_data *gswitch_subdevs_e1291_a03[] = { COMMON_GPIO_REG @@ -733,6 +773,10 @@ int __init cardhu_gpio_switch_regulator_init(void) gswitch_pdata.num_subdevs = ARRAY_SIZE(gswitch_subdevs_e1198); gswitch_pdata.subdevs = gswitch_subdevs_e1198; break; + case BOARD_PM269: + gswitch_pdata.num_subdevs = ARRAY_SIZE(gswitch_subdevs_pm269); + gswitch_pdata.subdevs = gswitch_subdevs_pm269; + break; default: gswitch_pdata.num_subdevs = ARRAY_SIZE(gswitch_subdevs_e118x); gswitch_pdata.subdevs = gswitch_subdevs_e118x; |