Vitis HLS 学习笔记--块级控制协议-ap_ctrl_chain/ap_ctrl_hs/ap_ctrl_none

目录

1. 简介

2. 详细分析

2.1 使用场景区别

2.2 ap_continue 行为详解

2.3 ap_ctrl_chain 行为详解

3. 总结


1. 简介

块级控制协议允许硬件模块表明:

  • 何时可以开始处理数据。
  • 何时完成了数据处理。
  • 以及何时处于空闲状态,准备接受新的数据输入。

这些信号用于本模块在与其他硬件组件交互时,同步和控制硬件模块的行为。例如,ap_start信号可以触发模块开始执行操作,而ap_done信号则表明操作已经完成,输出数据可以被读取。

区分端口级I/O协议,负责管理数据的实际输入和输出。端口级I/O协议涉及到如何将数据传递给模块的输入端口,以及如何从模块的输出端口获取数据。

块级控制协议是Vitis HLS设计中的一个关键组成部分,它确保了硬件模块能够有效地同步和控制其操作流程。

2. 详细分析

2.1 使用场景区别

ap_ctrl_chain 协议和 ap_ctrl_hs 协议

  • 这两种协议用于控制驱动的TLP
  • 它们可以用于顺序执行和流水线执行。
  • ap_ctrl_chain 协议与 ap_ctrl_hs 类似,但它增加了一个 ap_continue 信号,允许下游模块控制上游模块的运行或终止

ap_ctrl_none 协议

对于数据驱动的TLP,必须使用 ap_ctrl_none 协议。

ap_ctrl_none 没有握手信号 ap_start、ap_idle、ap_ready 和 ap_done。这允许硬件模块完全由数据可用性来驱动,而不是由控制信号来驱动。

注:可以观察到 ap_ctrl_none 有 ap_start、ap_idle、ap_ready 和 ap_done 等信号,但会被设为高电平并且会被优化掉。

2.2 ap_continue 行为详解

使用示例说明,ap_continue 信号的行为:

  • 内核的第 1 项传输事务完成后,第 2 项传输事务立即启动,因为 ap_continue 为高电平状态,且 ap_done 为高电平状态。
  • 内核的第 2 项传输事务结束后将停止,直至 ap_continue 断言为高电平有效为止。

图片引用自《UG1399》

2.3 ap_ctrl_chain 行为详解

时序图会在复位后显示以下行为:

1. ap_start 变高电平,模块激活。

2. ap_idle 立即变为低电平,退出空闲状态。

3. ap_start 信号必须保持处于高电平状态,直至下游模块 ap_ready 信号传递高电平状态。当 ap_ready 达到高电平状态后:

  • 如果 ap_start 保持高电平,设计将启动下一项传输事务。
  • 如果 ap_start 变为低电平,设计将完成当前传输事务,然后停止操作。

4. 本模块可读取输入端口上的数据(来自上游模块)。

5. 本模块可将数据写入输出端口(传递至下游模块)。
注释:输入和输出端口还可指定独立于控制协议的端口级 I/O 协议。

6. 当模块完成操作后,ap_done 输出会变为高电平状态。
注释:如果存在 ap_return 端口,那么当 ap_done 处于高电平状态时,此端口上的数据将变为有效。因此,ap_done 信号还用于指示 ap_return 输出上的数据有效。

7. ap_continue 反压信号解释:

  • 如果 ap_continue 为高电平,且 ap_done 也为高电平,那么内核将继续操作。
  • 如果下游块无法接收新数据输入,则下游模块控制 ap_continue 保持低电平,控制 ap_done 信号保持高电平状,直到下游模块处理完毕,控制 ap_continue 变为高电平状态后继续执行。

8. ap_ready 信号解释:

  • 下游块的 ap_ready 信号可直接驱动 ap_continue 信号。
  • ap_ready 信号处于不活动状态,直至设计开始操作为止。
  • 在非流水打拍设计中,ap_ready 信号与 ap_done 同时断言有效。
  • 在流水打拍设计中,当 ap_start 采样结果为高电平后,ap_ready 信号可能在任意周期变为高电平状态。这取决于设计的流水打拍方式。
  • 如果 ap_start 信号为低电平状态,而 ap_ready 为高电平状态,那么设计将持续执行操作,直至 ap_done 变为高电平状态后停止操作。
  • 如果 ap_start 信号为高电平状态,且 ap_ready 为高电平状态,那么下一项传输事务将立即启动,且设计将继续操作。

9. ap_idle 信号解释:

  • 用于指示设计何时处于空闲且不执行操作状态。
  • 如果 ap_start 信号为低电平状态,而 ap_ready 为高电平状态,那么设计将停止操作,而 ap_idle 信号将在达成 ap_done 后,再经过 1 个周期后变为高电平状态。
  • 如果 ap_start 信号为高电平状态,且 ap_ready 为高电平状态,那么设计将继续操作,且 ap_idle 信号保持处于低电平状态。

3. 总结

当设计硬件模块时,块级控制协议是至关重要的组成部分。这些协议允许模块同步和控制其操作流程,包括何时开始处理数据、何时完成数据处理以及何时处于空闲状态准备接受新的数据输入。其中,ap_ctrl_chain 和 ap_ctrl_hs 协议用于控制驱动的TLP,可以用于顺序执行和流水线执行。而 ap_ctrl_none 协议适用于数据驱动的TLP,它不包含握手信号,完全由数据可用性来驱动模块操作。

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

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

相关文章

C: error: request for member ‘tv_nsec‘ in something not a structure or union

文章目录 错误源代码原因是少了初始化用的逗号总结 错误 字面意思是,在非结构体,非联合体的某些事物里,请求成员(赋值)tv_nsec。 time.c:8:3: error: request for member tv_nsec in something not a structure or u…

这么多不同接口的固态硬盘,你选对了嘛!

固态硬盘大家都不陌生,玩游戏、办公存储都会用到。如果自己想要给电脑或笔记本升级下存储,想要存储更多的文件,该怎么选购不同类型的SSD固态盘呐,下面就来认识下日常使用中常见的固态硬盘。 固态硬盘(Solid State Drive, SSD)作为数据存储技术的革新力量,其接口类型的选…

【深度 Q 学习-01】 Q学习概念和python实现

文章目录 一、说明二、深度 Q 学习概念三、python实现四、结论 关键词:Deep Q-Networks 一、说明 在强化学习 (RL) 中,Q 学习是一种基础算法,它通过学习策略来最大化累积奖励,从而帮助智能体导航其环境。它…

气膜建筑的运营成本解析:高效节能的运作模式—轻空间

气膜建筑以其独特的优势和广泛的应用吸引了大量关注。然而,许多人对其持续吹气的运营成本产生了疑问。实际上,气膜建筑通过智能控制系统和高效的风机管理,大大降低了运营成本。本文将以2000平方米的气膜建筑为例,详细解析其运行成…

【PHP】半小时粒度填充一星期时间段

只能输入0和1,最大336位; 按照特定时间段时,01010100010010……表示指定特殊时段,半小时为粒度,用0、1标识是否选中,1为选中,0为未选中。一天24小时,即每天24 * 248位,共…

Vue3 - 实现一个雨水滴落的动画效果

在 Vue 3 中实现一个雨水滴落的动画效果,可以使用 HTML5 的 <canvas> 元素和 JavaScript 来绘制和控制动画。 以下是一个实现雨水滴落效果的示例: 创建一个 Vue 3 项目 首先,确保你已经创建了一个 Vue 3 项目。如果还没有,可以使用 Vue CLI 来创建: vue create r…

2024年社会发展、人文艺术与文化国际会议(ICSDHAC 2024)

2024年社会发展、人文艺术与文化国际会议&#xff08;ICSDHAC 2024&#xff09; 会议简介 2024年国际社会发展、人文、艺术和文化会议&#xff08;ICSDHAC 2024&#xff09;将在广州举行。会议旨在为从事社会发展、人文、艺术和文化研究的专家学者提供一个平台&#xff0c;分…

字符串操作:写一个方法,实现字符串的反转,如:输入abc,输出cba

import java.util.Scanner; public class Test_A15 {public static void main(String[] args){String strA"";System.out.println("请输入一串字符串:");Scanner scannernew Scanner(System.in);strAscanner.next();Test_A15 T15new Test_A15();String re…

leetCode.86. 分隔链表

leetCode.86. 分隔链表 题目思路&#xff1a; 代码 class Solution { public:ListNode* partition(ListNode* head, int x) {auto lh new ListNode(-1), rh new ListNode(-1);auto lt lh, rt rh;for(auto p head; p; p p->next ) {if(p->val < x) {lt lt->…

Midjourney保姆级教程(五):Midjourney图生图

Midjourney生成图片的方式除了使用文字描述生成图片外&#xff0c;还有“图生图”的方式&#xff0c;可以让生成的图片更接近参考的图片。 今天我们来聊聊“图生图”的方式。 一、模仿获取propmt 很多时候&#xff0c;我们不知道画什么内容的图片&#xff0c;大家可以关注内…

vue项目引入json/js文件批量或单个方法

vue项目 json // 方式一 &#xff1a; 将文件内容完整的引入 import json from ./src/assets/xxx.json console.log(json) console.log(---)// 方式二 &#xff1a; 部分引入-名称必须是文件中定义的key import {name1,name2} from ./src/assets/xxx.json console.log(name1)…

SRS视频服务器应用研究

1.SRS尝试从源码编译启动 1.1.安装ubuntu 下载镜像文件 使用VMWare安装&#xff0c;过程中出现蓝屏&#xff0c;后将VM的软件版本从15.5升级到17&#xff0c;就正常了。 1.2.更新ubuntu依赖

第二十四章多栏布局解决方案(什么是自适应?/)

什么是自适应? 指能使网页自适应显示在不同大小终端设备上新网页设计方式及技术.简单的来说自适应就是让同一个页面自动适应不同大小的设备&#xff0c;从而解决为不同设备提供不同版本的页面问题。 1&#xff0e;两列自适应 两列自适应布局是指左侧固定宽度&#xff0c;右…

低代码开发与人工智能技术在商品推荐系统中的应用

引言 低代码开发和人工智能技术的背景和重要性 随着数字化转型的深入&#xff0c;企业在信息技术领域面临着前所未有的挑战和机遇。快速变化的市场需求、日益复杂的技术环境以及高度竞争的商业环境&#xff0c;迫使企业不断寻求高效的开发和运营解决方案。低代码开发平台应运而…

Java基础入门day58

day58 EL表达式 概念 EL&#xff1a;expression language EL使得JSP写起来更简单、简介&#xff0c;主要用于获取作用域中的数据 语法 可以使用${}获取指定作用域中的数据 用于替换作用域.getAttribute("name") ${scope.name}获取指定的某个作用域中的数据 ${name}…

【java-数据结构19-队列的模拟实现】

上篇文章&#xff0c;小编已经带大家一起认识了队列&#xff0c;并且对队列的方法进行调用测试&#xff0c;下面我们将模拟实现一个队列&#xff0c;话不多说&#xff0c;上正文~ 1.队列的模拟实现 队列的实现方法和链表的实现方式一模一样&#xff0c;这里我们首选双链表&…

VirtualBox虚拟机与bhyve虚拟机冲突问题解决@FreeBSD

问题 在安装完bhyve虚拟系统的主机上启动VirtualBox虚拟机的时候&#xff0c;报错&#xff1a;不能为虚拟电脑 debian 打开一个新任务. VirtualBox cant operate in VMX root mode. Please close all other virtualization programs. (VERR_VMX_IN_VMX_ROOT_MODE). 返回 代码…

UWP与WPF:微软两大UI框架

在微软的开发者生态系统中&#xff0c;UWP(Universal Windows Platform)与WPF(Windows Presentation Foundation)是构建Windows应用的两大明星框架。它们各自携带独特的设计理念和技术特性&#xff0c;服务于不同的开发需求和应用场景。本文将深入探讨这两者之间的异同&#xf…

项目成功的关键要素:进度管理

在项目管理中&#xff0c;进度管理是决定项目成败的关键因素之一。它关乎项目能否在预定的时间范围内高效、准确地完成既定目标。 一、进度管理的重要性 1、时间控制&#xff1a;项目的成功往往与时间的把握息息相关。进度管理能够确保项目在既定的时间框架内有序进行&#x…

uni-app学习完结

昨天空余一天&#xff0c;并未写记录&#xff0c;是昨天属于项目完结&#xff0c;这里把最后的打包上线等这里说下。 打包成微信小程序 打包成微信小程序&#xff0c;这需要再微信公众平台里面&#xff0c;进行登陆和设置。这里说下&#xff0c;注册的后&#xff0c;选择需要…