Re: edma: "3-byte" transfers and masked writes in general

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 10/03/16 09:37, Matthijs van Duin wrote:
> I recently noticed the curious definition DMA_SLAVE_BUSWIDTH_3_BYTES
> and EDMA's supposed support thereof. While I appreciate it might just
> be a convenient hack to support dma for packed 24-bit audio, I feel it
> can use some clarification (and warning).
> 
> EDMA does not really support 3-byte transfers.

In A-Synchronized transfer the eDMA will transfer ACNT number of bytes in
response to a DMA request. ACNT valid values are 1 to 65535, including 3, 21, etc.

SRC is the _byte_ address from which the data is transferred
DST is the _byte_ address to which the data is transferred.

Also there are not alignment restrictions from eDMA to SRC or DST address. The
only exception is SAM/DAM in constant addressing mode where the SRC/DST should
be 256bit aligned.

> It supports aligned
> power-of-two transfers up to its bus width (typ 16 bytes), and aligned
> bursts of its bus width up to the configured max burst length (typ 4
> or 8 beats) but never crossing a (4 KB) page boundary. If you ask it
> for anything else it will simply use the smallest supported transfer
> that covers the requested range, and uses byte-masking for writes.
> 
> Beware that this means that e.g. a transfer with (len == 8 && addr % 8
> == 4) is not considered properly aligned even if the target's actual
> bus width is 32-bit!
> 
> The important property of the target therefore is: does it support
> masked writes?
> 
> I did a few tests of interesting peripherals on the DM814x, and it
> turns out the results are quite diverse (and utterly undocumented).
> 
> control module: despite all the magic there it seems to correctly
> support reads and writes of any size, including masked writes.
> 
> hwspinlock module, lock registers: surprisingly these properly support
> aligned 1- and 2-byte accesses, with the lock residing in byte 0 of
> each word and bytes 1-3 being RAZ/WI. Masked writes however are only
> supported if all or no bytes of each word are masked. If some but not
> all bytes of a word are masked a bus error is generated.
> 
> ethernet dma descriptor ram: ignores byte-masking hence masked writes
> cause silent corruption!! Aligned 1- and 2-byte accesses get the same
> treatment.
> 
> Note in particular that using edma to write words 1 and 2 of an
> ethernet dma descriptor would corrupt words 0 and 3 of that
> descriptor. This is not something I would have expected even though I
> already knew the descriptor memory only supported word-writes.

As far as I can see the eDMA itself does not have alignment restrictions, but
the peripheral might have. So it is up to the DMAengine client driver to make
sure to not ask the DMA to use a setup, which is not supported by it.

-- 
Péter
--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux Arm (vger)]     [ARM Kernel]     [ARM MSM]     [Linux Tegra]     [Linux WPAN Networking]     [Linux Wireless Networking]     [Maemo Users]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux