Re: [PATCH v1 1/1] cpufreq: loongson: Check for error code from devm_mutex_init() call
From: Andy Shevchenko
Date: Thu Oct 31 2024 - 03:07:44 EST
On Thu, Oct 31, 2024 at 09:29:52AM +0800, Huacai Chen wrote:
> On Thu, Oct 31, 2024 at 12:29 AM Andy Shevchenko
> <andriy.shevchenko@xxxxxxxxxxxxxxx> wrote:
...
> > - for (i = 0; i < MAX_PACKAGES; i++)
> > - devm_mutex_init(&pdev->dev, &cpufreq_mutex[i]);
> > + for (i = 0; i < MAX_PACKAGES; i++) {
> > + ret = devm_mutex_init(&pdev->dev, &cpufreq_mutex[i]);
> > + if (ret)
> Good catch, but I think "if (ret < 0)" is better? Sometimes a positive
> return value is legal, even if not in this case.
I disagree on this.
During a tons of reviews I have done in the past this kind of check is
impediment and always rises the Q "why?" It means that the author hasn't
fully thought through the code and most likely done something is a cargo cult.
On top of that, if the callee is changed at some point to actually return
a positive code(s), the caller most likely has to be at least aware of that
change. The proposed modification makes this silently compile and hides
possible important details from the caller(s).
> And it is better to use loongson3 rather than loongson because there
> is another loongson2 driver.
Thanks, I will change that in v2 (I believe you are talking about Subject?).
> > + return ret;
> > + }
--
With Best Regards,
Andy Shevchenko