* [PATCH v3 0/2] iio: light: gp2ap020a00f: fix return type and simplify locking
@ 2026-02-16 0:53 Ethan Tidmore
2026-02-16 0:53 ` [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard() Ethan Tidmore
2026-02-16 0:53 ` [PATCH v3 2/2] iio: light: gp2ap020a00f: correct return type to int Ethan Tidmore
0 siblings, 2 replies; 12+ messages in thread
From: Ethan Tidmore @ 2026-02-16 0:53 UTC (permalink / raw)
To: jic23; +Cc: dlechner, nuno.sa, andy, linux-iio, linux-kernel, Ethan Tidmore
Patch 1 is a cleanup that simplifies the locking mechanisms using
guard(), as suggested by Jonathan Cameron. This removes the need
for goto error paths, making the subsequent fix cleaner.
Patch 2 changes the return type of the helper function to int and
adds the necessary error checks in the callers.
Ethan Tidmore (2):
iio: light: gp2ap020a00f: simplify locking with guard()
iio: light: gp2ap020a00f: correct return type to int
drivers/iio/light/gp2ap020a00f.c | 77 ++++++++++++--------------------
1 file changed, 29 insertions(+), 48 deletions(-)
--
2.53.0
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard()
2026-02-16 0:53 [PATCH v3 0/2] iio: light: gp2ap020a00f: fix return type and simplify locking Ethan Tidmore
@ 2026-02-16 0:53 ` Ethan Tidmore
2026-02-16 7:08 ` Andy Shevchenko
2026-02-16 0:53 ` [PATCH v3 2/2] iio: light: gp2ap020a00f: correct return type to int Ethan Tidmore
1 sibling, 1 reply; 12+ messages in thread
From: Ethan Tidmore @ 2026-02-16 0:53 UTC (permalink / raw)
To: jic23; +Cc: dlechner, nuno.sa, andy, linux-iio, linux-kernel, Ethan Tidmore
Use the guard() cleanup handler to manage the device lock.
This simplifies the code by removing the need for manual unlocking
and goto error handling paths.
Suggested-by: Jonathan Cameron <jic23@kernel.org>
Signed-off-by: Ethan Tidmore <ethantidmore06@gmail.com>
---
v3:
- Use guard() instead of manual locking and unlocking.
drivers/iio/light/gp2ap020a00f.c | 64 ++++++++++----------------------
1 file changed, 20 insertions(+), 44 deletions(-)
diff --git a/drivers/iio/light/gp2ap020a00f.c b/drivers/iio/light/gp2ap020a00f.c
index c7df4b258e2c..d1a511ac7690 100644
--- a/drivers/iio/light/gp2ap020a00f.c
+++ b/drivers/iio/light/gp2ap020a00f.c
@@ -31,6 +31,7 @@
* the other one.
*/
+#include <linux/cleanup.h>
#include <linux/debugfs.h>
#include <linux/delay.h>
#include <linux/i2c.h>
@@ -1024,17 +1025,14 @@ static int gp2ap020a00f_write_event_val(struct iio_dev *indio_dev,
bool event_en = false;
u8 thresh_val_id;
u8 thresh_reg_l;
- int err = 0;
- mutex_lock(&data->lock);
+ guard(mutex)(&data->lock);
thresh_reg_l = gp2ap020a00f_get_thresh_reg(chan, dir);
thresh_val_id = GP2AP020A00F_THRESH_VAL_ID(thresh_reg_l);
- if (thresh_val_id > GP2AP020A00F_THRESH_PH) {
- err = -EINVAL;
- goto error_unlock;
- }
+ if (thresh_val_id > GP2AP020A00F_THRESH_PH)
+ return -EINVAL;
switch (thresh_reg_l) {
case GP2AP020A00F_TH_L_REG:
@@ -1046,30 +1044,23 @@ static int gp2ap020a00f_write_event_val(struct iio_dev *indio_dev,
&data->flags);
break;
case GP2AP020A00F_PH_L_REG:
- if (val == 0) {
- err = -EINVAL;
- goto error_unlock;
- }
+ if (val == 0)
+ return -EINVAL;
+
event_en = test_bit(GP2AP020A00F_FLAG_PROX_RISING_EV,
&data->flags);
break;
case GP2AP020A00F_PL_L_REG:
- if (val == 0) {
- err = -EINVAL;
- goto error_unlock;
- }
+ if (val == 0)
+ return -EINVAL;
+
event_en = test_bit(GP2AP020A00F_FLAG_PROX_FALLING_EV,
&data->flags);
break;
}
data->thresh_val[thresh_val_id] = val;
- err = gp2ap020a00f_write_event_threshold(data, thresh_val_id,
- event_en);
-error_unlock:
- mutex_unlock(&data->lock);
-
- return err;
+ return gp2ap020a00f_write_event_threshold(data, thresh_val_id, event_en);
}
static int gp2ap020a00f_read_event_val(struct iio_dev *indio_dev,
@@ -1081,23 +1072,17 @@ static int gp2ap020a00f_read_event_val(struct iio_dev *indio_dev,
{
struct gp2ap020a00f_data *data = iio_priv(indio_dev);
u8 thresh_reg_l;
- int err = IIO_VAL_INT;
- mutex_lock(&data->lock);
+ guard(mutex)(&data->lock);
thresh_reg_l = gp2ap020a00f_get_thresh_reg(chan, dir);
- if (thresh_reg_l > GP2AP020A00F_PH_L_REG) {
- err = -EINVAL;
- goto error_unlock;
- }
+ if (thresh_reg_l > GP2AP020A00F_PH_L_REG)
+ return -EINVAL;
*val = data->thresh_val[GP2AP020A00F_THRESH_VAL_ID(thresh_reg_l)];
-error_unlock:
- mutex_unlock(&data->lock);
-
- return err;
+ return IIO_VAL_INT;
}
static int gp2ap020a00f_write_prox_event_config(struct iio_dev *indio_dev,
@@ -1165,7 +1150,7 @@ static int gp2ap020a00f_write_event_config(struct iio_dev *indio_dev,
enum gp2ap020a00f_cmd cmd;
int err;
- mutex_lock(&data->lock);
+ guard(mutex)(&data->lock);
switch (chan->type) {
case IIO_PROXIMITY:
@@ -1186,8 +1171,6 @@ static int gp2ap020a00f_write_event_config(struct iio_dev *indio_dev,
err = -EINVAL;
}
- mutex_unlock(&data->lock);
-
return err;
}
@@ -1199,7 +1182,7 @@ static int gp2ap020a00f_read_event_config(struct iio_dev *indio_dev,
struct gp2ap020a00f_data *data = iio_priv(indio_dev);
int event_en = 0;
- mutex_lock(&data->lock);
+ guard(mutex)(&data->lock);
switch (chan->type) {
case IIO_PROXIMITY:
@@ -1223,8 +1206,6 @@ static int gp2ap020a00f_read_event_config(struct iio_dev *indio_dev,
break;
}
- mutex_unlock(&data->lock);
-
return event_en;
}
@@ -1385,7 +1366,7 @@ static int gp2ap020a00f_buffer_postenable(struct iio_dev *indio_dev)
struct gp2ap020a00f_data *data = iio_priv(indio_dev);
int i, err = 0;
- mutex_lock(&data->lock);
+ guard(mutex)(&data->lock);
/*
* Enable triggers according to the scan_mask. Enabling either
@@ -1413,15 +1394,12 @@ static int gp2ap020a00f_buffer_postenable(struct iio_dev *indio_dev)
}
if (err < 0)
- goto error_unlock;
+ return err;
data->buffer = kmalloc(indio_dev->scan_bytes, GFP_KERNEL);
if (!data->buffer)
err = -ENOMEM;
-error_unlock:
- mutex_unlock(&data->lock);
-
return err;
}
@@ -1430,7 +1408,7 @@ static int gp2ap020a00f_buffer_predisable(struct iio_dev *indio_dev)
struct gp2ap020a00f_data *data = iio_priv(indio_dev);
int i, err = 0;
- mutex_lock(&data->lock);
+ guard(mutex)(&data->lock);
iio_for_each_active_channel(indio_dev, i) {
switch (i) {
@@ -1452,8 +1430,6 @@ static int gp2ap020a00f_buffer_predisable(struct iio_dev *indio_dev)
if (err == 0)
kfree(data->buffer);
- mutex_unlock(&data->lock);
-
return err;
}
--
2.53.0
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH v3 2/2] iio: light: gp2ap020a00f: correct return type to int
2026-02-16 0:53 [PATCH v3 0/2] iio: light: gp2ap020a00f: fix return type and simplify locking Ethan Tidmore
2026-02-16 0:53 ` [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard() Ethan Tidmore
@ 2026-02-16 0:53 ` Ethan Tidmore
2026-02-16 7:10 ` Andy Shevchenko
1 sibling, 1 reply; 12+ messages in thread
From: Ethan Tidmore @ 2026-02-16 0:53 UTC (permalink / raw)
To: jic23; +Cc: dlechner, nuno.sa, andy, linux-iio, linux-kernel, Ethan Tidmore
The function gp2ap020a00f_get_thresh_reg() can return -EINVAL in its
error path. Yet, the function has return type of u8. Added error
checking for gp2ap020a00f_get_thresh_reg() return value.
Detected by Smatch:
drivers/iio/light/gp2ap020a00f.c:1013 gp2ap020a00f_get_thresh_reg() warn:
signedness bug returning '(-22)'
Signed-off-by: Ethan Tidmore <ethantidmore06@gmail.com>
---
v3:
- Remove Fixes: tag.
- Added Smatch warning.
v2:
- Fixed gp2ap020a00f_get_thresh_reg() parameter alignment.
- Removed unneeded whitespace between assignment and check.
drivers/iio/light/gp2ap020a00f.c | 13 +++++++++----
1 file changed, 9 insertions(+), 4 deletions(-)
diff --git a/drivers/iio/light/gp2ap020a00f.c b/drivers/iio/light/gp2ap020a00f.c
index d1a511ac7690..fae7605f2f5c 100644
--- a/drivers/iio/light/gp2ap020a00f.c
+++ b/drivers/iio/light/gp2ap020a00f.c
@@ -993,8 +993,8 @@ static irqreturn_t gp2ap020a00f_trigger_handler(int irq, void *data)
return IRQ_HANDLED;
}
-static u8 gp2ap020a00f_get_thresh_reg(const struct iio_chan_spec *chan,
- enum iio_event_direction event_dir)
+static int gp2ap020a00f_get_thresh_reg(const struct iio_chan_spec *chan,
+ enum iio_event_direction event_dir)
{
switch (chan->type) {
case IIO_PROXIMITY:
@@ -1024,11 +1024,14 @@ static int gp2ap020a00f_write_event_val(struct iio_dev *indio_dev,
struct gp2ap020a00f_data *data = iio_priv(indio_dev);
bool event_en = false;
u8 thresh_val_id;
- u8 thresh_reg_l;
+ int thresh_reg_l;
guard(mutex)(&data->lock);
thresh_reg_l = gp2ap020a00f_get_thresh_reg(chan, dir);
+ if (thresh_reg_l < 0)
+ return thresh_reg_l;
+
thresh_val_id = GP2AP020A00F_THRESH_VAL_ID(thresh_reg_l);
if (thresh_val_id > GP2AP020A00F_THRESH_PH)
@@ -1071,11 +1074,13 @@ static int gp2ap020a00f_read_event_val(struct iio_dev *indio_dev,
int *val, int *val2)
{
struct gp2ap020a00f_data *data = iio_priv(indio_dev);
- u8 thresh_reg_l;
+ int thresh_reg_l;
guard(mutex)(&data->lock);
thresh_reg_l = gp2ap020a00f_get_thresh_reg(chan, dir);
+ if (thresh_reg_l < 0)
+ return thresh_reg_l;
if (thresh_reg_l > GP2AP020A00F_PH_L_REG)
return -EINVAL;
--
2.53.0
^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard()
2026-02-16 0:53 ` [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard() Ethan Tidmore
@ 2026-02-16 7:08 ` Andy Shevchenko
2026-02-16 21:04 ` Ethan Tidmore
0 siblings, 1 reply; 12+ messages in thread
From: Andy Shevchenko @ 2026-02-16 7:08 UTC (permalink / raw)
To: Ethan Tidmore; +Cc: jic23, dlechner, nuno.sa, andy, linux-iio, linux-kernel
On Sun, Feb 15, 2026 at 06:53:16PM -0600, Ethan Tidmore wrote:
> Use the guard() cleanup handler to manage the device lock.
> This simplifies the code by removing the need for manual unlocking
> and goto error handling paths.
...
> thresh_reg_l = gp2ap020a00f_get_thresh_reg(chan, dir);
> thresh_val_id = GP2AP020A00F_THRESH_VAL_ID(thresh_reg_l);
>
Also drop this blank line, it will be aligned with the similar style in the
next patch.
> - if (thresh_val_id > GP2AP020A00F_THRESH_PH) {
> - err = -EINVAL;
> - goto error_unlock;
> - }
> + if (thresh_val_id > GP2AP020A00F_THRESH_PH)
> + return -EINVAL;
...
> thresh_reg_l = gp2ap020a00f_get_thresh_reg(chan, dir);
>
Ditto.
> - if (thresh_reg_l > GP2AP020A00F_PH_L_REG) {
> - err = -EINVAL;
> - goto error_unlock;
> - }
> + if (thresh_reg_l > GP2AP020A00F_PH_L_REG)
> + return -EINVAL;
...
> data->buffer = kmalloc(indio_dev->scan_bytes, GFP_KERNEL);
> if (!data->buffer)
> err = -ENOMEM;
Now simply
return -ENOMEM;
> -error_unlock:
> - mutex_unlock(&data->lock);
> -
> return err;
And with the above I believe this becomes
return 0;
> }
...
> struct gp2ap020a00f_data *data = iio_priv(indio_dev);
> int i, err = 0;
Would you need the err assignment now?
> - mutex_lock(&data->lock);
> + guard(mutex)(&data->lock);
>
> iio_for_each_active_channel(indio_dev, i) {
> switch (i) {
...
> if (err == 0)
> kfree(data->buffer);
With the guard()() in place this can be inverted to have something
(I haven't seen the full context, though) like
if (err)
return err;
kfree(...);
> - mutex_unlock(&data->lock);
> -
> return err;
Ideally this should become
return 0;
--
With Best Regards,
Andy Shevchenko
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v3 2/2] iio: light: gp2ap020a00f: correct return type to int
2026-02-16 0:53 ` [PATCH v3 2/2] iio: light: gp2ap020a00f: correct return type to int Ethan Tidmore
@ 2026-02-16 7:10 ` Andy Shevchenko
0 siblings, 0 replies; 12+ messages in thread
From: Andy Shevchenko @ 2026-02-16 7:10 UTC (permalink / raw)
To: Ethan Tidmore; +Cc: jic23, dlechner, nuno.sa, andy, linux-iio, linux-kernel
On Sun, Feb 15, 2026 at 06:53:17PM -0600, Ethan Tidmore wrote:
> The function gp2ap020a00f_get_thresh_reg() can return -EINVAL in its
> error path. Yet, the function has return type of u8. Added error
> checking for gp2ap020a00f_get_thresh_reg() return value.
>
> Detected by Smatch:
> drivers/iio/light/gp2ap020a00f.c:1013 gp2ap020a00f_get_thresh_reg() warn:
> signedness bug returning '(-22)'
LGTM now,
Reviewed-by: Andy Shevchenko <andriy.shevchenko@intel.com>
--
With Best Regards,
Andy Shevchenko
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard()
2026-02-16 7:08 ` Andy Shevchenko
@ 2026-02-16 21:04 ` Ethan Tidmore
2026-02-17 8:37 ` Andy Shevchenko
0 siblings, 1 reply; 12+ messages in thread
From: Ethan Tidmore @ 2026-02-16 21:04 UTC (permalink / raw)
To: Andy Shevchenko, Ethan Tidmore
Cc: jic23, dlechner, nuno.sa, andy, linux-iio, linux-kernel
On Mon Feb 16, 2026 at 1:08 AM CST, Andy Shevchenko wrote:
> On Sun, Feb 15, 2026 at 06:53:16PM -0600, Ethan Tidmore wrote:
>
>> struct gp2ap020a00f_data *data = iio_priv(indio_dev);
>> int i, err = 0;
>
> Would you need the err assignment now?
I'm not familiar with iio_for_each_active_channel() but, if there's a
chance it could run zero times, then it'd run into if (err) with err
not being initialized?
Thanks,
ET
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard()
2026-02-16 21:04 ` Ethan Tidmore
@ 2026-02-17 8:37 ` Andy Shevchenko
2026-02-17 9:02 ` Ethan Tidmore
2026-02-17 9:03 ` Andy Shevchenko
0 siblings, 2 replies; 12+ messages in thread
From: Andy Shevchenko @ 2026-02-17 8:37 UTC (permalink / raw)
To: Ethan Tidmore; +Cc: jic23, dlechner, nuno.sa, andy, linux-iio, linux-kernel
On Mon, Feb 16, 2026 at 03:04:55PM -0600, Ethan Tidmore wrote:
> On Mon Feb 16, 2026 at 1:08 AM CST, Andy Shevchenko wrote:
> > On Sun, Feb 15, 2026 at 06:53:16PM -0600, Ethan Tidmore wrote:
...
> >> int i, err = 0;
> >
> > Would you need the err assignment now?
>
> I'm not familiar with iio_for_each_active_channel() but, if there's a
> chance it could run zero times, then it'd run into if (err) with err
> not being initialized?
Have you read my other comments? I also mentioned to replace
err = -ENOMEM;
with
return -ENOMEM;
--
With Best Regards,
Andy Shevchenko
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard()
2026-02-17 8:37 ` Andy Shevchenko
@ 2026-02-17 9:02 ` Ethan Tidmore
2026-02-17 9:12 ` Andy Shevchenko
2026-02-17 9:03 ` Andy Shevchenko
1 sibling, 1 reply; 12+ messages in thread
From: Ethan Tidmore @ 2026-02-17 9:02 UTC (permalink / raw)
To: Andy Shevchenko, Ethan Tidmore
Cc: jic23, dlechner, nuno.sa, andy, linux-iio, linux-kernel
On Tue Feb 17, 2026 at 2:37 AM CST, Andy Shevchenko wrote:
> On Mon, Feb 16, 2026 at 03:04:55PM -0600, Ethan Tidmore wrote:
>> On Mon Feb 16, 2026 at 1:08 AM CST, Andy Shevchenko wrote:
>> > On Sun, Feb 15, 2026 at 06:53:16PM -0600, Ethan Tidmore wrote:
>
> ...
>
>> >> int i, err = 0;
>> >
>> > Would you need the err assignment now?
>>
>> I'm not familiar with iio_for_each_active_channel() but, if there's a
>> chance it could run zero times, then it'd run into if (err) with err
>> not being initialized?
>
> Have you read my other comments? I also mentioned to replace
>
> err = -ENOMEM;
>
> with
>
> return -ENOMEM;
Sorry about that, when you asked about the assignment, I thought you meant
the initialization (err = 0) vs just declaring it (int err), rather than
realizing the variable itself is redundant. Will send v4 shortly.
Thanks,
ET
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard()
2026-02-17 8:37 ` Andy Shevchenko
2026-02-17 9:02 ` Ethan Tidmore
@ 2026-02-17 9:03 ` Andy Shevchenko
2026-02-17 9:10 ` Ethan Tidmore
1 sibling, 1 reply; 12+ messages in thread
From: Andy Shevchenko @ 2026-02-17 9:03 UTC (permalink / raw)
To: Ethan Tidmore; +Cc: jic23, dlechner, nuno.sa, andy, linux-iio, linux-kernel
On Tue, Feb 17, 2026 at 10:37:18AM +0200, Andy Shevchenko wrote:
> On Mon, Feb 16, 2026 at 03:04:55PM -0600, Ethan Tidmore wrote:
> > On Mon Feb 16, 2026 at 1:08 AM CST, Andy Shevchenko wrote:
> > > On Sun, Feb 15, 2026 at 06:53:16PM -0600, Ethan Tidmore wrote:
...
> > >> int i, err = 0;
> > >
> > > Would you need the err assignment now?
> >
> > I'm not familiar with iio_for_each_active_channel() but, if there's a
> > chance it could run zero times, then it'd run into if (err) with err
> > not being initialized?
>
> Have you read my other comments? I also mentioned to replace
>
> err = -ENOMEM;
>
> with
>
> return -ENOMEM;
Looking into the driver code, it has some serious questions about the logic
behind. I will send soon a WIP series for you to take into account. Feel
free to integrate it into your next series.
...
Do you have HW to test?
--
With Best Regards,
Andy Shevchenko
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard()
2026-02-17 9:03 ` Andy Shevchenko
@ 2026-02-17 9:10 ` Ethan Tidmore
2026-02-17 10:23 ` Andy Shevchenko
0 siblings, 1 reply; 12+ messages in thread
From: Ethan Tidmore @ 2026-02-17 9:10 UTC (permalink / raw)
To: Andy Shevchenko, Ethan Tidmore
Cc: jic23, dlechner, nuno.sa, andy, linux-iio, linux-kernel
On Tue Feb 17, 2026 at 3:03 AM CST, Andy Shevchenko wrote:
> On Tue, Feb 17, 2026 at 10:37:18AM +0200, Andy Shevchenko wrote:
>> On Mon, Feb 16, 2026 at 03:04:55PM -0600, Ethan Tidmore wrote:
>> > On Mon Feb 16, 2026 at 1:08 AM CST, Andy Shevchenko wrote:
>> > > On Sun, Feb 15, 2026 at 06:53:16PM -0600, Ethan Tidmore wrote:
>
> ...
>
>> > >> int i, err = 0;
>> > >
>> > > Would you need the err assignment now?
>> >
>> > I'm not familiar with iio_for_each_active_channel() but, if there's a
>> > chance it could run zero times, then it'd run into if (err) with err
>> > not being initialized?
>>
>> Have you read my other comments? I also mentioned to replace
>>
>> err = -ENOMEM;
>>
>> with
>>
>> return -ENOMEM;
>
> Looking into the driver code, it has some serious questions about the logic
> behind. I will send soon a WIP series for you to take into account. Feel
> free to integrate it into your next series.
>
> ...
>
> Do you have HW to test?
Ignore my previous statement about sending v4 shortly now. No, I don't
have the HW, but I will be happy to integrate your series into this
cleanup.
Thanks,
ET
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard()
2026-02-17 9:02 ` Ethan Tidmore
@ 2026-02-17 9:12 ` Andy Shevchenko
0 siblings, 0 replies; 12+ messages in thread
From: Andy Shevchenko @ 2026-02-17 9:12 UTC (permalink / raw)
To: Ethan Tidmore; +Cc: jic23, dlechner, nuno.sa, andy, linux-iio, linux-kernel
On Tue, Feb 17, 2026 at 03:02:48AM -0600, Ethan Tidmore wrote:
> On Tue Feb 17, 2026 at 2:37 AM CST, Andy Shevchenko wrote:
> > On Mon, Feb 16, 2026 at 03:04:55PM -0600, Ethan Tidmore wrote:
> >> On Mon Feb 16, 2026 at 1:08 AM CST, Andy Shevchenko wrote:
> >> > On Sun, Feb 15, 2026 at 06:53:16PM -0600, Ethan Tidmore wrote:
...
> >> >> int i, err = 0;
> >> >
> >> > Would you need the err assignment now?
> >>
> >> I'm not familiar with iio_for_each_active_channel() but, if there's a
> >> chance it could run zero times, then it'd run into if (err) with err
> >> not being initialized?
> >
> > Have you read my other comments? I also mentioned to replace
> >
> > err = -ENOMEM;
> >
> > with
> >
> > return -ENOMEM;
>
> Sorry about that, when you asked about the assignment, I thought you meant
> the initialization (err = 0) vs just declaring it (int err), rather than
> realizing the variable itself is redundant. Will send v4 shortly.
Please, wait a bit. I will send what I have, you will see better what can be done.
But again, do you have an HW to test?
--
With Best Regards,
Andy Shevchenko
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard()
2026-02-17 9:10 ` Ethan Tidmore
@ 2026-02-17 10:23 ` Andy Shevchenko
0 siblings, 0 replies; 12+ messages in thread
From: Andy Shevchenko @ 2026-02-17 10:23 UTC (permalink / raw)
To: Ethan Tidmore; +Cc: jic23, dlechner, nuno.sa, andy, linux-iio, linux-kernel
On Tue, Feb 17, 2026 at 03:10:37AM -0600, Ethan Tidmore wrote:
> On Tue Feb 17, 2026 at 3:03 AM CST, Andy Shevchenko wrote:
> > On Tue, Feb 17, 2026 at 10:37:18AM +0200, Andy Shevchenko wrote:
...
> Ignore my previous statement about sending v4 shortly now. No, I don't
> have the HW, but I will be happy to integrate your series into this
> cleanup.
Just have sent it.
--
With Best Regards,
Andy Shevchenko
^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2026-02-17 10:24 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-02-16 0:53 [PATCH v3 0/2] iio: light: gp2ap020a00f: fix return type and simplify locking Ethan Tidmore
2026-02-16 0:53 ` [PATCH v3 1/2] iio: light: gp2ap020a00f: simplify locking with guard() Ethan Tidmore
2026-02-16 7:08 ` Andy Shevchenko
2026-02-16 21:04 ` Ethan Tidmore
2026-02-17 8:37 ` Andy Shevchenko
2026-02-17 9:02 ` Ethan Tidmore
2026-02-17 9:12 ` Andy Shevchenko
2026-02-17 9:03 ` Andy Shevchenko
2026-02-17 9:10 ` Ethan Tidmore
2026-02-17 10:23 ` Andy Shevchenko
2026-02-16 0:53 ` [PATCH v3 2/2] iio: light: gp2ap020a00f: correct return type to int Ethan Tidmore
2026-02-16 7:10 ` Andy Shevchenko
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox