From: Jonathan Cameron <jic23@kernel.org>
To: "Uwe Kleine-König" <u.kleine-koenig@pengutronix.de>
Cc: Hartmut Knaack <knaack.h@gmx.de>,
Lars-Peter Clausen <lars@metafoo.de>,
Peter Meerwald-Stadler <pmeerw@pmeerw.net>,
Rob Herring <robh+dt@kernel.org>,
Mark Rutland <mark.rutland@arm.com>,
Michael Hennerich <Michael.Hennerich@analog.com>,
Stefan Popa <stefan.popa@analog.com>,
Alexandru Ardelean <alexandru.Ardelean@analog.com>,
linux-iio@vger.kernel.org, kernel@pengutronix.de
Subject: Re: [PATCH v3 3/3] iio: adc: new driver to support Linear technology's ltc2496
Date: Sun, 1 Dec 2019 11:00:19 +0000 [thread overview]
Message-ID: <20191201110019.7cac56ac@archlinux> (raw)
In-Reply-To: <20191124191101.duh646kbrlackget@pengutronix.de>
On Sun, 24 Nov 2019 20:11:01 +0100
Uwe Kleine-König <u.kleine-koenig@pengutronix.de> wrote:
> On Sat, Nov 23, 2019 at 05:12:04PM +0000, Jonathan Cameron wrote:
> > On Thu, 21 Nov 2019 22:00:07 +0100
> > Uwe Kleine-König <u.kleine-koenig@pengutronix.de> wrote:
> >
> > > This chip is similar to the LTC2497 ADC, it just uses SPI instead of I2C
> > > and so has a slightly different protocol. Only the actual hardware
> > > access is different. The spi protocol is different enough to not be able
> > > to map the differences via a regmap.
> > >
> > > Also generalize the entry in MAINTAINER to cover the newly introduced
> > > file.
> > >
> > > Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
> > looks good with the exception of the now overly protected DMA buffers.
> >
> > See inline. As that's all I'm seeing that needs fixing I'll just
> > fix this up whilst applying.
> >
> > I'd like the series to sit a little longer on the list though to give
> > devicetree maintainers time to look at the bindings.
>
> ok.
>
> > > +struct ltc2496_driverdata {
> > > + /* this must be the first member */
> > > + struct ltc2497core_driverdata common_ddata;
> > > + struct spi_device *spi;
> > > +
> > > + /*
> > > + * DMA (thus cache coherency maintenance) requires the
> > > + * transfer buffers to live in their own cache lines.
> > > + */
> > > + unsigned char rxbuf[3] ____cacheline_aligned;
> > > + unsigned char txbuf[3] ____cacheline_aligned;
> > Ah. I've not explained this clearly enough. Upshot is you only need
> > to ensure that the buffers used for dma are not shared with any other
> > usage. the __cacheline_aligned marker pads the structure to ensure
> > the element so marked is at the start of a new cacheline. This means
> > there is no sharing with non DMA related elements which may be accidentally
> > reset when the DMA transfer ends.
> >
> > Imagine we had:
> > struct bob {
> > int a; //used for all sorts of fun things not related to dma and not
> > //protected from happening concurrently with dma.
> > unsigned char rx_buf[3];
> > unsigned char tx_buf[3]
> > };
> >
> > The buffers are used for DMA. The DMA engine takes a copy of the cacheline
> > to start doing it's magic.
> >
> > Along comes other activity and writes to 'a'.
> >
> > DMA completes, then engine pushes the cacheline back to the memory including
> > writing back what it had as a copy of a. Thus the update to 'a' is lost.
> >
> > Now the guarantee we make use of is that DMA engines are not allowed to
> > copy cachelines that do not contain the buffers they are using (all sorts
> > of things would break if they were).
> >
> > However, there is no need to separate rx_buf and tx_buf as they are being
> > used by the same DMA engine and nothing else is going to update them whilst
> > they are in use.
>
> Yeah, I thought about that when adding the second annotation but then
> forgot to mention that in my cover letter.
>
> So I assume you will just drop the 2nd ____cacheline_aligned? That's
> fine for me; thanks.
Yup.
Jonathan
>
> Best regards
> Uwe
>
prev parent reply other threads:[~2019-12-01 11:00 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-11-21 21:00 [PATCH v3 0/3] iio: adc: add support for ltc2496 Uwe Kleine-König
2019-11-21 21:00 ` [PATCH v3 1/3] iio: adc: ltc2496: provide device tree binding document Uwe Kleine-König
2019-12-01 11:28 ` Jonathan Cameron
2019-12-09 15:18 ` Uwe Kleine-König
2019-12-09 20:34 ` Uwe Kleine-König
2019-11-21 21:00 ` [PATCH v3 2/3] iio: adc: ltc2497: split protocol independent part in a separate module Uwe Kleine-König
2019-11-21 21:00 ` [PATCH v3 3/3] iio: adc: new driver to support Linear technology's ltc2496 Uwe Kleine-König
2019-11-23 17:12 ` Jonathan Cameron
2019-11-24 19:11 ` Uwe Kleine-König
2019-12-01 11:00 ` Jonathan Cameron [this message]
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=20191201110019.7cac56ac@archlinux \
--to=jic23@kernel.org \
--cc=Michael.Hennerich@analog.com \
--cc=alexandru.Ardelean@analog.com \
--cc=kernel@pengutronix.de \
--cc=knaack.h@gmx.de \
--cc=lars@metafoo.de \
--cc=linux-iio@vger.kernel.org \
--cc=mark.rutland@arm.com \
--cc=pmeerw@pmeerw.net \
--cc=robh+dt@kernel.org \
--cc=stefan.popa@analog.com \
--cc=u.kleine-koenig@pengutronix.de \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox