對于Vivado Hls來說,輸入包括Tesbench,C/C++源代碼和Directives,相應的輸出為IP Catalog,DSP和SysGen,特別的,一個工程只能有一個頂層函數用于綜和,這個頂層函數下面的子函數也是可以被綜合的,會生成相應的VHDL和Verilog代碼,所以,C綜合后的RTL代碼結構通常是跟原始C描述的結構是一致的,除非是子函數功能很簡單,所需要的邏輯量很小。 通常在main函數以下的函數都可以被綜合,也就是說,并不是所有的C/C++都可以被綜合,動態內存分配和涉及到操作系統層面的操作不可以被綜合。
本文結構框架:
1.Creat New Project新建文檔:
新建一個Project name,點next(這里選取簡單的4選1數據選擇器為例,主要是說明流程)
在Add Files里添加mux41.c文件,點next
添加mux41_test測試文件,點next
點Part,這里選擇Board下面的Zedboard Zynq開發板,然后點OK和finish
注釋:
mux41.c代碼: #include "mux41.h" int1 mux41(int1 sig_a, int1 sig_b,int1 sig_c,int1 sig_d, int select) { if(select==0) return sig_a; else if(select==1) return sig_b; else if(select==2) return sig_c; else if(select==3) return sig_d; } mux41.h代碼:(頭文件) #include mux41_tb代碼: #include #include "mux41.h" int main(void) { int res1 = 0; int res2 = 0; int res3 = 0; int res4 = 0; res1=mux41(1,0,0,0,0); res2=mux41(0,1,0,0,1); res3=mux41(0,0,1,0,2); res4=mux41(0,0,0,1,3); if(res1 && res2 && res3 && res4) printf("test passed, well done!/n"); return 0; }
2.C simulation:
在菜單里Project>Run C simulation,C simulation可以得到csim文件
從圖中看到,可以看到test passed,well done!,證明結果是正確的:
注意綜合得到的verilog代碼的可讀性很差,不需要讀懂,所以大多數優化都在C這個層面去做的,下面是綜合后的verilog代碼:
// ============================================================== // RTL generated by Vivado(TM) HLS - High-Level Synthesis from C, C++ and SystemC // Version: 2016.3 // Copyright (C) 1986-2016 Xilinx, Inc. All Rights Reserved. // // =========================================================== `timescale 1 ns / 1 ps (* CORE_GENERATION_INFO="mux41,hls_ip_2016_3,{HLS_INPUT_TYPE=c,HLS_INPUT_FLOAT=0,HLS_INPUT_FIXED=1,HLS_INPUT_PART=xc7z020clg484- 1,HLS_INPUT_CLOCK=10.000000,HLS_INPUT_ARCH=others,HLS_SYN_CLOCK=5.258000,HLS_SYN_LAT=0,HLS_SYN_TPT=none,HLS_SYN_MEM=0,HLS_SYN_DSP=0,HLS_SYN_FF=0,HLS_SYN_LUT=41}" *) module mux41 ( ap_start, ap_done, ap_idle, ap_ready, sig_a, sig_b, sig_c, sig_d, select_r, ap_return ); parameter ap_const_lv32_0 = 32'b00000000000000000000000000000000; parameter ap_const_lv32_1 = 32'b1; parameter ap_const_lv32_2 = 32'b10; input ap_start; output ap_done; output ap_idle; output ap_ready; input [0:0] sig_a; input [0:0] sig_b; input [0:0] sig_c; input [0:0] sig_d; input [31:0] select_r; output [0:0] ap_return; wire [0:0] tmp_fu_60_p2; wire [0:0] tmp_1_fu_66_p2; wire [0:0] sel_tmp1_fu_86_p2; wire [0:0] sel_tmp2_fu_92_p2; wire [0:0] sel_tmp_fu_78_p3; wire [0:0] tmp_2_fu_72_p2; wire [0:0] tmp7_fu_106_p2; wire [0:0] sel_tmp5_fu_112_p2; wire [0:0] p_0_fu_98_p3; assign ap_done = ap_start; assign ap_idle = 1'b1; assign ap_ready = ap_start; assign ap_return = ((sel_tmp5_fu_112_p2[0:0] === 1'b1) ? p_0_fu_98_p3 : sig_d); assign p_0_fu_98_p3 = ((sel_tmp2_fu_92_p2[0:0] === 1'b1) ? sig_b : sel_tmp_fu_78_p3); assign sel_tmp1_fu_86_p2 = (tmp_fu_60_p2 ^ 1'b1); assign sel_tmp2_fu_92_p2 = (tmp_1_fu_66_p2 & sel_tmp1_fu_86_p2); assign sel_tmp5_fu_112_p2 = (tmp7_fu_106_p2 | tmp_fu_60_p2); assign sel_tmp_fu_78_p3 = ((tmp_fu_60_p2[0:0] === 1'b1) ? sig_a : sig_c); assign tmp7_fu_106_p2 = (tmp_1_fu_66_p2 | tmp_2_fu_72_p2); assign tmp_1_fu_66_p2 = ((select_r == ap_const_lv32_1) ? 1'b1 : 1'b0); assign tmp_2_fu_72_p2 = ((select_r == ap_const_lv32_2) ? 1'b1 : 1'b0); assign tmp_fu_60_p2 = ((select_r == ap_const_lv32_0) ? 1'b1 : 1'b0); endmodule //mux41
4.RTL級仿真:
在菜單里Solution>RunC/RTL cosimulation,需要對Co-similation Dialog設置如下:
得到如下結果,我們會發現Verilog的Status是pass,證明C/RTL cosimulation成功:
然后我們點開波形查看窗口,此時會自動打開Vivado軟件,從圖中看到,mux41的功能正確:
5.IP封裝:
在菜單里Solution>Export TL,設置如下:
IP封裝后,會得到impl文件,其中就有我們所需要的三個子文件ip,verilog,vhdl
總結:
事實上,在整個流程中,用戶先創建一個設計 C、C++ 或 SystemC 源代碼,以及一個C的測試平臺。隨后需要用 GCC/G++或 Visual C++ 仿真器驗證設計的系統行為。一旦行為設計運行良好,對應的測試臺的問題全部解決,就可以通過 Vivado HLS Synthesis 運行設計,生成 RTL 設計,代碼可以是 Verilog,也可以是 VHDL。有了 RTL 后,隨即可以執行設計的 Verilog 或 VHDL 仿真,或使用工具的C封裝器技術創建 SystemC 版本。然后可以進行System C架構級仿真,進一步根據之前創建的 C 測試平臺,驗證設計的架構行為和功能。設計固化后,就可以通過 Vivado 設計套件的物理實現流程來運行設計,將設計編程到器件上,在硬件中運行和/或使用 IP 封裝器將設計轉為可重用的 IP。隨后使用 IP 集成器將 IP 集成到設計中,或在系統生成器 (System Generator) 中運行 IP。
本文轉載自:
-
vhdl
+關注
關注
30文章
817瀏覽量
128346 -
Vivado
+關注
關注
19文章
815瀏覽量
66897 -
HLS
+關注
關注
1文章
130瀏覽量
24208
發布評論請先 登錄
相關推薦
探索Vivado HLS設計流,Vivado HLS高層次綜合設計
請問如何只下載Vivado HLS 2015.2
Vivado HLS設計流的相關資料分享
嵌入式硬件開發學習教程——Xilinx Vivado HLS案例 (流程說明)
嵌入式HLS 案例開發步驟分享——基于Zynq-7010/20工業開發板(4)
嵌入式HLS 案例開發步驟分享——基于Zynq-7010/20工業開發板(1)
嵌入式HLS 案例開發步驟分享——基于Zynq-7010/20工業開發板(1)
嵌入式HLS 案例開發步驟分享——基于Zynq-7010/20工業開發板(4)
Hackaday讀者有話說:Vivado HLS使用經驗分享
![Hackaday讀者有話說:<b class='flag-5'>Vivado</b> <b class='flag-5'>HLS</b>使用經驗分享](https://file1.elecfans.com//web2/M00/A6/A8/wKgZomUMP22ACg7eAAAS4Iecc64562.jpg)
用Vivado-HLS實現低latency 除法器
![用<b class='flag-5'>Vivado-HLS</b>實現低latency 除法器](https://file.elecfans.com/web2/M00/49/70/poYBAGKhwLSALp-1AABLz8q1CfE363.png)
基于Vivado HLS的計算機視覺開發
如何創建Vivado HLS項目
如何使用Tcl命令語言讓Vivado HLS運作
將VIVADO HLS設計移植到CATAPULT HLS平臺
![將<b class='flag-5'>VIVADO</b> <b class='flag-5'>HLS</b>設計移植到CATAPULT <b class='flag-5'>HLS</b>平臺](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
評論