Vitis HLS 学习笔记--MAXI手动控制突发传输

目录

1. 简介

2. MAXI 突发传输详解

2.1 突发传输的前置条件

2.2 hls::burst_maxi 详解

2.2.1 基本知识

2.2.2 hls::burst_maxi 构造函数

2.2.3 hls::burst_maxi 读取方法

2.2.4 hls::burst_maxi 写入方法

2.3 示例一

2.4 示例二

3. 总结


1. 简介

这篇文章探讨了在《Vitis HLS 学习笔记--AXI4 主接口-CSDN博客》中介绍的AXI4主接口的突发传输。虽然适用于HLS工具能够自动推断突发传输的情况,但并非所有情况工具都能自动推断。文章提供了详细的操作方法和示例,帮助读者在各种情况下优化存储器访问。

2. MAXI 突发传输详解

2.1 突发传输的前置条件

突发前置条件

突发就是对连续的内存空间请求访问。突发必须满足下列前置条件才能成功启动突发最优化:

  • 请求必须全部为读取请求或者全部为写入请求。
  • 访问必须按单调递增顺序。
  • 访问必须为连续的内存空间,如果有两个存储器,它们之间需按正序彼此相邻且无间隔或重叠。
  • 读取/写入访问的次数(或突发长度)必须可在发出请求之前确定。要么编译时确定,如果在运行时计算得到突发长度,必须在发出读取/写入请求之前完成计算。
  • 如果将两个阵列绑定到同一个 M-AXI 端口,那么任意给定时间内,任一方向上最多仅针对一个阵列执行突发。
  • 突发请求的发起时间与完成时间之间不得存在任何依赖关系问题。

2.2 hls::burst_maxi 详解

2.2.1 基本知识

Vitis HLS 可以执行自动突发最优化,从用户代码汇总循环/函数自动推断并优化存储器访问,并在单个突发请求内执行特定大小的读取/写入操作。但突发传输也有要求的,这些要求有时可能难以满足,或者 HLS 工具无法正确推断出用户的突发传输需求。

如果你发现 HLS 工具自动突发传输未按期望方式工作,并且无法按需对设计进行最优化,那么可以使用hls::burst_maxi 对象来实现读取和写入传输事务,即使用手动突发。

使用手动突发需要掌握熟悉 AXI4 m_axi 协议,并且理解硬件传输事务建模。

hls::burst_maxi 类工作原理

hls::burst_maxi 类可以实现对 DDR 执行读/写访问,它可以控制 AXI4 总线信号上发送和接收请求:AW、AR、WDATA、BVALID 和 RDATA,通过这些操作就可以控制 AXI 调度器的突发行为。适配器可从调度器接收命令,并负责向 DDR 发送数据。这些请求将遵循用户指定的 INTERFACE 编译指示选项,例如 max_read_burst_length 和 max_write_burst_length等。

注:hls::burst_maxi 类方法应仅在内核代码中使用,不得在测试激励文件中使用。

关于适配器和调度器请参见下图:

2.2.2 hls::burst_maxi 构造函数

burst_maxi(const burst_maxi &B) : Ptr(B.Ptr) {}
burst_maxi(T *p) : Ptr(p) {}

2.2.3 hls::burst_maxi 读取方法

void read_request(size_t offset, size_t len);

此方法用于对 m_axi 适配器执行读取请求。如果 m_axi 适配器内部的读取请求队列未满,那么该函数就会立即返回,否则它会等待至空间变为可用为止。

  • offset:指定存储器偏移,将从该指定偏移位置读取数据
  • len:指定调度器突发长度。此突发长度将发送至适配器,随后,适配器即可将其转换为标准 AXI AMBA 协议
T read();

此方法用于将数据从 m_axi 适配器传输至调度器 FIFO。如果数据不可用,read() 将执行阻塞。read() 方法应调用 len 次,具体次数在 read_request() 中指定。

