Lines Matching full:sram
29 the system SRAM) for different peripheral. It can access external RAMs but
110 STM32 DMA-MDMA chaining feature then uses a SRAM buffer. STM32MP1 SoCs embed
113 bad with DDR, while they are optimal with SRAM. Hence the SRAM buffer used
124 | DMA_SxM0AR |<=>| | SRAM | |<=>| []-[]...[] |
140 **1. Allocate a SRAM buffer**
142 SRAM device tree node is defined in SoC device tree. You can refer to it in
143 your board device tree to define your SRAM pool.
146 &sram {
147 my_foo_device_dma_pool: dma-sram@0 {
152 Be careful of the start index, in case there are other SRAM consumers.
155 SRAM.
156 If the SRAM period is greater than the expected DMA transfer, then STM32 DMA
160 Don't forget to refer to your SRAM pool in your device node. You need to
169 Then get this SRAM pool in your foo driver and allocate your SRAM buffer.
217 STM32 DMA transfer (where memory address targets now the SRAM buffer instead
221 The new sg_list items must fit SRAM period length. Here is an example for
295 SRAM buffer, and set (struct dma_slave_config).peripheral_size != 0.
306 (depending on the transfer direction) must point on your SRAM buffer, and
320 config.dst_addr = sram_dma_buf; // SRAM buffer
327 mdma_conf.src_addr = sram_dma_buf; // SRAM buffer
338 dmaengine_prep_slave_sg()) with the new sg_list using SRAM buffer, or to
340 dmaengine_prep_dma_cyclic()) with the new SRAM buffer.
351 Use the new sg_list using SRAM buffer (in case of dmaengine_prep_slave_sg())
353 case of DMA_DEV_TO_MEM) or the SRAM buffer (in case of DMA_MEM_TO_DEV), the
385 STM32 MDMA feeds the SRAM buffer with the DDR data, and the STM32 DMA reads
386 data from SRAM buffer. So some data (the first period) have to be copied in
387 SRAM buffer when the STM32 DMA starts to read.
391 by the STM32 DMA could be "wrong". The proper way is to prepare the first SRAM