赞
踩
所有DMA事务都使用AXI接口在PL中的片上存储器、DDR存储器和从外设之间传递数据。PL中的从设备通过DMAC的外部请求接口与DMAC通信,以控制数据流。这意味着从设备可以请求DMA交易,以便将数据从源地址传输到目标地址。
虽然DMAC在技术上可以访问PS中的IOPs,但这通常不是很有用。原因是这些路径通常不提供流量控制信号。流量控制是确保数据以稳定速率传输的机制,以避免缓冲区溢出或数据丢失。由于缺少这些信号,DMAC无法有效地管理通过PS IOPs的数据流。
DMAC通常使用的数据路径如图9-3所示,外围请求接口(用于流量控制)在图中没有显示。每个AXI路径可以是读或写操作,因此存在多种组合。其中两个典型的DMA事务例子包括:
在考虑AXI事务时,有一些关键的特性和限制需要注意。如下所示:
src_burst_size
或dst_burst_size
字段编程为大于64位,AXI会发出一个精确的终止信号。这些考虑因素对于正确配置和使用AXI接口至关重要,特别是在设计高性能数据传输系统时。了解AXI的这些特性和限制可以帮助开发者避免潜在的问题,并优化数据传输的效率。
DMA Manager
负责管理DMA传输的软件或硬件接口的一部分。它允许用户通过两个APB(Advanced Peripheral Bus,高级外设总线)接口之一向DMA控制器发送指令。
当DMAC(DMA控制器)在实时操作中时,用户通常只能发送以下有限指令集的一个子集:
需要注意的是,当DMAC在实时操作中时,其他更复杂的配置或管理指令可能不可用或受到限制,因为实时系统需要快速响应和确定性行为。因此,这些基本指令集(DMAGO、DMASEV和DMAKILL)为实时环境中的DMA操作提供了必要的控制和反馈机制。
DMA管理器(DMA Manager)的操作取决于SLCR(System Level Control Register)寄存器中的TZ_DMA_NS
设置的安全状态。这个设置决定了DMA管理器是在安全状态还是非安全状态下运行。
在通过Debug Instruction寄存器或DBGCMD寄存器向DMA管理器发送指令之前,必须首先读取DBGSTATUS寄存器以确保调试器处于空闲状态。如果调试器不处于空闲状态,DMA管理器将忽略这些指令。
当DMA管理器从APB(Advanced Peripheral Bus)从接口接收到指令时,由于系统内部的处理流程和资源限制,可能需要经过几个时钟周期才能处理该指令。例如,如果流水线正忙于处理另一条指令。
在发出DMAGO之前,系统内存必须包含一个适合DMA通道线程执行的程序,从DMAGO指定的地址开始。
以下示例显示了使用调试指令寄存器启动DMA通道线程所需的步骤:
创建DMA通道程序:
首先,你需要为DMA通道编写一个程序。这通常是一个包含DMA传输指令的序列。
将程序存储在系统内存区域:
将你的DMA通道程序存储在系统内存的一个区域中。确保这个区域对DMA管理器是可访问的。
轮询dmac.DBGSTATUS
寄存器以确保调试空闲:
在尝试编程DMAGO指令之前,你需要确保调试器处于空闲状态。这可以通过读取dmac.DBGSTATUS
寄存器并检查其dbgstatus
位是否为0来实现。
写入dmac.DBGINST0
寄存器:
使用APB接口之一,向dmac.DBGINST0
寄存器写入以下信息:
写入dmac.DBGINST1
寄存器:
使用DMAGO指令的字节[5:2]数据(通常是目标地址的高位部分)写入dmac.DBGINST1
寄存器。这些字节必须设置为在第2步中写入系统内存的程序中第一个指令的地址。
指示DMAC执行指令:
向dmac.DBGCMD
寄存器写入0。这将指示DMAC执行调试指令寄存器中包含的指令。DMAC会启动DMA通道线程,并将dbgstatus
位设置为1。当DMAC完成指令的执行后,它会清除dbgstatus
位,将其设置回0。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。