AXI DMA笔记

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,则如果数据位于字偏移

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值