Zynq7000系列FPGA中的DMA控制器简介(二)

news2025/2/24 8:57:52

AXI互连上的DMA传输

所有DMA事务都使用AXI接口在PL中的片上存储器、DDR存储器和从外设之间传递数据。PL中的从设备通过DMAC的外部请求接口与DMAC通信,以控制数据流。这意味着从设备可以请求DMA交易,以便将数据从源地址传输到目标地址。

虽然DMAC在技术上可以访问PS中的IOPs,但这通常不是很有用。原因是这些路径通常不提供流量控制信号。流量控制是确保数据以稳定速率传输的机制,以避免缓冲区溢出或数据丢失。由于缺少这些信号,DMAC无法有效地管理通过PS IOPs的数据流。

DMAC通常使用的数据路径如图9-3所示,外围请求接口(用于流量控制)在图中没有显示。每个AXI路径可以是读或写操作,因此存在多种组合。其中两个典型的DMA事务例子包括:

  • 内存到内存(片上内存到DDR内存):通常用于在系统的不同内存区域之间高效地传输数据。例如,处理器可能需要将数据从片上缓存或SRAM移动到DDR主存储器中,以便长期存储或供其他设备访问。
  • 内存到/从PL外设(DDR内存到PL外设或从PL外设到DDR内存);用于在系统的处理器系统和可编程逻辑部分之间传输数据。DDR内存中的数据可以通过DMA被高效地传输到PL中的外设,如硬件加速器或I/O接口。同样,PL外设产生的数据也可以通过DMA被传输回DDR内存或片上内存,以供处理器或其他设备使用。

5c7b3c1df6754be899035f924c47b56a.png

在考虑AXI事务时,有一些关键的特性和限制需要注意。如下所示:

  • AXI数据传输大小
    • AXI支持的数据访问宽度可以达到AXI数据总线的64位宽度。
    • 如果用户将src_burst_sizedst_burst_size字段编程为大于64位,AXI会发出一个精确的终止信号。
    • 最大突发长度(burst length)是16个数据节拍(data beats)。
  • AXI突发跨越4KB边界
    • AXI规范不允许AXI突发跨越4KB地址边界。
    • 如果控制器被编程为使用突发起始地址、大小和长度的组合,这会导致单个突发跨越4KB地址边界,那么控制器将生成两个突发,它们的组合长度等于指定的长度。这种操作对DMAC通道线程程序是透明的。换句话说,DMAC(或其背后的软件/硬件逻辑)会处理这种地址边界的跨越情况,而不需要DMAC通道线程程序显式地处理这个问题。例如,当DMAC接收到一个DMALD(可能是表示DMA读操作的指令)时,它会自动生成两个适当的AXI读突发操作,而不是一个可能会跨越4KB边界的突发操作。
  • AXI突发类型
    • 可以编程以生成仅用于数据访问的固定地址或递增地址突发类型。不会为数据访问或指令获取生成环绕地址突发。
  • AXI写地址
    • 可以发出多达八个未完成的写地址(写发出能力)。
    • DMAC在发出写地址之前,会先读取完成该写事务所需的所有数据字节。
  • AXI写数据交织
    • 不生成交织的写数据。一个写事务的所有写数据节拍都会在下一个写事务的任何写数据节拍之前输出。
  • AXI特性
    • 不支持锁定(locked)或独占(exclusive)访问。锁定访问通常用于确保在事务完成之前,数据不会被其他事务修改。独占访问则用于缓存一致性协议,确保在特定时间只有一个处理器可以访问或修改某个内存位置。

这些考虑因素对于正确配置和使用AXI接口至关重要,特别是在设计高性能数据传输系统时。了解AXI的这些特性和限制可以帮助开发者避免潜在的问题,并优化数据传输的效率。

DMA Manager 

负责管理DMA传输的软件或硬件接口的一部分。它允许用户通过两个APB(Advanced Peripheral Bus,高级外设总线)接口之一向DMA控制器发送指令。

当DMAC(DMA控制器)在实时操作中时,用户通常只能发送以下有限指令集的一个子集:

  1. DMAGO :用于启动用户指定的DMA通道上的DMA传输。它告诉DMA控制器开始从源地址读取数据,并将数据写入目标地址,根据预配置的DMA描述符或通道设置进行传输。
  2. DMASEV (DMA Set Event/Interrupt):用于通过用户指定的事件编号来触发事件或中断。这可以用于通知系统DMA操作已完成,或者达到某个特定条件(如传输错误、完成一定百分比等)。这样,CPU或其他系统组件可以响应这些事件并采取相应的行动。
  3. DMAKILL:用于终止一个DMA线程。在某些情况下,可能需要取消或停止正在进行的DMA传输。DMAKILL指令允许用户做到这一点,它会导致DMA控制器停止当前的DMA操作,并释放与该线程关联的任何资源。

