From: "Kurt Borja" <kuurtb@gmail.com>
To: "Jonathan Cameron" <jic23@kernel.org>, "Kurt Borja" <kuurtb@gmail.com>
Cc: "David Lechner" <dlechner@baylibre.com>,
"Andy Shevchenko" <andriy.shevchenko@intel.com>,
"Rob Herring" <robh@kernel.org>,
"Krzysztof Kozlowski" <krzk+dt@kernel.org>,
"Conor Dooley" <conor+dt@kernel.org>,
"Tobias Sperling" <tobias.sperling@softing.com>,
"Nuno Sá" <nuno.sa@analog.com>,
"Andy Shevchenko" <andy@kernel.org>,
linux-iio@vger.kernel.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org,
"Jonathan Cameron" <Jonathan.Cameron@huawei.com>
Subject: Re: [PATCH v3 2/2] iio: adc: Add ti-ads1018 driver
Date: Sun, 07 Dec 2025 11:01:41 -0500 [thread overview]
Message-ID: <DES3ZMFGDP6A.2LQ1WHH17P7JS@gmail.com> (raw)
In-Reply-To: <20251206192750.03469a87@jic23-huawei>
On Sat Dec 6, 2025 at 2:27 PM -05, Jonathan Cameron wrote:
> On Tue, 02 Dec 2025 09:46:37 -0500
> "Kurt Borja" <kuurtb@gmail.com> wrote:
>
>> On Mon Dec 1, 2025 at 4:53 PM -05, David Lechner wrote:
>> > On 12/1/25 1:47 PM, Kurt Borja wrote:
>> >> On Mon Dec 1, 2025 at 11:07 AM -05, David Lechner wrote:
>> >>
>> >> ...
>> >>
>> >>>>>> + if (iio_device_claim_buffer_mode(indio_dev))
>> >>>>>> + goto out_notify_done;
>> >>>>>> +
>> >>>>>> + if (iio_trigger_using_own(indio_dev)) {
>> >>>>>> + disable_irq(ads1018->drdy_irq);
>> >>>>>> + ret = ads1018_read_unlocked(ads1018, &scan.conv, true);
>> >>>>>> + enable_irq(ads1018->drdy_irq);
>> >>>>>> + } else {
>> >>>>>> + ret = spi_read(ads1018->spi, ads1018->rx_buf, sizeof(ads1018->rx_buf));
>> >>>>>> + scan.conv = ads1018->rx_buf[0];
>> >>>>>> + }
>> >>>>>> +
>> >>>>>> + iio_device_release_buffer_mode(indio_dev);
>> >>>>>> +
>> >>>>>> + if (ret)
>> >>>>>> + goto out_notify_done;
>> >>>>>> +
>> >>>>>> + iio_push_to_buffers_with_ts(indio_dev, &scan, sizeof(scan), pf->timestamp);
>> >>>>>> +
>> >>>>>> +out_notify_done:
>> >>>>>> + iio_trigger_notify_done(ads1018->indio_trig);
>> >>>>>
>> >>>>> Jonathan et al., maybe we need an ACQUIRE() class for this? It will solve
>> >>>>> the conditional scoped guard case, no?
>> >>>
>> >>> No, ACQUIRE() is not scoped, just conditional. I don't think it
>> >>> will improve anything here.
>> >>
>> >> Maybe I'm not understanding the problem fully?
>> >>
>> >> I interpreted "ACQUIRE() class" as a general GUARD class, i.e.
>> >>
>> >> guard(iio_trigger_notify)(indio_dev->trig);
>> >>
>> >> This way drivers may use other cleanup.h helpers cleaner, because of the
>> >> goto problem?
>> >>
>> >> I do think it's a good idea, like a `defer` keyword. But it is a bit
>> >> unorthodox using guard for non locks.
>
> Agreed. This one is weird if called guard().
>
> I'd not be against a defer() if it existed, but my guess is Linus Torvalds
> will just say this is too weird and helper function for everything before
> the unconditional cleanup is the way to go.
>
> People did mess around with __free() for cases like this but that is very
> ugly given no 'constructor' occurred so mostly those got rejected I think.
Makes sense.
Isn't there a "defer" proposal to the language spec? I think I came
across something like that in the past. I really hope this is the case.
>
>> >>
>> >>
>> >
>> > To take a simple example first:
>> >
>> > static int
>> > ads1018_read_raw(struct iio_dev *indio_dev, struct iio_chan_spec const *chan,
>> > int *val, int *val2, long mask)
>> > {
>> > int ret;
>> >
>> > if (!iio_device_claim_direct(indio_dev))
>> > return -EBUSY;
>> >
>> > ret = ads1018_read_raw_unlocked(indio_dev, chan, val, val2, mask);
>> >
>> > iio_device_release_direct(indio_dev);
>> >
>> > return ret;
>> > }
>> >
>> > using ACQUIRE would look like:
>> >
>> > static int
>> > ads1018_read_raw(struct iio_dev *indio_dev, struct iio_chan_spec const *chan,
>> > int *val, int *val2, long mask)
>> > {
>> > int ret;
>> >
>> > ACQUIRE(iio_device_claim_direct_mode, claim)(indio_dev);
>> > if ((ret = ACQUIRE_ERR(iio_device_claim_direct_mode, &claim)))
>> > return ret;
>> >
>> > return ads1018_read_raw_unlocked(indio_dev, chan, val, val2, mask);
>> > }
>> >
>> > It makes it quite more verbose IMHO with little benefit (the direct
>> > return is nice, but comes at at an expense of the rest being less
>> > readable).
>>
>> This is verbose yes, but we could avoid having two functions in the
>> first place and implement everything inside ads1018_read_raw() with
>> ACQUIRE(...) on top.
>
> Agreed - there are places where this makes sense but I'm not keen
> on lots of churn to inject it in places where we already have
> the two function approach.
I agree.
>
>>
>> >
>> >
>> >
>> > And when we need it to be scoped, it adds indent and we have to do
>> > some unusual things still to avoid using goto.
>> >
>> > static irqreturn_t ads1018_trigger_handler(int irq, void *p)
>> > {
>> > struct iio_poll_func *pf = p;
>> > struct iio_dev *indio_dev = pf->indio_dev;
>> > struct ads1018 *ads1018 = iio_priv(indio_dev);
>> > struct {
>> > __be16 conv;
>> > aligned_s64 ts;
>> > } scan = {};
>> > int ret;
>> >
>> > do {
>> > ACQUIRE(iio_device_claim_direct_mode, claim)(indio_dev);
>> > if ((ret = ACQUIRE_ERR(iio_device_claim_direct_mode, &claim)))
>> > break;
>> >
>> > if (iio_trigger_using_own(indio_dev)) {
>> > disable_irq(ads1018->drdy_irq);
>> > ret = ads1018_read_unlocked(ads1018, &scan.conv, true);
>> > enable_irq(ads1018->drdy_irq);
>> > } else {
>> > ret = spi_read(ads1018->spi, ads1018->rx_buf, sizeof(ads1018->rx_buf));
>> > scan.conv = ads1018->rx_buf[0];
>> > }
>> > } while (0);
>>
>> Here we could use scoped_cond_guard() instead, no?
> Just in case this comes back. Please no!
>
> scoped_cond_guard() manages to thoroughly confuse compilers.
> It got so bad when we tried that originally I went back and reverted
> all use of that in IIO.
That's good to know!
>
> Thanks and very wise to not yet use it in here as that discussion
> may take some time given there is naming involved ;)
Glad I can help :)
>
> Jonathan
>
--
~ Kurt
next prev parent reply other threads:[~2025-12-07 16:01 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-11-29 3:47 [PATCH v3 0/2] iio: Add support for TI ADS1X18 ADCs Kurt Borja
2025-11-29 3:47 ` [PATCH v3 1/2] dt-bindings: iio: adc: Add TI ADS1018/ADS1118 Kurt Borja
2025-11-29 9:25 ` Krzysztof Kozlowski
2025-11-30 3:32 ` Kurt Borja
2025-11-29 3:47 ` [PATCH v3 2/2] iio: adc: Add ti-ads1018 driver Kurt Borja
2025-11-29 14:21 ` Andy Shevchenko
2025-11-29 14:23 ` Andy Shevchenko
2025-11-30 3:31 ` Kurt Borja
2025-11-30 16:45 ` Andy Shevchenko
2025-12-01 16:07 ` David Lechner
2025-12-01 19:47 ` Kurt Borja
2025-12-01 21:53 ` David Lechner
2025-12-02 14:46 ` Kurt Borja
2025-12-06 19:27 ` Jonathan Cameron
2025-12-07 16:01 ` Kurt Borja [this message]
2025-11-29 17:08 ` kernel test robot
2025-12-01 23:09 ` David Lechner
2025-12-02 14:39 ` Kurt Borja
2025-12-02 14:59 ` Andy Shevchenko
2025-12-02 17:49 ` Kurt Borja
2025-12-02 18:04 ` Andy Shevchenko
2025-12-02 16:52 ` Kurt Borja
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=DES3ZMFGDP6A.2LQ1WHH17P7JS@gmail.com \
--to=kuurtb@gmail.com \
--cc=Jonathan.Cameron@huawei.com \
--cc=andriy.shevchenko@intel.com \
--cc=andy@kernel.org \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=dlechner@baylibre.com \
--cc=jic23@kernel.org \
--cc=krzk+dt@kernel.org \
--cc=linux-iio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=nuno.sa@analog.com \
--cc=robh@kernel.org \
--cc=tobias.sperling@softing.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.