All of lore.kernel.org
 help / color / mirror / Atom feed
From: Simon Glass <sjg@chromium.org>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH v5 02/19] usb: dwc2: Use separate input and output buffers
Date: Sun, 2 Apr 2017 09:43:38 -0600	[thread overview]
Message-ID: <CAPnjgZ3zREJGQ8Ax+hTGw+bjGVVcNUEvo9=x4=igR94GCt48ww@mail.gmail.com> (raw)
In-Reply-To: <7825980.L7YSPUyO6P@pebbles.site>

Hi Stefan,

On 2 April 2017 at 07:10, Stefan Bruens <stefan.bruens@rwth-aachen.de> wrote:
> On Sonntag, 2. April 2017 05:01:41 CEST Marek Vasut wrote:
>> On 04/02/2017 01:40 AM, Simon Glass wrote:
>> > Hi Marek,
>> >
>> > On 1 April 2017 at 14:15, Marek Vasut <marex@denx.de> wrote:
>> >> On 04/01/2017 08:05 PM, Simon Glass wrote:
>> >>> On Raspberry Pi 2 and 3 a problem was noticed when enabling driver model
>> >>> for USB: the cache invalidate after an incoming transfer does not seem
>> >>> to
>> >>> work correctly.
>> >>>
>> >>> This may be a problem with the underlying caching implementation on
>> >>> armv7
>> >>> and armv8 but this seems very unlikely. As a work-around, use separate
>> >>> buffers for input and output. This ensures that the input buffer will
>> >>> not
>> >>> hold dirty cache data.
>> >>
>> >> What do you think of this patch:
>> >> [U-Boot] usb: dwc2: invalidate the dcache before starting the DMA
>> >
>> > Yes that matches what I did as a hack. I didn't realise that the DMA
>> > would go through the cache. Thanks for the pointer.
>>
>> DMA should not go through the cache. I have yet to review that patch,
>> but IMO it's relevant to this problem you observe.
>
> DMA transfers not going through the cache is probably the problem here:
>
> Assume we have the aligned_buffer at address 0xdead0000
>
> 1. The cpu writes to address 0xdead0002. This is fine, as it is the current
> owner of the address. The cacheline is marked dirty.
> 2. The cpu no longer needs the corresponding address range, and it is
> reallocated (i.e. freed and then allocated from dwc2) or reused (i.e. formerly
> out buffer, now in buffer).
> 3. The CPU starts the DMA transfer
> 4. The DMA transfer writes to e.g. 0xdead0000-0xdead0200 in memory.
> 5. The CPU fetches an address aliasing with 0xdead0000. The dirty cache line
> is evicted, and the 0xdead0000-0xdead0040 memory contents are overwritten.

This is the part I don't understand. This should be an invalidate, not
a clean and invalidate, so there should be not memory write.

Also if the CPU fetches from cached 0xdead0000 without an invalidate,
it will not cause a cash clean. It will simple read the data from the
cache and ignore what the DMA wrote.

On armv8 we appear not to suppose invalidate in the code, so it makes
sense for rpi_3.

But for rpi_2 which seems to do a proper invalidate, I still don't see
the problem.

>
> Obviously, the dirty cache line from (1.) has to be cleared at the beginning
> of (3.), as Eddys patch does.

But I still don't understand why we have to clean instead of just invalidate?

Regards,
Simon

  reply	other threads:[~2017-04-02 15:43 UTC|newest]

Thread overview: 35+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-04-01 18:05 [U-Boot] [PATCH v5 00/19] arm: rpi: Enable USB, Ethernet, MMC, Video driver model on Raspberry Pi Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 01/19] net: smsc95xx: Correct free_pkt() implementation Simon Glass
2017-04-02 17:46   ` Joe Hershberger
2017-04-01 18:05 ` [U-Boot] [PATCH v5 02/19] usb: dwc2: Use separate input and output buffers Simon Glass
2017-04-01 20:15   ` Marek Vasut
2017-04-01 23:40     ` Simon Glass
2017-04-02  3:01       ` Marek Vasut
2017-04-02 13:10         ` Stefan Bruens
2017-04-02 15:43           ` Simon Glass [this message]
2017-04-02 21:34             ` Stefan Bruens
2017-04-02 23:23               ` Simon Glass
2017-04-03 14:26                 ` Brüns, Stefan
2017-04-03 15:38                   ` Simon Glass
2017-04-03 18:18                     ` Brüns, Stefan
2017-04-03 18:24                       ` Brüns, Stefan
2017-04-03 20:10                         ` Simon Glass
2017-04-03 20:10                       ` Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 03/19] dm: mmc: Set up the MMC device when controller is probed Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 04/19] dm: video: Correct line clearing code Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 05/19] string: Use memcpy() within memmove() when we can Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 06/19] arm: rpi: Drop the GPIO device addresses Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 07/19] arm: rpi: Drop CONFIG_CONS_INDEX Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 08/19] dm: arm: rpi: Move to driver model for USB Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 09/19] dm: arm: rpi: Use driver model for Ethernet Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 10/19] arm: rpi: Add a file to handle messages Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 11/19] arm: rpi: Add a function to obtain the MMC clock Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 12/19] dm: mmc: rpi: Convert Raspberry Pi to driver model for MMC Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 13/19] dm: arm: rpi: Drop CONFIG_OF_EMBED Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 14/19] video: arm: rpi: Move the video query out of the driver Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 15/19] video: arm: rpi: Move the video settings " Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 16/19] dm: video: Refactor lcd_simplefb to prepare for driver model Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 17/19] dm: video: Add driver-model support to lcd_simplefb Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 18/19] dm: video: arm: rpi: Convert to use driver model for video Simon Glass
2017-04-01 18:05 ` [U-Boot] [PATCH v5 19/19] arm: rpi: Add a TODO to move all messages into the msg handler Simon Glass
2017-04-01 19:05 ` [U-Boot] [PATCH v5 00/19] arm: rpi: Enable USB, Ethernet, MMC, Video driver model on Raspberry Pi Stefan Bruens

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='CAPnjgZ3zREJGQ8Ax+hTGw+bjGVVcNUEvo9=x4=igR94GCt48ww@mail.gmail.com' \
    --to=sjg@chromium.org \
    --cc=u-boot@lists.denx.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 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.