需要注意的是,当DMAC在实时操作中时,其他更复杂的配置或管理指令可能不可用或受到限制,因为实时系统需要快速响应和确定性行为。因此,这些基本指令集(DMAGO、DMASEV和DMAKILL)为实时环境中的DMA操作提供了必要的控制和反馈机制。

DMA管理器(DMA Manager)的操作取决于SLCR(System Level Control Register)寄存器中的TZ_DMA_NS设置的安全状态。这个设置决定了DMA管理器是在安全状态还是非安全状态下运行。

  • 安全状态(Secure State):如果DMA管理器在安全状态下运行,那么必须使用安全的APB接口来发送指令。如果使用非安全的APB接口发送指令,DMAC(DMA Controller)将会忽略这些指令。
  • 非安全状态(Non-Secure State):当DMA管理器在非安全状态下运行时,建议使用非安全的APB接口来启动或重启DMA通道。但是,即使在非安全模式下,也可以使用安全的APB接口。这通常是在某些特殊情况下,比如需要更高安全级别的操作时才这样做。

在通过Debug Instruction寄存器或DBGCMD寄存器向DMA管理器发送指令之前,必须首先读取DBGSTATUS寄存器以确保调试器处于空闲状态。如果调试器不处于空闲状态,DMA管理器将忽略这些指令。

当DMA管理器从APB(Advanced Peripheral Bus)从接口接收到指令时,由于系统内部的处理流程和资源限制,可能需要经过几个时钟周期才能处理该指令。例如,如果流水线正忙于处理另一条指令。

在发出DMAGO之前,系统内存必须包含一个适合DMA通道线程执行的程序,从DMAGO指定的地址开始。

示例:启动DMA通道线程

以下示例显示了使用调试指令寄存器启动DMA通道线程所需的步骤:

  1. 创建DMA通道程序
    首先,你需要为DMA通道编写一个程序。这通常是一个包含DMA传输指令的序列。

  2. 将程序存储在系统内存区域
    将你的DMA通道程序存储在系统内存的一个区域中。确保这个区域对DMA管理器是可访问的。

  3. 轮询dmac.DBGSTATUS寄存器以确保调试空闲
    在尝试编程DMAGO指令之前,你需要确保调试器处于空闲状态。这可以通过读取dmac.DBGSTATUS寄存器并检查其dbgstatus位是否为0来实现。

  4. 写入dmac.DBGINST0寄存器
    使用APB接口之一,向dmac.DBGINST0寄存器写入以下信息:

    • DMAGO指令的字节0编码。
    • DMAGO指令的字节1编码。
    • 调试线程位设置为0,以选择DMA管理器。
  5. 写入dmac.DBGINST1寄存器
    使用DMAGO指令的字节[5:2]数据(通常是目标地址的高位部分)写入dmac.DBGINST1寄存器。这些字节必须设置为在第2步中写入系统内存的程序中第一个指令的地址。

  6. 指示DMAC执行指令
    dmac.DBGCMD寄存器写入0。这将指示DMAC执行调试指令寄存器中包含的指令。DMAC会启动DMA通道线程,并将dbgstatus位设置为1。当DMAC完成指令的执行后,它会清除dbgstatus位,将其设置回0。

注意事项:

  • 在编写和调试DMA通道程序时,请确保遵循你的硬件文档和DMA管理器的规范。
  • 在发送任何DMA指令之前,始终检查DMA管理器的状态,以确保它准备好接受新的指令。
  • 如果你的系统支持中断,并且你希望在DMA操作完成时得到通知,请确保正确设置和配置相关的中断。
  • 始终考虑DMA操作的性能和资源消耗,以避免对系统造成不良影响。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1878601.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

pdf拆分,pdf拆分在线使用,pdf拆分多个pdf

在数字化的时代,pdf文件已经成为我们日常办公、学习不可或缺的文档格式。然而,有时候我们可能需要对一个大的pdf文件进行拆分,以方便管理和分享。那么,如何将一个pdf文件拆分成多个pdf呢?本文将为你推荐一种好用的拆分…

033基于SSM+Jsp的多用户博客个人网站

开发语言:Java框架:ssm技术:JSPJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包…

Java----面向对象----总复习

面向对象 面向对象的程序设计思想(Object Oriented Programming),简称OOP.是一种设计者思想.关注的焦点是类,参照现实中的事务,将事务的属性特征,行为抽象出来,用类来表示.代码结构:以类为组织单位,每种事务都有自己的属性和行为,功能, 思想:从宏观上 帮助我们把握,整体分析整…

独家原创 | Matlab实现CNN-Transformer多变量时间序列预测

SCI一区级 | Matlab实现BO-Transformer-GRU多变量时间序列预测 目录 SCI一区级 | Matlab实现BO-Transformer-GRU多变量时间序列预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab实现CNN-Transformer多变量时间序列预测; 2.运行环境为Matlab2023b…

理解论文笔记:基于贝叶斯网络和最大期望算法的可维护性研究