2.2.4 hls::burst_maxi 写入方法

void write_request(size_t offset, size_t len);

此方法用于对 m_axi 适配器执行写入请求。如果 m_axi 适配器内部的写入请求队列未满,那么该函数就会立即返回。

  • offset:指定存储器偏移,数据应写入该指定偏移位置
  • len:指定调度器突发长度。此突发长度将发送至适配器,随后,适配器即可将其转换为标准 AXI AMBA 协议
void write(const T &val, ap_int<sizeof(T)> byteenable_mask = -1);

此方法用于将数据从调度器的内部缓冲器传输到 m_axi 适配器。如果内部写入缓冲器已满,那么它会执行阻塞。byteenable_mask 用于在 WDATA 中启用字节。默认情况下,它将启用传输的所有字节。write() 方法应调用 len 次,具体次数在 write_request() 中指定。

void write_response();

此方法会执行阻塞,直至从全局存储器返回所有写入响应为止。此方法的调用次数应与 write_request() 相同。

2.3 示例一

提供一个原始代码样本,它使用指针实参从全局存储器读取数据:

void dut(int *A) {for (int i = 0; i < 64; i++) {
#pragma pipeline II=1... = A[i]}
}

修改代码,拆分A为 4 个请求(len 均为 16)从端口 A 放置到 m_axi 适配器上。

首先,指针需要被替换为 hls::burst_maxi<> 类。该适配器将其存储在 FIFO 内部,只要 AW/AR 总线可用,它就会将请求发送到全局存储器。其次,在 64 次循环迭代中,通过 read() 命令发出阻塞调用,调用将等待全局存储器返回的数据。最后,数据可用后,HLS 调度器将从 m_axi 适配器 FIFO 读取此数据。代码如下:

#include "hls_burst_maxi.h"
void dut(hls::burst_maxi<int> A) {// Issue 4 burst requestsA.read_request(0, 16); // request 16 elements, starting from A[0]A.read_request(128, 16); // request 16 elements, starting from A[128]A.read_request(256, 16); // request 16 elements, starting from A[256]A.read_request(384, 16); // request 16 elements, starting from A[384]for (int i = 0; i < 64; i++) {
#pragma pipeline II=1... = A.read(); // Read the requested data}
}

2.4 示例二

void trf(hls::burst_maxi<int> A) {A.write_request(0, 2);A.write(x); // write A[0]A.write_request(10, 1);A.write(x, 2); // write A[1] with byte enable 0010A.write(x); // write A[10]A.write_response(); // response of write_request(0, 2)A.write_response(); // response of write_request(10, 1)
}
  • 内核会将 2 个请求从端口 A 放置到适配器上,第一个请求的 len 为 2,第二个请求的 len 为 1,总计 2 个写入请求。
  • 它会发出对应的请求,因为总计突发长度为 3 条写入命令。
  • 适配器将这些请求存储在 FIFO 内部,只要 AW 和 WD 总线可用,它就会将请求和数据发送到全局存储器。
  • 最后,使用 2 条write_response 命令等待 2 个 write_requests 的响应。
     

3. 总结

本文分享了在Vitis HLS中使用AXI4主接口进行手动突发传输的方法。首先,解释了突发传输的前置条件,包括请求类型、顺序、连续性等。接着,介绍了通过hls::burst_maxi对象实现手动突发传输的方法,包括构造函数、读取和写入方法的使用。本文还提供了两个示例,展示了如何使用该对象进行数据读取和写入,并解释了相应的过程。

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

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

相关文章

ESP32-C3模组上跑通MQTT(1)

本文内容参考&#xff1a; 《ESP32-C3 物联网工程开发实战》 特此致谢&#xff01; 一、远程控制的介绍 什么是远程控制&#xff1f;顾名思义&#xff0c;远程控制就是远距离控制&#xff0c;是指控制设备&#xff08;如智能手机、计算机等网络设备&#xff09;通过广域网控制…

[笔试训练](十一)

目录 031&#xff1a;游游的水果大礼包 032&#xff1a;买卖股票的最好时机&#xff08;二&#xff09; 033&#xff1a;倒置字符串 031&#xff1a;游游的水果大礼包 游游的水果大礼包 (nowcoder.com) 题目&#xff1a; 题解&#xff1a; 枚举&#xff1a;依次枚举1号礼…

windows驱动开发-电源状态(一)

在windows设备驱动开发中&#xff0c;随着笔记本电脑的普及&#xff0c;低功耗要求的增加&#xff0c;设备电源状态越来越重要&#xff0c;和之前不一样&#xff0c;在以前&#xff0c;驱动仅仅只处理PNP的电源状态而已&#xff0c;现在需要处理非常多的电源状态和请求。 系统…

python中的self是什么

你对Python编程中的self真的了解吗? 当我们在Python编程的时候,尤其是写一个方法的时候,会自动补齐括号中的self,那么我们对它真的了解吗? Self 是什么?有什么作用? self指的是调用该函数的对象&#xff08;是一个实例&#xff09;,首先明确的是self只有在类中的方法中才…

掌握Spring Boot核心全攻略

本文介绍的内容包括&#xff1a;Spring Boot 的 pom文件、应用入口类、开发测试热启动&#xff0c;以及 Spring Boot 的配置文件。 1 pom 文件、应用入口类 1、pom 文件介绍 具体介绍可参见以下的代码注释&#xff1a; <?xml version"1.0" encoding"UTF-8&q…

WizTree去右上角抖动图标donate

希望有能力的网友去支持一波&#xff0c;捐赠无可厚非&#xff0c;做软件费精力要点捐赠可以&#xff0c;放个按钮就好&#xff0c;10秒抖一下子&#xff0c;让我觉得有点难受&#xff0c;收起了伸往钱包的小手。 工具 resource hacker官网https://www.angusj.com/resourceha…

超强动画制作软件blender

blender中文手册&#xff1a;Blender 4.1 Manual Blender 是一款集3D建模、渲染、动画、视频编辑、音频处理、游戏设计等多功能于一体的软件。由于其开源性质&#xff0c;它拥有庞大的用户群体和活跃的开发者社区&#xff0c;这使得Blender的功能和性能得到了不断的提升和优化…

FIFO Generate IP核使用——Data Counts页详解

在Vivado IDE中&#xff0c;当看到一个用于设置数据计数选项的选项卡时&#xff0c;需要注意的是&#xff0c;尽管某些选项值可能因为当前的配置而显示为灰色&#xff08;即不可选或已禁用&#xff09;&#xff0c;但IDE中显示的有效范围值实际上是你可以选择的真实值。即使某些…

Python 植物大战僵尸

文章目录 效果图项目结构实现思路源代码 效果图 项目结构 实现思路 下面是代码的实现思路&#xff1a; 导入必要的库和模块&#xff1a;首先&#xff0c;我们导入了Python的os、time库以及pygame库&#xff0c;还有植物大战僵尸游戏中用到的各个植物和僵尸的类。 初始化游戏和…

如何在Mac上恢复格式化硬盘的数据?

“嗨&#xff0c;我格式化了我的一个Mac硬盘&#xff0c;而没有使用Time Machine备份数据。这个硬盘被未知病毒感染了&#xff0c;所以我把它格式化为出厂设置。但是&#xff0c;我忘了备份我的文件。现在&#xff0c;我想恢复格式化的硬盘驱动器并恢复我的文档&#xff0c;您能…

uni-app(优医咨询)项目实战 - 第2天

学习目标: 掌握WXML获取节点信息的用法 知道如何修改 uni-ui 扩展组件的样式 掌握 uniForm 表单验证的使用方法 能够在 uni-app 中使用自定义字体图标 一、uni-app 基础知识 uni-app 是组合了 Vue 和微信小程序的相关技术知识,要求大家同时俱备 Vue 和原生小程序的开发基础。…

8 -- JavaSE总结

目录 Java语言发展 Java基础语法 Java流程控制 Java方法 Java数组 面向对象 异常 Java常用类 集合框架 IO流 多线程 网络编程 GUI Java SE&#xff08;Java Standard Edition&#xff0c;Java标准版&#xff09;是Java技术的核心和基础&#xff0c;也是Java ME和J…

JavaScript 动态网页实例 —— 日期时间应用

前言 日期和时间也是网站设计中不可或缺的重要内容。本章基于JavaScript中Date 对象的基本概念,介绍日期和时间的各种应用。鉴于其他章节已间接涉及部分内容,本章主要介绍各类不同时钟的设计,以及各种不同形式的时间的实现,同时,还涉及日历的设计和倒计时效果的实现。 本…

BeanFactory 源码浅析

BeanFactory 功能介绍 BeanFactory 是核心容器&#xff0c;负责管理 Bean 对象 BeanFactory 接口的功能只有一个 getBean() 方法BeanFactory 的实现类&#xff08;DefaultListableBeanFactory&#xff09;包含&#xff1a;控制反转、基本的依赖注入、Bean 生命周期的各种功能…

HR招聘面试时采用的在线人才测评,主要考察求职者哪些方面?

现如今的企业招聘求职者的时候&#xff0c;考察的方面是多样化的。以往很有可能只是考察求职者的业务能力&#xff0c;目前的大多数企业为了在竞争当中拥有更多的竞争力&#xff0c;企业人才测评的时候&#xff0c;往往更青睐于考察求职者多方面的能力。 对于求职者来说&#…

代码随想录算法训练营DAY48|C++动态规划Part9|121.买卖股票的最佳时机、122.买卖股票的最佳时机II、123.买卖股票的最佳时机III

文章目录 121.买卖股票的最佳时机思路CPP代码 122.买卖股票的最佳时机II思路CPP代码 123.买卖股票的最佳时机III思路CPP代码 121.买卖股票的最佳时机 力扣题目链接 文章讲解&#xff1a;121.买卖股票的最佳时机 视频讲解&#xff1a;动态规划之 LeetCode&#xff1a;121.买卖股…

【Mac】Lightroom Classic 2024 v13.1安装教程

软件介绍 Lightroom Classic 2024是Adobe公司推出的一款专业的数字图像处理软件&#xff0c;旨在为摄影师提供强大的工具和功能&#xff0c;以管理、编辑和分享他们的照片作品。以下是Lightroom Classic 2024的主要特点和功能&#xff1a; 数字照片管理&#xff1a; 提供直观…

如何在postman上提交文件格式的数据

如何在postman上提交文件格式的数据 今天在写一个文件上传的功能接口时&#xff0c;想用postman进行提交&#xff0c;花了些时间才找到在postman提交文件格式的数据。记录一下吧&#xff01; 1.打开postman&#xff0c;选择POST提交方式&#xff0c;然后在Params那一行的Head…

求职应聘找工作,如何看待企业在线人才测评

求职者面试的过程当中&#xff0c;除了要向求职的单位展现自身的业务能力之外&#xff0c;更需要展现其他方面的优势。企业人才测评对求职者存在哪些好处&#xff1f; 可能觉得参加测评只是面试的一部分&#xff0c;但是没有测评的情况下&#xff0c;求职者很有可能很难真正全…

【C++题解】1300. 小明暑假的零花钱

问题&#xff1a;1300. 小明暑假的零花钱 类型&#xff1a;多分支结构 题目描述&#xff1a; 小明同学的妈妈在期末考试之后决定根据小明的考试成绩奖励小明不同的暑假零花钱&#xff0c;如果考试成绩在90 分以上&#xff08;包括 90 分&#xff09;&#xff0c;零花钱是成绩…