Merge branch 'perf-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel...
[pandora-kernel.git] / arch / arm / mach-tegra / board-harmony-pcie.c
index f7e7d45..9c27b95 100644 (file)
 
 #ifdef CONFIG_TEGRA_PCI
 
+/* GPIO 3 of the PMIC */
+#define EN_VDD_1V05_GPIO       (TEGRA_NR_GPIOS + 2)
+
 static int __init harmony_pcie_init(void)
 {
+       struct regulator *regulator = NULL;
        int err;
 
        if (!machine_is_harmony())
                return 0;
 
+       err = gpio_request(EN_VDD_1V05_GPIO, "EN_VDD_1V05");
+       if (err)
+               return err;
+
+       gpio_direction_output(EN_VDD_1V05_GPIO, 1);
+
+       regulator = regulator_get(NULL, "pex_clk");
+       if (IS_ERR_OR_NULL(regulator))
+               goto err_reg;
+
+       regulator_enable(regulator);
+
        tegra_pinmux_set_tristate(TEGRA_PINGROUP_GPV, TEGRA_TRI_NORMAL);
        tegra_pinmux_set_tristate(TEGRA_PINGROUP_SLXA, TEGRA_TRI_NORMAL);
        tegra_pinmux_set_tristate(TEGRA_PINGROUP_SLXK, TEGRA_TRI_NORMAL);
@@ -49,9 +65,15 @@ err_pcie:
        tegra_pinmux_set_tristate(TEGRA_PINGROUP_SLXA, TEGRA_TRI_TRISTATE);
        tegra_pinmux_set_tristate(TEGRA_PINGROUP_SLXK, TEGRA_TRI_TRISTATE);
 
+       regulator_disable(regulator);
+       regulator_put(regulator);
+err_reg:
+       gpio_free(EN_VDD_1V05_GPIO);
+
        return err;
 }
 
-subsys_initcall(harmony_pcie_init);
+/* PCI should be initialized after I2C, mfd and regulators */
+subsys_initcall_sync(harmony_pcie_init);
 
 #endif