• Amelie Delaunay's avatar
    dmaengine: Add STM32 DMA3 support · f561ec8b
    Amelie Delaunay authored
    STM32 DMA3 driver supports the 3 hardware configurations of the STM32 DMA3
    controller:
    - LPDMA (Low Power): 4 channels, no FIFO
    - GPDMA (General Purpose): 16 channels, FIFO from 8 to 32 bytes
    - HPDMA (High Performance): 16 channels, FIFO from 8 to 256 bytes
    Hardware configuration of the channels is retrieved from the hardware
    configuration registers.
    
    The client can specify its channel requirements through device tree.
    STM32 DMA3 channels can be individually reserved either because they are
    secure, or dedicated to another CPU.
    Indeed, channels availability depends on Resource Isolation Framework
    (RIF) configuration. RIF grants access to buses with Compartment ID (CID)
    filtering, secure and privilege level. It also assigns DMA channels to one
    or several processors.
    DMA channels used by Linux should be CID-filtered and statically assigned
    to CID1 or shared with other CPUs but using semaphore. In case CID
    filtering is not configured, dma-channel-mask property can be used to
    specify available DMA channels to the kernel, otherwise such channels
    will be marked as reserved and can't be used by Linux.
    
    STM32 DMA3 is a new STM32 DMA controller, not a new version of an existing
    one.
    stm32-dma is not considered for reuse because register layout is completely
    different and doesn't rely on descriptors mechanism.
    stm32-mdma is based on descriptors mechanism but there are significant
    differences in register layout and descriptors structure.
    Signed-off-by: default avatarAmelie Delaunay <amelie.delaunay@foss.st.com>
    Link: https://lore.kernel.org/r/20240531150712.2503554-6-amelie.delaunay@foss.st.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
    f561ec8b
Kconfig 1.35 KB