]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
net: rswitch: Add missing cache invalidate of TX descriptor
authorMarek Vasut <marek.vasut+renesas@mailbox.org>
Thu, 19 Dec 2024 10:52:46 +0000 (11:52 +0100)
committerMarek Vasut <marek.vasut+renesas@mailbox.org>
Fri, 20 Dec 2024 21:20:37 +0000 (22:20 +0100)
TFTP transfers of large files, for example 128 MiB, can sporadically
get stuck and the transfer slows down considerably.

This happens because the TX DMA descriptor in DRAM becomes out of sync
with the view of the TX DMA descriptor content from the CPU side, which
is viewed through the CPU caches. In order to guarantee these two views
are consistent, the cache over TX DMA descriptor that has possibly been
written by the rswitch hardware must first be invalidated, only then can
the descriptor be cleared and updated by the CPU, and finally the cache
over that area must be flushed back into DRAM to make sure the rswitch
hardware has consistent view of the updated descriptor content.

The very first invalidation operation was missing, which led to sporadic
corruption of the TX DMA descriptor. Fix it, add the missing invalidation
operation.

Reported-by: Enric Balletbo i Serra <eballetb@redhat.com>
Signed-off-by: Marek Vasut <marek.vasut+renesas@mailbox.org>
Tested-by: Enric Balletbo i Serra <eballetb@redhat.com>
drivers/net/rswitch.c

index 8e1b6e2f6f6a21d27b74e7bb8b8e8feab850cfb3..97b5d1b75c1ea4128dd0e1333582a85a9c42457a 100644 (file)
@@ -837,6 +837,7 @@ static int rswitch_send(struct udevice *dev, void *packet, int len)
 
        /* Update TX descriptor */
        rswitch_flush_dcache((uintptr_t)packet, len);
+       rswitch_invalidate_dcache((uintptr_t)desc, sizeof(*desc));
        memset(desc, 0x0, sizeof(*desc));
        desc->die_dt = DT_FSINGLE;
        desc->info_ds = len;