* [PATCH v2] pwm: meson: Remove error print for devm_add_action_or_reset() @ 2025-08-05 9:33 Waqar Hameed 2025-08-05 13:23 ` Uwe Kleine-König 0 siblings, 1 reply; 3+ messages in thread From: Waqar Hameed @ 2025-08-05 9:33 UTC (permalink / raw) To: Uwe Kleine-König, Neil Armstrong, Kevin Hilman, Jerome Brunet, Martin Blumenstingl Cc: kernel, linux-pwm, linux-arm-kernel, linux-amlogic, linux-kernel When `devm_add_action_or_reset()` fails, it is due to a failed memory allocation and will thus return `-ENOMEM`. `dev_err_probe()` doesn't do anything when error is `-ENOMEM`. Therefore, remove the useless call to `dev_err_probe()` when `devm_add_action_or_reset()` fails, and just return the value instead. Signed-off-by: Waqar Hameed <waqar.hameed@axis.com> --- Changes in v2: * Split the patch to one seperate patch for each sub-system. Link to v1: https://lore.kernel.org/all/pnd7c0s6ji2.fsf@axis.com/ drivers/pwm/pwm-meson.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/drivers/pwm/pwm-meson.c b/drivers/pwm/pwm-meson.c index 8c6bf3d49753..e90d37d4f956 100644 --- a/drivers/pwm/pwm-meson.c +++ b/drivers/pwm/pwm-meson.c @@ -520,8 +520,7 @@ static int meson_pwm_init_channels_s4(struct pwm_chip *chip) ret = devm_add_action_or_reset(dev, meson_pwm_s4_put_clk, meson->channels[i].clk); if (ret) - return dev_err_probe(dev, ret, - "Failed to add clk_put action\n"); + return ret; } return 0; base-commit: 260f6f4fda93c8485c8037865c941b42b9cba5d2 -- 2.39.5 ^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH v2] pwm: meson: Remove error print for devm_add_action_or_reset() 2025-08-05 9:33 [PATCH v2] pwm: meson: Remove error print for devm_add_action_or_reset() Waqar Hameed @ 2025-08-05 13:23 ` Uwe Kleine-König 2025-08-05 14:00 ` Waqar Hameed 0 siblings, 1 reply; 3+ messages in thread From: Uwe Kleine-König @ 2025-08-05 13:23 UTC (permalink / raw) To: Waqar Hameed Cc: Neil Armstrong, Kevin Hilman, Jerome Brunet, Martin Blumenstingl, kernel, linux-pwm, linux-arm-kernel, linux-amlogic, linux-kernel [-- Attachment #1: Type: text/plain, Size: 2544 bytes --] Hello Waqar, On Tue, Aug 05, 2025 at 11:33:36AM +0200, Waqar Hameed wrote: > When `devm_add_action_or_reset()` fails, it is due to a failed memory > allocation and will thus return `-ENOMEM`. `dev_err_probe()` doesn't do > anything when error is `-ENOMEM`. Therefore, remove the useless call to > `dev_err_probe()` when `devm_add_action_or_reset()` fails, and just > return the value instead. > > Signed-off-by: Waqar Hameed <waqar.hameed@axis.com> > --- > Changes in v2: > > * Split the patch to one seperate patch for each sub-system. > > Link to v1: https://lore.kernel.org/all/pnd7c0s6ji2.fsf@axis.com/ > > drivers/pwm/pwm-meson.c | 3 +-- > 1 file changed, 1 insertion(+), 2 deletions(-) > > diff --git a/drivers/pwm/pwm-meson.c b/drivers/pwm/pwm-meson.c > index 8c6bf3d49753..e90d37d4f956 100644 > --- a/drivers/pwm/pwm-meson.c > +++ b/drivers/pwm/pwm-meson.c > @@ -520,8 +520,7 @@ static int meson_pwm_init_channels_s4(struct pwm_chip *chip) > ret = devm_add_action_or_reset(dev, meson_pwm_s4_put_clk, > meson->channels[i].clk); > if (ret) > - return dev_err_probe(dev, ret, > - "Failed to add clk_put action\n"); > + return ret; On the other hand the call to dev_err_probe() also doesn't hurt, right? And when we keep it, it is clear that this error path is correctly handled without having to know that devm_add_action_or_reset() can only return success or -ENOMEM and we don't have to watch devm_add_action_or_reset() to not grow something like diff --git a/include/linux/device/devres.h b/include/linux/device/devres.h index ae696d10faff..0876cce68776 100644 --- a/include/linux/device/devres.h +++ b/include/linux/device/devres.h @@ -156,6 +156,9 @@ static inline int __devm_add_action_or_reset(struct device *dev, void (*action)( { int ret; + if (IS_ERR_OR_NULL(dev)) + return -EINVAL; + ret = __devm_add_action(dev, action, data, name); if (ret) action(data); From a subsystem maintainer's POV it would be great if it was easy to notice if a given function needs an error message or not. One excellent way to cover functions that can only return -ENOMEM on failure is to optimize out the small overhead of the devm_add_action_or_reset() call. See https://lore.kernel.org/all/ylr7cuxldwb24ccenen4khtyddzq3owgzzfblbohkdxb7p7eeo@qpuddn6wrz3x/ for a prototype of what I imagine. Oh, you were the addressee of that mail, so you already know. To make my position here explicit: This is a nack. Best regards Uwe [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 488 bytes --] ^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH v2] pwm: meson: Remove error print for devm_add_action_or_reset() 2025-08-05 13:23 ` Uwe Kleine-König @ 2025-08-05 14:00 ` Waqar Hameed 0 siblings, 0 replies; 3+ messages in thread From: Waqar Hameed @ 2025-08-05 14:00 UTC (permalink / raw) To: Uwe Kleine-König Cc: Neil Armstrong, Kevin Hilman, Jerome Brunet, Martin Blumenstingl, kernel, linux-pwm, linux-arm-kernel, linux-amlogic, linux-kernel On Tue, Aug 05, 2025 at 15:23 +0200 Uwe Kleine-König <ukleinek@kernel.org> wrote: > Hello Waqar, > > On Tue, Aug 05, 2025 at 11:33:36AM +0200, Waqar Hameed wrote: >> When `devm_add_action_or_reset()` fails, it is due to a failed memory >> allocation and will thus return `-ENOMEM`. `dev_err_probe()` doesn't do >> anything when error is `-ENOMEM`. Therefore, remove the useless call to >> `dev_err_probe()` when `devm_add_action_or_reset()` fails, and just >> return the value instead. >> >> Signed-off-by: Waqar Hameed <waqar.hameed@axis.com> >> --- >> Changes in v2: >> >> * Split the patch to one seperate patch for each sub-system. >> >> Link to v1: https://lore.kernel.org/all/pnd7c0s6ji2.fsf@axis.com/ >> >> drivers/pwm/pwm-meson.c | 3 +-- >> 1 file changed, 1 insertion(+), 2 deletions(-) >> >> diff --git a/drivers/pwm/pwm-meson.c b/drivers/pwm/pwm-meson.c >> index 8c6bf3d49753..e90d37d4f956 100644 >> --- a/drivers/pwm/pwm-meson.c >> +++ b/drivers/pwm/pwm-meson.c >> @@ -520,8 +520,7 @@ static int meson_pwm_init_channels_s4(struct pwm_chip *chip) >> ret = devm_add_action_or_reset(dev, meson_pwm_s4_put_clk, >> meson->channels[i].clk); >> if (ret) >> - return dev_err_probe(dev, ret, >> - "Failed to add clk_put action\n"); >> + return ret; > > On the other hand the call to dev_err_probe() also doesn't hurt, right? > And when we keep it, it is clear that this error path is correctly > handled without having to know that devm_add_action_or_reset() can only > return success or -ENOMEM and we don't have to watch > devm_add_action_or_reset() to not grow something like > > diff --git a/include/linux/device/devres.h b/include/linux/device/devres.h > index ae696d10faff..0876cce68776 100644 > --- a/include/linux/device/devres.h > +++ b/include/linux/device/devres.h > @@ -156,6 +156,9 @@ static inline int __devm_add_action_or_reset(struct device *dev, void (*action)( > { > int ret; > > + if (IS_ERR_OR_NULL(dev)) > + return -EINVAL; > + > ret = __devm_add_action(dev, action, data, name); > if (ret) > action(data); > > From a subsystem maintainer's POV it would be great if it was easy to > notice if a given function needs an error message or not. One excellent > way to cover functions that can only return -ENOMEM on failure is to > optimize out the small overhead of the devm_add_action_or_reset() call. > > See > https://lore.kernel.org/all/ylr7cuxldwb24ccenen4khtyddzq3owgzzfblbohkdxb7p7eeo@qpuddn6wrz3x/ > for a prototype of what I imagine. Oh, you were the addressee of that > mail, so you already know. > > To make my position here explicit: This is a nack. I fully understand your point and agree that there should not be a mental burden of knowing the exact return values from a function. That should be handled automatically, e.g. by the compiler or other tools. There was no real consensus in the previous thread (Jonathan Cameron even CC:ed some checkpatch-people to get some input for automatic detection from tools, but with no response). I hope that we can have some good way of solving these in the future, because this currently doesn't scale well and I'm fairly sure another driver in the future will hit this exact situation again... ^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2025-08-05 14:01 UTC | newest] Thread overview: 3+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2025-08-05 9:33 [PATCH v2] pwm: meson: Remove error print for devm_add_action_or_reset() Waqar Hameed 2025-08-05 13:23 ` Uwe Kleine-König 2025-08-05 14:00 ` Waqar Hameed
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox