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

目录

[1. 简介](#1. 简介)

[2. 详细分析](#2. 详细分析)

[2.1 使用场景区别](#2.1 使用场景区别)

[2.2 ap_continue 行为详解](#2.2 ap_continue 行为详解)

[2.3 ap_ctrl_chain 行为详解](#2.3 ap_ctrl_chain 行为详解)

[3. 总结](#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 变为低电平,设计将完成当前传输事务,然后停止操作。
  1. 本模块可读取输入端口上的数据(来自上游模块)。

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

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

  4. ap_continue 反压信号解释:

  • 如果 ap_continue 为高电平,且 ap_done 也为高电平,那么内核将继续操作。
  • 如果下游块无法接收新数据输入,则下游模块控制 ap_continue 保持低电平,控制 ap_done 信号保持高电平状,直到下游模块处理完毕,控制 ap_continue 变为高电平状态后继续执行。
  1. 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 为高电平状态,那么下一项传输事务将立即启动,且设计将继续操作。
  1. 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,它不包含握手信号,完全由数据可用性来驱动模块操作。

相关推荐
ctrey_40 分钟前
2024-11-1 学习人工智能的Day20 openCV(2)
人工智能·opencv·学习
Dola_Pan1 小时前
C++算法和竞赛:哈希算法、动态规划DP算法、贪心算法、博弈算法
c++·算法·哈希算法
十年之少1 小时前
由中文乱码引来的一系列学习——Qt
学习
yanlou2331 小时前
KMP算法,next数组详解(c++)
开发语言·c++·kmp算法
小林熬夜学编程1 小时前
【Linux系统编程】第四十一弹---线程深度解析:从地址空间到多线程实践
linux·c语言·开发语言·c++·算法
A-超1 小时前
vue3展示pag格式动态图
笔记
阿洵Rain2 小时前
【C++】哈希
数据结构·c++·算法·list·哈希算法
u0101526582 小时前
STM32F103C8T6学习笔记2--LED流水灯与蜂鸣器
笔记·stm32·学习
weixin_518285052 小时前
深度学习笔记10-多分类
人工智能·笔记·深度学习
Liknana2 小时前
C++ shared_ptr 动态内存
开发语言·c++