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

news2024/10/7 10:23:19

目录

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 requests
    A.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 0010
    A.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.coloradmin.cn/o/1639911.html

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

相关文章

Java 新手上路常见的5个经典问题,你遇到过吗?

当我们开始学习一门新的编程语言或者开发平台时&#xff0c;经常会遇到一些常见的问题。这些问题不仅是学习过程中的一部分&#xff0c;也是成长和提高的机会。 1. 空指针异常&#xff08;NullPointerException&#xff09; 空指针异常是 Java 开发中最常见的问题之一。它的产…

【AI大模型应用开发】3. RAG初探 - 动手实现一个最简单的RAG应用

0. 什么是RAG 大模型也不是万能的&#xff0c;也有局限性。 LLM 的知识不是实时的LLM 可能不知道你私有的领域/业务知识 RAG&#xff08;Retrieval Augmented Generation&#xff09;顾名思义&#xff1a;通过检索的方法来增强生成模型的能力。你可以把这个过程想象成开卷考…

TCP协议在物联网中的实战

一、TCP协议介绍 网上对TCP协议介绍众多&#xff0c;本人按照自己的理解简单介绍一下。 TCP&#xff08;Transmission Control Protocol&#xff0c; 传输控制协议&#xff09;是一种面向连接的、可靠的、基于字节流的传输控制层通信协议。 1.1 协议机制 1.1.1 三次握手 &…

基于Springboot的民宿管理平台

基于SpringbootVue的民宿管理平台设计与实现 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringbootMybatis工具&#xff1a;IDEA、Maven、Navicat 系统展示 用户登录 首页 民宿信息 后台登录 后台首页 用户管理 商家管理 民宿信息管理 房间类型管理 …

C. Assembly via Remainders

C.通过余数组装 每次测试时限&#xff1a;2 秒 每次测试的内存限制&#xff1a;256 兆字节 输入&#xff1a;标准输入 输出&#xff1a;标准输出 思路分析 我们用arr数组存放输入的数据,用brr代表代表答案数组,我们可以看到答案的第一位是都是arr的首位1,然后我们观察可…

【研发管理】产品经理知识体系-组合管理

导读&#xff1a;新产品开发的组合管理是一个重要的过程&#xff0c;它涉及到对一系列新产品开发项目进行策略性选择、优先级排序、资源分配和监控。这个过程旨在确保企业能够最大化地利用有限的资源&#xff0c;以实现其战略目标。 目录 1、组合管理、五大目标 2、组合管理的…

Numerical Analysis(byRichard.L..Burden)【pdf高清英文原版】

专栏导读 作者简介&#xff1a;工学博士&#xff0c;高级工程师&#xff0c;专注于工业软件算法研究本文已收录于专栏&#xff1a;《有限元编程从入门到精通》本专栏旨在提供 1.以案例的形式讲解各类有限元问题的程序实现&#xff0c;并提供所有案例完整源码&#xff1b;2.单元…

Linux下top命令指标说明

目录 Linux下top命令指标说明1. 概览2. CPU利用率3. 内存利用率4. 进程信息 Linux下top命令指标说明 在Linux系统中&#xff0c;top 命令是一个用于实时监视系统运行状态的工具。通过 top 命令&#xff0c;我们可以了解系统的负载情况、CPU利用率、内存使用情况以及各个进程的…

k8s环境部署gpu以及CUDA兼容性分析

本文记录和学习在实用gpu搭建k8s支持上层应用时的功能实践和遇到的问题。 1. 基础概念 CUDA本质上就是NVIDIA专为通用高性能并行计算设计的一套计算平台和编程模型&#xff0c;换句话使用GPU并行编程的规范方法&#xff0c;所以CUDA在软件层面包含了众多库&#xff0c; 那这里…

《QT实用小工具·五十一》带动画的 CheckBox

