当前位置: 首页 > news >正文

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

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操作的性能和资源消耗,以避免对系统造成不良影响。

 

相关文章:

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

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

获取 url 地址栏 ? 后面的查询字符串,并以键值对形式放到对象里面

写在前面 在前端面试当中,关于 url 相关的问题很常见,而对于 url 请求参数的问题也很常见,大部分以笔试题常见,今天就根据这道面试题一起来看一下。 问题 获取 url 地址栏?后面的查询字符串,并以键值对形式放到对象…...

List接口, ArrayList Vector LinkedList

Collection接口的子接口 子类Vector,ArrayList,LinkedList 1.元素的添加顺序和取出顺序一致,且可重复 2.每个元素都有其对应的顺序索引 方法 在index 1 的位置插入一个对象,list.add(1,list2)获取指定index位置的元素&#…...

探讨数字化背景下VSM(价值流程图)的挑战和机遇

在信息化、数字化飞速发展的今天,各行各业都面临着前所未有的挑战与机遇。作为源自丰田生产模式的VSM(价值流程图),这一曾经引领制造业革命的工具,在数字化背景下又将如何乘风破浪,应对新的市场格局和技术变…...

Conda跨平台环境迁移

问题描述: 在一台Ubuntu电脑上完全复刻在Windows中通过conda创建的环境。 导出环境 在Windows机器上,需要导出当前conda环境的配置。这将生成一个environment.yml文件,其中包含所有已安装的包和版本信息。 打开Anaconda Prompt(…...

全面掌握 Jackson 序列化工具:原理、使用与高级配置详解

全面掌握 Jackson 序列化工具:原理、使用与高级配置详解 Jackson 是一个功能强大的 JSON 处理库,广泛应用于 Java 项目中。它提供了丰富的功能和灵活的配置选项,可以轻松地在 Java 对象和 JSON 数据之间进行转换。本文将详细介绍 Jackson 的…...

mathtype7.4永久激活码密钥及2024最新破解版注册码附安装教程

MathType 7版本号还提升了对教育行业的支持,如增加了大量预定义的教学公式和符号,使老师和学生在教学过程中能够更加便捷的应用。同时,它还加强了云备份功能,用户可将自己的公式存储在云端,随时随地访问和编辑&#xf…...

【SQL】优化慢 SQL的简单思路

优化慢 SQL 需要综合考虑多个方面,包括查询的结构、索引的使用、表结构设计等。以下是一些常见的 SQL 优化技巧和步骤: 1. 检查查询计划 使用数据库提供的工具查看查询计划(例如 MySQL 的 EXPLAIN 命令)可以帮助了解查询的执行路…...

禁止浏览器对input的自动填充和填充提示(适用于谷歌、火狐、Edge(原IE浏览器)等常见浏览器)

目录 1.要解决的问题2.一技能:原生属性,小试牛刀3.二技能:傀儡input,瞒天过海4.三技能:JavaScript出击,直接开大5.九九八十一难,永远还有最后一难 写在前面: 如有转载,务…...

鸿蒙项目实战-月木学途:1.编写首页,包括搜索栏、轮播图、宫格

效果展示 搜索栏制作 相关知识回顾 输入框组件TextInput 单行输入框类型.type(InputType.Normal)//基本输入框.type(InputType.Password)//密码.type(InputType.Email)//邮箱.type(InputType.Number)//数字.type(InputType.PhoneNumber)//电话号.type(InputType.Normal).type…...

深入浅出:npm常用命令详解和实践

npm 是 Node.js 的包管理器,用于管理 Node.js 应用的依赖关系和版本。 以下是一些常用的 npm 命令: npm init: 命令用于初始化一个新的 Node.js 项目。它会创建一个 package.json 文件,这个文件包含了项目的元数据和依赖信息。 npm initnpm…...

山东大学-科技文献阅读与翻译(期末复习)(选择题+翻译)

目录 选择题 Chapter1 1.which of the following is not categorized as scientific literature 2.Which of the followings is defined as tertiary(三级文献) literature? 3.Which type of the following international conferences is listed as Number one conference…...

二分查找:自定义 upper_bound、lower_bound

二分查找详细介绍可以看这篇文章&#xff0c;此篇文章介绍返回索引的 upper_bound 和 lower_bound 的 C 实现。 lower_bound 实现代码 #include <vector>int lower_bound_index(const std::vector<int>& vec, const int& target) {int left 0;int right…...

Java 搭建个人博客基本框架

为了实现一个功能完善的个人博客系统&#xff0c;我们将使用Spring Boot作为框架&#xff0c;MySQL作为数据库&#xff0c;并引入Spring Security来处理用户认证和授权。以下是系统的详细设计和实现步骤&#xff1a; ## 项目结构 - src/main/java/com/blog - controller …...

停车场智能化管理:车位引导系统实现车位资源优化与数据分析

随着城市汽车保有量的不断增长&#xff0c;停车难问题日益凸显。尤其是在高峰时段&#xff0c;寻找停车位和取车成为了许多车主的头疼问题。为了解决这一难题&#xff0c;维小帮智能车位引导系统应运而生&#xff0c;它利用先进的技术手段&#xff0c;帮助车主快速找到停车位&a…...

梯度下降法

梯度下降法是一种在机器学习和深度学习中广泛使用的优化算法。它用于最小化某个函数&#xff0c;通常是损失函数或成本函数&#xff0c;通过迭代调整参数来找到函数的最小值点。梯度下降法的基本思想是从一个初始参数出发&#xff0c;沿着损失函数梯度&#xff08;导数&#xf…...

【高考志愿】光学工程

目录 一、专业概述 二、专业特点 三、研究和就业方向 3.1 研究方向 3.2 就业方向 四、光学工程专业排名 高考志愿选择光学工程专业无疑是一项既具深度又富挑战性的明智之举。这个古老而充满魅力的专业&#xff0c;正逐渐崭露其在现代社会中的重要性与独特魅力。 一、专业…...

Golang | Leetcode Golang题解之第205题同构字符串

题目&#xff1a; 题解&#xff1a; func isIsomorphic(s, t string) bool {s2t : map[byte]byte{}t2s : map[byte]byte{}for i : range s {x, y : s[i], t[i]if s2t[x] > 0 && s2t[x] ! y || t2s[y] > 0 && t2s[y] ! x {return false}s2t[x] yt2s[y] …...

【Unity】RPG2D龙城纷争(五)关卡编辑器之地图编辑

更新日期:2024年6月25日。 项目源码:本章发布 索引 简介关卡编辑器窗口类(LevelEditor)一、定义关卡编辑器窗口类二、两种编辑模式三、地块编辑模式1.关卡模板2.打开编辑窗口3.编辑器基本属性4.地块模板5.重新生成地图6.地图刷子7.刷地块源码链接简介 关卡编辑器将是我们配…...

音视频入门基础:H.264专题(4)——NALU Header:forbidden_zero_bit、nal_ref_idc、nal_unit_type简介

音视频入门基础&#xff1a;H.264专题系列文章&#xff1a; 音视频入门基础&#xff1a;H.264专题&#xff08;1&#xff09;——H.264官方文档下载 音视频入门基础&#xff1a;H.264专题&#xff08;2&#xff09;——使用FFmpeg命令生成H.264裸流文件 音视频入门基础&…...

设计模式和设计原则回顾

设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...

解决Ubuntu22.04 VMware失败的问题 ubuntu入门之二十八

现象1 打开VMware失败 Ubuntu升级之后打开VMware上报需要安装vmmon和vmnet&#xff0c;点击确认后如下提示 最终上报fail 解决方法 内核升级导致&#xff0c;需要在新内核下重新下载编译安装 查看版本 $ vmware -v VMware Workstation 17.5.1 build-23298084$ lsb_release…...

Cinnamon修改面板小工具图标

Cinnamon开始菜单-CSDN博客 设置模块都是做好的&#xff0c;比GNOME简单得多&#xff01; 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...

Spring AI 入门:Java 开发者的生成式 AI 实践之路

一、Spring AI 简介 在人工智能技术快速迭代的今天&#xff0c;Spring AI 作为 Spring 生态系统的新生力量&#xff0c;正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务&#xff08;如 OpenAI、Anthropic&#xff09;的无缝对接&…...

【C语言练习】080. 使用C语言实现简单的数据库操作

080. 使用C语言实现简单的数据库操作 080. 使用C语言实现简单的数据库操作使用原生APIODBC接口第三方库ORM框架文件模拟1. 安装SQLite2. 示例代码:使用SQLite创建数据库、表和插入数据3. 编译和运行4. 示例运行输出:5. 注意事项6. 总结080. 使用C语言实现简单的数据库操作 在…...

深入解析C++中的extern关键字:跨文件共享变量与函数的终极指南

&#x1f680; C extern 关键字深度解析&#xff1a;跨文件编程的终极指南 &#x1f4c5; 更新时间&#xff1a;2025年6月5日 &#x1f3f7;️ 标签&#xff1a;C | extern关键字 | 多文件编程 | 链接与声明 | 现代C 文章目录 前言&#x1f525;一、extern 是什么&#xff1f;&…...

【笔记】WSL 中 Rust 安装与测试完整记录

#工作记录 WSL 中 Rust 安装与测试完整记录 1. 运行环境 系统&#xff1a;Ubuntu 24.04 LTS (WSL2)架构&#xff1a;x86_64 (GNU/Linux)Rust 版本&#xff1a;rustc 1.87.0 (2025-05-09)Cargo 版本&#xff1a;cargo 1.87.0 (2025-05-06) 2. 安装 Rust 2.1 使用 Rust 官方安…...

加密通信 + 行为分析:运营商行业安全防御体系重构

在数字经济蓬勃发展的时代&#xff0c;运营商作为信息通信网络的核心枢纽&#xff0c;承载着海量用户数据与关键业务传输&#xff0c;其安全防御体系的可靠性直接关乎国家安全、社会稳定与企业发展。随着网络攻击手段的不断升级&#xff0c;传统安全防护体系逐渐暴露出局限性&a…...

Vue3 PC端 UI组件库我更推荐Naive UI

一、Vue3生态现状与UI库选择的重要性 随着Vue3的稳定发布和Composition API的广泛采用&#xff0c;前端开发者面临着UI组件库的重新选择。一个好的UI库不仅能提升开发效率&#xff0c;还能确保项目的长期可维护性。本文将对比三大主流Vue3 UI库&#xff08;Naive UI、Element …...

【java】【服务器】线程上下文丢失 是指什么

目录 ■前言 ■正文开始 线程上下文的核心组成部分 为什么会出现上下文丢失&#xff1f; 直观示例说明 为什么上下文如此重要&#xff1f; 解决上下文丢失的关键 总结 ■如果我想在servlet中使用线程&#xff0c;代码应该如何实现 推荐方案&#xff1a;使用 ManagedE…...