From: Robin Murphy <robin.murphy@arm.com>
To: Robin Gong <yibin.gong@nxp.com>, Mark Brown <broonie@kernel.org>
Cc: "mark.rutland@arm.com" <mark.rutland@arm.com>,
"devicetree@vger.kernel.org" <devicetree@vger.kernel.org>,
"matthias.schiffer@ew.tq-group.com"
<matthias.schiffer@ew.tq-group.com>,
"martin.fuzzey@flowbird.group" <martin.fuzzey@flowbird.group>,
"catalin.marinas@arm.com" <catalin.marinas@arm.com>,
"s.hauer@pengutronix.de" <s.hauer@pengutronix.de>,
"will.deacon@arm.com" <will.deacon@arm.com>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"linux-spi@vger.kernel.org" <linux-spi@vger.kernel.org>,
"vkoul@kernel.org" <vkoul@kernel.org>,
"robh+dt@kernel.org" <robh+dt@kernel.org>,
dl-linux-imx <linux-imx@nxp.com>,
"festevam@gmail.com" <festevam@gmail.com>,
"u.kleine-koenig@pengutronix.de" <u.kleine-koenig@pengutronix.de>,
"dmaengine@vger.kernel.org" <dmaengine@vger.kernel.org>,
"dan.j.williams@intel.com" <dan.j.williams@intel.com>,
"shawnguo@kernel.org" <shawnguo@kernel.org>,
"kernel@pengutronix.de" <kernel@pengutronix.de>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>
Subject: Re: [PATCH v9 RESEND 01/13] spi: imx: add dma_sync_sg_for_device after fallback from dma
Date: Tue, 9 Jun 2020 11:00:33 +0100 [thread overview]
Message-ID: <bcfc3637-65af-577a-ddbd-890b6c83a6e6@arm.com> (raw)
In-Reply-To: <VE1PR04MB6638B1EC49D295C64292B7BD89820@VE1PR04MB6638.eurprd04.prod.outlook.com>
On 2020-06-09 06:21, Robin Gong wrote:
> On 2020/06/09 0:44 Robin Murphy <robin.murphy@arm.com> wrote:
>> On 2020-06-08 16:31, Mark Brown wrote:
>>> On Mon, Jun 08, 2020 at 03:08:45PM +0000, Robin Gong wrote:
>>>
>>>>>> + if (transfer->rx_sg.sgl) {
>>>>>> + struct device *rx_dev = spi->controller->dma_rx->device->dev;
>>>>>> +
>>>>>> + dma_sync_sg_for_device(rx_dev, transfer->rx_sg.sgl,
>>>>>> + transfer->rx_sg.nents, DMA_TO_DEVICE);
>>>>>> + }
>>>>>> +
>>>
>>>>> This is confusing - why are we DMA mapping to the device after doing
>>>>> a PIO transfer?
>>>
>>>> 'transfer->rx_sg.sgl' condition check that's the case fallback PIO
>>>> after DMA transfer failed. But the spi core still think the buffer
>>>> should be in 'device' while spi driver touch it by PIO(CPU), so sync it back to
>> device to ensure all received data flush to DDR.
>>>
>>> So we sync it back to the device so that we can then do another sync
>>> to CPU? TBH I'm a bit surprised that there's a requirement that we
>>> explicitly undo a sync and that a redundant double sync in the same
>>> direction might be an issue but I've not had a need to care so I'm
>>> perfectly prepared to believe there is.
>>>
>>> At the very least this needs a comment.
>>
>> Yeah, something's off here - at the very least, syncing with DMA_TO_DEVICE on
>> the Rx buffer that was mapped with DMA_FROM_DEVICE is clearly wrong.
>> CONFIG_DMA_API_DEBUG should scream about that.
>>
>> If the device has written to the buffer at all since dma_map_sg() was called
>> then you do need a dma_sync_sg_for_cpu() call before touching it from a CPU
>> fallback path, but if nobody's going to touch it from that point until it's
>> unmapped then there's no point syncing it again. The
>> my_card_interrupt_handler() example in DMA-API_HOWTO.txt demonstrates
>> this.
> Thanks for you post, but sorry, that's not spi-imx case now, because the rx data in device memory is not truly updated from 'device'/DMA, but from PIO, so that dma_sync_sg_for_cpu with DMA_FROM_DEVICE can't be used, otherwise the fresh data in cache will be invalidated.
> But you're right, kernel warning comes out if CONFIG_DMA_API_DEBUG enabled...
Ah, I think I understand what's going on now. That's... really ugly :(
Looking at the SPI core code, I think a better way to handle this would
be to have your fallback path call spi_unmap_buf() directly (or perform
the same actions, if exporting that to drivers is unacceptable), then
make sure ->can_dma() returns false after that such that spi_unmap_msg()
won't try to unmap it again. That's a lot more reasonable than trying to
fake up a DMA_TO_DEVICE transfer in the middle of a DMA_FROM_DEVICE
operation on the same buffer.
Alternatively, is it feasible to initiate a dummy DMA request during
probe, such that you can detect the failure condition and give up on the
DMA channel early, and not have to deal with it during a real SPI transfer?
Robin.
next prev parent reply other threads:[~2020-06-09 10:01 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-06-06 23:21 [PATCH v9 RESEND 00/13] add ecspi ERR009165 for i.mx6/7 soc family Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 01/13] spi: imx: add dma_sync_sg_for_device after fallback from dma Robin Gong
2020-06-08 14:34 ` Mark Brown
2020-06-08 15:08 ` Robin Gong
2020-06-08 15:31 ` Mark Brown
2020-06-08 16:44 ` Robin Murphy
2020-06-09 5:21 ` Robin Gong
2020-06-09 10:00 ` Robin Murphy [this message]
2020-06-09 10:09 ` (EXT) " Matthias Schiffer
2020-06-09 13:26 ` Mark Brown
2020-06-09 10:10 ` Robin Gong
2020-06-09 13:36 ` Mark Brown
2020-06-09 2:45 ` Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 02/13] Revert "ARM: dts: imx6q: Use correct SDMA script for SPI5 core" Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 03/13] Revert "ARM: dts: imx6: Use correct SDMA script for SPI cores" Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 04/13] Revert "dmaengine: imx-sdma: refine to load context only once" Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 05/13] dmaengine: imx-sdma: remove duplicated sdma_load_context Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 06/13] dmaengine: imx-sdma: add mcu_2_ecspi script Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 07/13] spi: imx: fix ERR009165 Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 08/13] spi: imx: remove ERR009165 workaround on i.mx6ul Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 09/13] spi: imx: add new i.mx6ul compatible name in binding doc Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 10/13] dmaengine: imx-sdma: remove ERR009165 on i.mx6ul Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 11/13] dma: imx-sdma: add i.mx6ul compatible name Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 12/13] dmaengine: imx-sdma: fix ecspi1 rx dma not work on i.mx8mm Robin Gong
2020-06-06 23:21 ` [PATCH v9 RESEND 13/13] dmaengine: imx-sdma: add uart rom script Robin Gong
2020-06-08 9:11 ` (EXT) [PATCH v9 RESEND 00/13] add ecspi ERR009165 for i.mx6/7 soc family Matthias Schiffer
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=bcfc3637-65af-577a-ddbd-890b6c83a6e6@arm.com \
--to=robin.murphy@arm.com \
--cc=broonie@kernel.org \
--cc=catalin.marinas@arm.com \
--cc=dan.j.williams@intel.com \
--cc=devicetree@vger.kernel.org \
--cc=dmaengine@vger.kernel.org \
--cc=festevam@gmail.com \
--cc=kernel@pengutronix.de \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-imx@nxp.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-spi@vger.kernel.org \
--cc=mark.rutland@arm.com \
--cc=martin.fuzzey@flowbird.group \
--cc=matthias.schiffer@ew.tq-group.com \
--cc=robh+dt@kernel.org \
--cc=s.hauer@pengutronix.de \
--cc=shawnguo@kernel.org \
--cc=u.kleine-koenig@pengutronix.de \
--cc=vkoul@kernel.org \
--cc=will.deacon@arm.com \
--cc=yibin.gong@nxp.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).