Block DMA
直接寄存器模式(分散-聚集引擎被禁用)提供了一种配置,用于在需要较少FPGA资源利用率的MM2S和S2MM通道上进行简单DMA传输。通过访问DMACR、源地址或目标地址以及长度寄存器来启动传输。传输完成后,DMASR.IOC_Irq将为相关通道断言,如果启用,将生成中断输出。
MM2S通道的DMA操作按以下顺序设置和启动:
1.通过将运行/停止位设置为1(MM2S_DMACR.RS = 1),启动MM2S通道运行。暂停位(DMASR.Halted)解除设置,指示MM2S通道正在运行。
2.如果需要,通过将1写入MM2S_DMACR.IOC_IrqEn和MM2S_DMACR.Err_IrqEn来启用中断。当AXI DMA配置为直接寄存器模式时,不使用延迟中断、延迟计数和阈值计数。
3.将有效的源地址写入MM2S_SA寄存器。如果为AXI DMA配置了大于32的地址空间,则对MM2S_SA MSB寄存器进行编程。如果AXI DMA未配置数据对齐,则必须对齐有效地址,否则会出现未定义的结果。被视为对齐或未对齐的内容基于流数据宽度。在Micro模式下配置AXI_DMA时,您有责任指定正确的地址。Micro DMA不关心4K边界。
例如,如果内存映射数据宽度=32,则如果数据位于字偏移