Vitis HLS 学习笔记--IDE软件高效操作指引

目录

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

[2. 实用软件操作](#2. 实用软件操作)

[2.1 C/RTL Cosimulation 选项](#2.1 C/RTL Cosimulation 选项)

[2.2 Do not show this dialog again](#2.2 Do not show this dialog again)

[2.3 New Solution](#2.3 New Solution)

[2.4 对比 Solution](#2.4 对比 Solution)

[2.5 以命令行方式运行(windows)](#2.5 以命令行方式运行(windows))

[2.6 文本缩放快捷键](#2.6 文本缩放快捷键)

[2.7 查看和修改快捷键](#2.7 查看和修改快捷键)

[2.8 将Vitis HLS RTL 导入 Vivado IP](#2.8 将Vitis HLS RTL 导入 Vivado IP)

[3. Schedule Viewer](#3. Schedule Viewer)

[3.1 概览](#3.1 概览)

[3.2 示例一](#3.2 示例一)

[3.3 理解函数执行细节](#3.3 理解函数执行细节)

[4. 总结](#4. 总结)


1. 简介

本文持续更新,分享一些实用操作指引,为提高使用Vitis HLS IDE效率。

2. 实用软件操作

2.1 C/RTL Cosimulation 选项

2.2 Do not show this dialog again

可随时在Solution Settings中恢复或者设置。

2.3 New Solution

2.4 对比 Solution

选中两个solution即可对比

2.5 以命令行方式运行(windows)

D:\Xilinx\Vitis_HLS\2022.1\bin\vitis_hls_cmd.bat

Or 开始菜单中:

>> vitis_hls -gui

>> vitis_hls -i #命令行

2.6 文本缩放快捷键

Ctrl + =:放大文本

Ctrl + -:减小文本

2.7 查看和修改快捷键

2.8 将Vitis HLS RTL 导入 Vivado IP

3. Schedule Viewer

3.1 概览

调度查看器,显示函数的每项操作和每个控制步骤,以及执行操作和步骤的时钟周期。

界面最左侧Operation\Control Step是指程序的操作码运行过程。

右侧右侧是时序视图,在同一周期内出现的指令,它们是并行执行的。

属性解释:
Bitwidth,位宽,对应运算的位宽。
Name,名称,包含代码的位置。
Op Latency,运算时延,显示运算或存储的绑定的默认时延或指定时延。
Opcode:操作码,请区分"指令码"。

指令码是指令的完整二进制编码,包含了 操作码 以及用于指定 操作数操作细节
操作码通常包含在指令码前几位,表示指令的类型和功能,例如加法、乘法、逻辑操作等。

3.2 示例一

复制代码
#include <ap_int.h>

void foo(ap_int<8>  xin[3],
         ap_int<8>  a,
         ap_int<8>  b,
         ap_int<8>  c,
         ap_int<17> yo[3]) {

    int i = 0;
loop:
    for(i = 0; i < 3; i++){
        yo[i] = a * xin[i] + b + c;
    }
}

编译器会自动执行优化

3.3 理解函数执行细节

在linux中,可以通过以下命令来了解函数的具体调用过程:

gcc -E tt.c -o tt.i

gcc -S tt.i -o tt.S

总结:

  • 调用函数后,压栈pushq最先被执行
  • 然后参数复制movl到%rbp(base pointer)区
  • 返回值存放在%eax(accumulator)寄存器中
  • 保存返回值后,出栈popq
  • 出栈后,函数返回ret
  • 主函数读取返回值%eax

4. 总结

本文持续更新,计划将Vitis HLS所用到的高级操作全覆盖。

相关推荐
Shang1809893572621 分钟前
MS2107高性能USB 2.0视频信号和音频采集,支持NTSC/PAL制式,适用于低成本视频采集设备
嵌入式硬件·fpga开发·音视频·硬件工程·信息与通信·dsp开发
浓墨染彩霞39 分钟前
Java----set
java·经验分享·笔记
浮游本尊44 分钟前
React 18.x 学习计划 - 第五天:React状态管理
前端·学习·react.js
baole9631 小时前
YOLOv4简单基础学习
学习·yolo·目标跟踪
Pluchon2 小时前
硅基计划5.0 MySQL 叁 E-R关系图&联合/多表查询&三大连接&子查询&合并查询
开发语言·数据库·学习·mysql
爱滑雪的码农2 小时前
微信小程序页面配置,基本语法,页面切换,tabbar全局配置
笔记
学工科的皮皮志^_^2 小时前
网口学习理解
经验分享·笔记·嵌入式硬件·学习·fpga开发·以太网
张人玉3 小时前
C#WPF如何跳转页面
笔记·ui·c#·wpf
山顶听风3 小时前
Flask应用改用Waitress运行
前端·笔记·python·flask
后端小张4 小时前
【鸿蒙开发手册】重生之我要学习鸿蒙HarmonyOS开发
开发语言·学习·华为·架构·harmonyos·鸿蒙·鸿蒙系统