[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <036bd63f14707d9c99273e334ac21eb68b29ea4c.camel@analog.com>
Date: Fri, 22 May 2020 06:58:13 +0000
From: "Ardelean, Alexandru" <alexandru.Ardelean@...log.com>
To: "linux-arm-kernel@...ts.infradead.org"
<linux-arm-kernel@...ts.infradead.org>,
"linux-stm32@...md-mailman.stormreply.com"
<linux-stm32@...md-mailman.stormreply.com>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
"linux-iio@...r.kernel.org" <linux-iio@...r.kernel.org>
CC: "ludovic.desroches@...rochip.com" <ludovic.desroches@...rochip.com>,
"nicolas.ferre@...rochip.com" <nicolas.ferre@...rochip.com>,
"alexandre.torgue@...com" <alexandre.torgue@...com>,
"ak@...klinger.de" <ak@...klinger.de>,
"jic23@...nel.org" <jic23@...nel.org>,
"eugen.hristev@...rochip.com" <eugen.hristev@...rochip.com>,
"mcoquelin.stm32@...il.com" <mcoquelin.stm32@...il.com>,
"alexandre.belloni@...tlin.com" <alexandre.belloni@...tlin.com>
Subject: Re: [PATCH v2 0/8] iio: core: wrap IIO device into an iio_dev_opaque
object
On Thu, 2020-05-14 at 16:17 +0300, Alexandru Ardelean wrote:
> This change starts to hide some internal fields of the IIO device into
> the framework.
>
> Because the iio_priv_to_dev() will be hidden some pre-work is done to
> try to remove it from some interrupt handlers.
> iio_priv_to_dev() will become a function call and won't be expandable
> into place (as-is now as an inline function).
>
I'll defer this series.
A cleanup of iio_priv_to_dev() doesn't look like a bit detour.
> Changelog v1 -> v2:
> - add pre-work patches that remove some calls to iio_priv_to_dev() from
> interrupt handlers
> - renamed iio_dev_priv -> iio_dev_opaque
> - moved the iio_dev_opaque to 'include/linux/iio/iio-opaque.h' this way
> it should be usable for debugging
> - the iio_priv() call, is still an inline function that returns an
> 'indio_dev->priv' reference; this field is added to 'struct iio_dev';
> the reference is computed in iio_device_alloc() and should be
> cacheline aligned
> - the to_iio_dev_opaque() container is in the
> 'include/linux/iio/iio-opaque.h' header; it's still implemented with
> some pointer arithmetic; one idea was to do it via an
> 'indio_dev->opaque' field; that may still be an optionif there are
> some opinions in that direction
>
> Alexandru Ardelean (8):
> iio: proximity: ping: pass reference to IIO device via call-stack
> iio: at91-sama5d2_adc: pass ref to IIO device via param for int
> function
> iio: at91_adc: pass ref to IIO device via param for int function
> iio: stm32-dfsdm-adc: pass iio device as arg for the interrupt handler
> iio: stm32-adc: pass iio device as arg for the interrupt handler
> iio: core: wrap IIO device into an iio_dev_opaque object
> iio: core: simplify alloc alignment code
> iio: core: move debugfs data on the private iio dev info
>
> drivers/iio/adc/at91-sama5d2_adc.c | 7 ++-
> drivers/iio/adc/at91_adc.c | 5 +-
> drivers/iio/adc/stm32-adc.c | 10 ++--
> drivers/iio/adc/stm32-dfsdm-adc.c | 6 +--
> drivers/iio/industrialio-core.c | 75 ++++++++++++++++++++----------
> drivers/iio/proximity/ping.c | 5 +-
> include/linux/iio/iio-opaque.h | 27 +++++++++++
> include/linux/iio/iio.h | 24 +++-------
> 8 files changed, 99 insertions(+), 60 deletions(-)
> create mode 100644 include/linux/iio/iio-opaque.h
>
Powered by blists - more mailing lists