看了与上一篇研究方向一致的文章,上一篇19年的,这一篇22年的更新。若有侵权,请联系删除。 I. INTRODUCTION 介绍 主要介绍了使用贝叶斯网络和历史数据对无线传感器网络可维护性研究的重要性和必要性,并对下面的各章进行了总结。 本文的其余部分组织如下:第二节论述…

对数函数转换公式

对数函数换底公式. 1. 2. 3. 以上公式可以由以下公式推导而来, 1. 2. 3. 4.

【Python系列】列表推导式:简洁而强大的数据操作工具

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

Avue框架学习

Avue框架学习 我们的项目使用的框架是 Avue 在我看来这个框架最大的特点是可以基于JSON配置页面上的From,Table以及各种各样的输入框等,不需要懂前端就可以很快上手,前提是需要多查一下文档 开发环境搭建 由于我本地的环境全是用docker来搭建的,所以我依然选择用docker搭建我…

微软推出集成GPT-4o的文本转语音虚拟数字人服务

微软近日宣布,其全新的文本转语音虚拟数字人服务正式上线,并集成了GPT-4o技术。这一服务为用户提供了创建实时互动数字人的可能。通过先进的自然语言处理技术,数字人能够将文本转化为自然流畅的语音,并配以生动的虚拟形象&#xf…

Python 提取图片主色调

Python 提取图片主色调 效果代码编写 效果 有个要提取图片主色调的需求,记录一下。 代码编写 import numpy as np import cv2 from sklearn.cluster import KMeans from skimage.color import rgb2lab, deltaE_cie76 from collections import Counter# 创建默认…

寄存器相关知识点

文章目录 寄存器是什么?举例子—如何去看手册来配置寄存器寄存器地址知识点输出功能具体实现,在linux编写代码的话 其他 相关视频 寄存器是什么? 本质就是一个存储器,写内存和写指针都是一样的 寄存器里的值和RAM的值&#xff0c…

Android 11.0 修改系统显示大小导航栏消失

Android 11.0 修改系统显示大小导航栏消失 1.显示大小设置为大时,导航栏图标不显示。 设置为大,较大,最大时,导航栏图标不显示。 2.开始怀疑是导航栏被隐藏了,各种折腾无效。 3.发现: frameworks/base/pa…

springboot+vue 开发记录(八) 前端项目打包

本篇文章涉及到前端项目打包的一些说明 我打包后的项目在部署到服务器上后,访问页面时按下F12出现了这种情况: 它显示出了我的源码,这是一种很不安全的行为 该怎么办?很简单: 我们只需要下载一点点插件,再…

说说MQ在你项目中的应用(二)商品支付

看了不少关于MQ的文章,也对MQ的作用做了一些总结。通常来说MQ有三大功能:异步处理、系统解耦和流量削峰。但我觉得这些功能本质上都是围绕着异步这个核心来的,只是针对不同的业务场景做了些调整。 现在市面上常用的MQ中间件,如Ra…

大数据之Linux部署常用命令脚本封装

文章目录 编写集群命令执行脚本xcall集群命令执行1. 脚本需求2. 需求分析3. 脚本实现3.1 创建脚本存放目录3.2 编写xcall脚本3.3 修改脚本执行权限3.4 测试脚本 编写集群分发脚本xsync集群分发脚本1. 脚本需求2. 需求分析3. 脚本实现3.1 创建脚本存放目录3.2 编写xsync脚本3.3 …

amis-editor 注册自定义组件

建议先将amis文档从头到尾,仔细看一遍。 参考:amis - 低代码前端框架 amis 的渲染过程是将 json 转成对应的 React 组件。先通过 json 的 type 找到对应的 Component,然后把其他属性作为 props 传递过去完成渲染。 import * as React from …

[数据集][目标检测]睡岗检测数据集VOC+YOLO格式3290张4类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):3316 标注数量(xml文件个数):3316 标注数量(txt文件个数):3316 标注…

了解C# 中的集合(包括泛型和非泛型)

跨站点脚本 (XSS) 攻击是一种严重的安全威胁,恶意脚本会注入其他用户查看的网页中。本文演示了如何在 ASP.NET Core MVC 中构建一个简单的博客应用程序,同时使用内置安全功能和最佳实践来防止 XSS 攻击。 步骤 1.创建 ASP.NET Core MVC 项目 创建新的 …

Ollama中文版部署

M1部署Ollama Ollama中文网站: Featured - 精选 - Ollama中文网 下载网址: Download Ollama on macOS 安装后运行llma3模型: ollama run llama3:8b 界面使用: GitHub - open-webui/open-webui: User-friendly WebUI for LLMs (Formerly Ollama WebUI) 部署open-webui: do…

摸鱼大数据——Spark基础——Spark环境安装——PySpark搭建

三、PySpark环境安装 PySpark: 是Python的库, 由Spark官方提供. 专供Python语言使用. 类似Pandas一样,是一个库 Spark: 是一个独立的框架, 包含PySpark的全部功能, 除此之外, Spark框架还包含了对R语言\ Java语言\ Scala语言的支持. 功能更全. 可以认为是通用Spark。 功能 P…