int err;
if (!dev->pm_domain) {
- err = tegra_powergate_power_off(TEGRA_POWERGATE_VDEC);
+ err = tegra_pmc_powergate_power_off(vde->pmc,
+ TEGRA_POWERGATE_VDEC);
if (err) {
dev_err(dev, "Failed to power down HW: %d\n", err);
return err;
}
if (!dev->pm_domain) {
- err = tegra_powergate_sequence_power_up(TEGRA_POWERGATE_VDEC,
- vde->clk, vde->rst);
+ err = tegra_pmc_powergate_sequence_power_up(vde->pmc,
+ TEGRA_POWERGATE_VDEC,
+ vde->clk, vde->rst);
if (err) {
dev_err(dev, "Failed to power up HW : %d\n", err);
goto release_reset;
}
} else {
/*
- * tegra_powergate_sequence_power_up() leaves clocks enabled,
+ * tegra_pmc_powergate_sequence_power_up() leaves clocks enabled,
* while GENPD not.
*/
err = clk_prepare_enable(vde->clk);
return err;
}
+ vde->pmc = devm_tegra_pmc_get(dev);
+ if (IS_ERR(vde->pmc))
+ return dev_err_probe(dev, PTR_ERR(vde->pmc),
+ "failed to get PMC\n");
+
irq = platform_get_irq_byname(pdev, "sync-token");
if (irq < 0)
return irq;
struct list_head map_list;
struct reset_control *rst;
struct reset_control *rst_mc;
+ struct tegra_pmc *pmc;
struct gen_pool *iram_pool;
struct completion decode_completion;
struct clk *clk;