Commit f6a30530 authored by Stefan Wahren's avatar Stefan Wahren Committed by Ulf Hansson
Browse files

pmdomain: bcm: bcm2835-power: Use devm_clk_get_optional



The driver tries to implement optional clock handling with devm_clk_get.
It treats all errors except EPROBE_DEFER as a missing clock, which is
not correct. So use devm_clk_get_optional here and get the corner-cases
right.

Signed-off-by: default avatarStefan Wahren <wahrenst@gmx.net>
Reviewed-by: default avatarFlorian Fainelli <florian.fainelli@broadcom.com>
Link: https://lore.kernel.org/r/20250415190558.16354-1-wahrenst@gmx.net


Signed-off-by: default avatarUlf Hansson <ulf.hansson@linaro.org>
parent f89c082d
Loading
Loading
Loading
Loading
+4 −12
Original line number Diff line number Diff line
@@ -506,18 +506,10 @@ bcm2835_init_power_domain(struct bcm2835_power *power,
	struct device *dev = power->dev;
	struct bcm2835_power_domain *dom = &power->domains[pd_xlate_index];

	dom->clk = devm_clk_get(dev->parent, name);
	if (IS_ERR(dom->clk)) {
		int ret = PTR_ERR(dom->clk);

		if (ret == -EPROBE_DEFER)
			return ret;

		/* Some domains don't have a clk, so make sure that we
		 * don't deref an error pointer later.
		 */
		dom->clk = NULL;
	}
	dom->clk = devm_clk_get_optional(dev->parent, name);
	if (IS_ERR(dom->clk))
		return dev_err_probe(dev, PTR_ERR(dom->clk), "Failed to get clock %s\n",
							     name);

	dom->base.name = name;
	dom->base.flags = GENPD_FLAG_ACTIVE_WAKEUP;