目录
2.1 Aggregation_Disaggregation 聚合与解聚
2.1.1 aggregation_of_m_axi_ports
2.1.2 aggregation_of_nested_structs
2.1.4 auto_disaggregation_of_struct
2.1.5 disaggregation_of_axis_port
2.3.2 using_axi_lite_with_user_defined_offset
2.4.3 using_axi_stream_no_side_channel_data
2.4.4 using_axi_stream_with_side_channel_data
2.4.5 using_axi_stream_with_struct
2.4.6 using_axis_array_stream_no_side_channel_data
3.3.4 using_free_running_pipeline
4.1.2.6 using_stream_of_blocks
4.2 mixed_control_and_data_driven
5.4 free_running_kernel_remerge_ii4to1
5.6 using_arbitrary_precision_arith
5.7 using_arbitrary_precision_casting
5.11 variable_bound_loops 变量循环边界
6.1.4 static_array_of_struct_with_array_RAM
6.1.5 static_struct_with_array_RAM
6.1.6 static_struct_with_array_RAM_Versal
GitHub - Xilinx/Vitis-HLS-Introductory-ExamplesContribute to Xilinx/Vitis-HLS-Introductory-Examples development by creating an account on GitHub.https://github.com/Xilinx/Vitis-HLS-Introductory-Examples此示例集与先前的博客《Vitis HLS 学习笔记--HLS优化指令示例-目录-CSDN博客》相得益彰,分别聚焦于展示HLS功能和演示HLS优化指令。与之前的博客相比,需要同时编译宿主代码和PL(可编程逻辑)代码,而本示例集则可完全在Vitis HLS仿真环境下运行,使得效果展示更为直观。这两者互为补充,共同促进了对Vitis HLS的深入理解和掌握。
本示例集分类如下:
#pragma HLS AGGREGATE compact=auto
嵌套结构体
迭代间隔违规
Error Checking and Correcting
如果在设计中并未发生自动突发,则可使用 hls::burst_maxi 数据类型执行手动突发
可选参数max_widen_bitwidth,因为Compiler会根据数据类型自动进行数据位宽的调整。
achive II=1 by removing redundant memory accesses in the code。
BIND_STORAGE type=ram_2p impl=uram,DEPENDENCE inter WAR false,WAR is Write-After-Read
sin_table[i] = (din1_t)(32768.0 * real_val);
INTERFACE m_axi port=a depth=50
hls::stream
hls::stream
无信道侧,hls::axis
含信道侧,hls::axis
查看Slide:“HLS - 接口综合:典范”
实例化函数
分层函数,__SYNTHESIS__
循环边界是变量、循环体出现在外层
循环边界是固定常数,循环体只在最内层
DATAFLOW
(a-->t2, t2->t3) (b->k1; k1->k2; k2-k3)
(a-->t1, t1->t3) (b->k1; k1->k2; k2-k3)
(a-->t1, t1->t2) (b->k1; k1->k2; k2-k3)
use FIFOs instead of the default PIPOs on host
config_dataflow -default_channel fifo -fifo_depth 2
#pragma HLS performance target_ti=32,ti=transaction interval,事务间隔
hls::stream_of_blocks
hls_thread_local hls::stream
hls_thread_local hls::task t[4];
函数无返回,但指针修改了数组中的数据,实际上可以被视为函数的输出
static 变量通常会在硬件中实现为一个寄存器或存储器单元,其值会在多个调用之间保持不变
局部的静态变量,是靠编译器实现作用区域限制的
默认ap_hs
可通过Tcl脚本命令实现ap_fifo,也可以通过编译指令#pragma HLS INTERFACE
双重指针,应尽量避免使用,因为双重指针会增加访问数据时的间接性,从而导致额外的逻辑开销
pipline off,unroll
使用了自定义的sqrt函数,建议还是优先使用
Iteration Interval,ap_ctrl_none
hls::vector
变量循环边界问题:该变量为函数参数,在编译时未知,需要运行时传递。
- Loop: for (x=0; x
- out_accum += A[x];
- }
6. Misc
6.1 initialization_and_reset
6.1.1 global_array_RAM
全局数组,是指在函数外部定义的数组,ap_int<10> A[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
6.1.2 static_array_RAM
static ap_int<10> A[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
6.1.3 static_array_ROM
BIND_STORAGE variable=A type=ROM_1P impl=BRAM;
6.1.4 static_array_of_struct_with_array_RAM
数组结构体;
6.1.5 static_struct_with_array_RAM
结构体
6.1.6 static_struct_with_array_RAM_Versal
6.2 malloc_removed
#include "malloc_removed.h"
6.3 rtl_as_blackbox
7. 学习规划
这个示例集含有丰富的内容,我将在未来的博客文章中,专门挑选其中的重要部分进行详细讨论,并会在这里附上相关链接。
这个目录也方便我快速检索到相关知识点。