Re: [PATCH] OPP: ti: Fix ti_opp_supply_probe wrong return values

From: Primoz Fiser
Date: Thu Jun 06 2024 - 06:34:45 EST


Hi Viresh,

On 6. 06. 24 11:48, Viresh Kumar wrote:
> On 06-06-24, 11:43, Primoz Fiser wrote:
>> ti_opp_supply_probe
>> -> dev_pm_opp_set_config_regulators
>> -> dev_pm_opp_set_config (returns negative if error, otherwise >= 1)
>
> Ah, I forgot about the token that is returned here. I think the driver
> should be fixed properly once and for all here.
>
> The token must be used to clean the module removal part. Else if you
> try to insert this module, remove it, insert again, you will get some
> errors as the resources aren't cleaned well.
>
> So either provide a remove() callback to the driver, or use
> devm_pm_opp_set_config() here.
>

So basically, you want v2 with:

> diff --git a/drivers/opp/ti-opp-supply.c b/drivers/opp/ti-opp-supply.c
> index e3b97cd1fbbf..8a4bcc5fb9dc 100644
> --- a/drivers/opp/ti-opp-supply.c
> +++ b/drivers/opp/ti-opp-supply.c
> @@ -392,7 +392,7 @@ static int ti_opp_supply_probe(struct platform_device *pdev)
> return ret;
> }
>
> - ret = dev_pm_opp_set_config_regulators(cpu_dev, ti_opp_config_regulators);
> + ret = devm_pm_opp_set_config_regulators(cpu_dev, ti_opp_config_regulators);
> if (ret < 0)
> _free_optimized_voltages(dev, &opp_data);
>
> diff --git a/include/linux/pm_opp.h b/include/linux/pm_opp.h
> index dd7c8441af42..a2401878d1d9 100644
> --- a/include/linux/pm_opp.h
> +++ b/include/linux/pm_opp.h
> @@ -654,14 +654,14 @@ static inline int devm_pm_opp_set_clkname(struct device *dev, const char *name)
> }
>
> /* config-regulators helpers */
> -static inline int dev_pm_opp_set_config_regulators(struct device *dev,
> +static inline int devm_pm_opp_set_config_regulators(struct device *dev,
> config_regulators_t helper)
> {
> struct dev_pm_opp_config config = {
> .config_regulators = helper,
> };
>
> - return dev_pm_opp_set_config(dev, &config);
> + return devm_pm_opp_set_config(dev, &config);
> }
>
> static inline void dev_pm_opp_put_config_regulators(int token)

Right?

BR,
Primoz