Skip to content

Commit

Permalink
soc/tegra: pmc: Clean-up I/O rail error messages
Browse files Browse the repository at this point in the history
Use pr_err() instead of dev_err() when the pmc->dev field has not been
initialized yet and add a few missing error messages as well as remove
duplicate ones.

Based on work by Jon Hunter <[email protected]>.

Signed-off-by: Thierry Reding <[email protected]>
  • Loading branch information
thierryreding committed Nov 15, 2016
1 parent 27b12b4 commit 54e2472
Showing 1 changed file with 20 additions and 23 deletions.
43 changes: 20 additions & 23 deletions drivers/soc/tegra/pmc.c
Original file line number Diff line number Diff line change
Expand Up @@ -251,8 +251,6 @@ static int tegra_powergate_lookup(struct tegra_pmc *pmc, const char *name)
return i;
}

dev_err(pmc->dev, "powergate %s not found\n", name);

return -ENODEV;
}

Expand Down Expand Up @@ -469,27 +467,25 @@ static int tegra_powergate_power_down(struct tegra_powergate *pg)
static int tegra_genpd_power_on(struct generic_pm_domain *domain)
{
struct tegra_powergate *pg = to_powergate(domain);
struct tegra_pmc *pmc = pg->pmc;
int err;

err = tegra_powergate_power_up(pg, true);
if (err)
dev_err(pmc->dev, "failed to turn on PM domain %s: %d\n",
pg->genpd.name, err);
pr_err("failed to turn on PM domain %s: %d\n", pg->genpd.name,
err);

return err;
}

static int tegra_genpd_power_off(struct generic_pm_domain *domain)
{
struct tegra_powergate *pg = to_powergate(domain);
struct tegra_pmc *pmc = pg->pmc;
int err;

err = tegra_powergate_power_down(pg);
if (err)
dev_err(pmc->dev, "failed to turn off PM domain %s: %d\n",
pg->genpd.name, err);
pr_err("failed to turn off PM domain %s: %d\n",
pg->genpd.name, err);

return err;
}
Expand Down Expand Up @@ -814,8 +810,7 @@ static void tegra_powergate_add(struct tegra_pmc *pmc, struct device_node *np)

id = tegra_powergate_lookup(pmc, np->name);
if (id < 0) {
dev_err(pmc->dev, "powergate lookup failed for %s: %d\n",
np->name, id);
pr_err("powergate lookup failed for %s: %d\n", np->name, id);
goto free_mem;
}

Expand All @@ -835,15 +830,13 @@ static void tegra_powergate_add(struct tegra_pmc *pmc, struct device_node *np)

err = tegra_powergate_of_get_clks(pg, np);
if (err < 0) {
dev_err(pmc->dev, "failed to get clocks for %s: %d\n",
np->name, err);
pr_err("failed to get clocks for %s: %d\n", np->name, err);
goto set_available;
}

err = tegra_powergate_of_get_resets(pg, np, off);
if (err < 0) {
dev_err(pmc->dev, "failed to get resets for %s: %d\n",
np->name, err);
pr_err("failed to get resets for %s: %d\n", np->name, err);
goto remove_clks;
}

Expand All @@ -866,12 +859,12 @@ static void tegra_powergate_add(struct tegra_pmc *pmc, struct device_node *np)

err = of_genpd_add_provider_simple(np, &pg->genpd);
if (err < 0) {
dev_err(pmc->dev, "failed to add genpd provider for %s: %d\n",
np->name, err);
pr_err("failed to add genpd provider for %s: %d\n", np->name,
err);
goto remove_resets;
}

dev_dbg(pmc->dev, "added power domain %s\n", pg->genpd.name);
pr_debug("added power domain %s\n", pg->genpd.name);

return;

Expand Down Expand Up @@ -940,8 +933,10 @@ static int tegra_io_pad_prepare(enum tegra_io_pad id, unsigned long *request,
unsigned long rate, value;

pad = tegra_io_pad_find(pmc, id);
if (!pad)
if (!pad) {
pr_err("invalid I/O pad ID %u\n", id);
return -ENOENT;
}

if (pad->dpd == UINT_MAX)
return -ENOTSUPP;
Expand All @@ -957,8 +952,10 @@ static int tegra_io_pad_prepare(enum tegra_io_pad id, unsigned long *request,
}

rate = clk_get_rate(pmc->clk);
if (!rate)
if (!rate) {
pr_err("failed to get clock rate\n");
return -ENODEV;
}

tegra_pmc_writel(DPD_SAMPLE_ENABLE, DPD_SAMPLE);

Expand Down Expand Up @@ -1009,15 +1006,15 @@ int tegra_io_pad_power_enable(enum tegra_io_pad id)

err = tegra_io_pad_prepare(id, &request, &status, &mask);
if (err < 0) {
dev_err(pmc->dev, "tegra_io_pad_prepare() failed: %d\n", err);
pr_err("failed to prepare I/O pad: %d\n", err);
goto unlock;
}

tegra_pmc_writel(IO_DPD_REQ_CODE_OFF | mask, request);

err = tegra_io_pad_poll(status, mask, 0, 250);
if (err < 0) {
dev_err(pmc->dev, "tegra_io_pad_poll() failed: %d\n", err);
pr_err("failed to enable I/O pad: %d\n", err);
goto unlock;
}

Expand Down Expand Up @@ -1045,15 +1042,15 @@ int tegra_io_pad_power_disable(enum tegra_io_pad id)

err = tegra_io_pad_prepare(id, &request, &status, &mask);
if (err < 0) {
dev_err(pmc->dev, "tegra_io_pad_prepare() failed: %d\n", err);
pr_err("failed to prepare I/O pad: %d\n", err);
goto unlock;
}

tegra_pmc_writel(IO_DPD_REQ_CODE_ON | mask, request);

err = tegra_io_pad_poll(status, mask, mask, 250);
if (err < 0) {
dev_err(pmc->dev, "tegra_io_pad_poll() failed: %d\n", err);
pr_err("failed to disable I/O pad: %d\n", err);
goto unlock;
}

Expand Down

0 comments on commit 54e2472

Please sign in to comment.