1、概述 源码放在文章末尾 该项目实现了带动画效果的多选框&#xff0c;鼠标放在上面或者选中都会呈现炫酷的动画效果&#xff0c;demo演示如下&#xff1a; 项目部分代码如下所示&#xff1a; #ifndef LINEARCHECKBOX_H #define LINEARCHECKBOX_H#include <QCheckBox> …

图像处理1,灰度,data,for循环批处理图片,图片属性查看,图片单通道查看,椒盐噪声的生成,滤波处理,图像分割

图像处理1 灰度处理data库的使用for循环批处理图像对图像属性的查看图片类型图片尺寸图片宽度图像高度通道数总像素个数最大像素值最小像素值&#xff0c;像素平均值图像点像素值 for循环分别显示图像rgb通道椒盐噪声的生成中值滤波处理高斯模糊处理图像切割 灰度处理 from sk…

多国语言免费在线客服系统源码,网站在线客服系统,网页在线客服软件在线聊天通讯平台

详情介绍 多国语言免费在线客服系统源码,网站在线客服系统,网页在线客服软件在线聊天通讯平台 新款在线客服系统全开源无加密:多商户、国际化多语言、智能机器人、自动回复、语音聊天、 文件发送、系统强力防黑加固、不限坐席、国际外贸、超多功能 支持手机移动端和PC网页…

如何从Mac电脑恢复任何删除的视频

Microsoft Office是包括Mac用户在内的人们在世界各地创建文档时使用的最佳软件之一。该软件允许您创建任何类型的文件&#xff0c;如演示文稿、帐户文件和书面文件。您可以使用 MS Office 来完成。所有Microsoft文档都可以在Mac上使用。大多数情况下&#xff0c;您处理文档&…

私有开源LLM实例的三个考虑因素

原文地址&#xff1a;three-considerations-for-private-open-source-llm-instances 2024 年 4 月 29 日 在生产应用中使用商业 LLM APIs 会带来明确且经过充分研究的风险。因此&#xff0c;企业越来越多地转向利用开源的私有托管LLM实例&#xff0c;并通过RAG技术进行增强。 介…

RCE学习

从最近的xyctf中&#xff0c;最大的感受就是自己的rce基础并不牢固&#xff0c;所以马上来恶补一下 漏洞成因 php和其他语言有很多能够执行系统命令或执行其他php代码的函数&#xff0c;因为开发者的使用不当&#xff0c;使得用户能够控制传递给执行命令的函数的参数&#xf…

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

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

clang:在 Win10 上编译 MIDI 音乐程序

先从 Microsoft C Build Tools - Visual Studio 下载 1.73GB 安装 "Microsoft C Build Tools“ 访问 Swift.org - Download Swift 找到 Windows 10&#xff1a;x86_64 下载 swift-5.10-RELEASE-windows10.exe 大约490MB 建议安装在 D:\Swift\ &#xff0c;安装后大约占…

【Linux系统编程】32.线程同步、锁的使用、互斥锁管理

目录 线程同步 锁的使用 注意事项 pthread_mutex_init 注意 参数mutex 参数attr 返回值 动态初始化 静态初始化 pthread_mutex_destroy 参数mutex 返回值 pthread_mutex_lock 参数mutex 返回值 pthread_mutex_unlock 参数mutex 返回值 pthread_mutex_trylo…

JAVA面试之MQ

如何保证消息的可靠传输&#xff1f;如果消息丢了怎么办 数据的丢失问题&#xff0c;可能出现在生产者、MQ、消费者中。 &#xff08;1&#xff09;生产者发送消息时丢失&#xff1a; ①生产者发送消息时连接MQ失败 ②生产者发送消息到达MQ后未找到Exchange(交换机) ③生产者发…

Python | Leetcode Python题解之第64题最小路径和

题目&#xff1a; 题解&#xff1a; class Solution:def minPathSum(self, grid: List[List[int]]) -> int:if not grid or not grid[0]:return 0rows, columns len(grid), len(grid[0])dp [[0] * columns for _ in range(rows)]dp[0][0] grid[0][0]for i in range(1, r…