在Vitis 統(tǒng)一軟件平臺中使用Alveo系列開發(fā)板設(shè)計(jì)加速Kernel時,系統(tǒng)會自動為Kernel的時鐘設(shè)置默認(rèn)頻率。
以 xilinx_u200_qdma_201910_1 平臺為例,在Vitis中選擇平臺時可以看到默認(rèn)的時鐘頻率是300Mhz和500Mhz.
在Vitis Application Acceleration Development Flow 中我們看到 --kernel_frequency 選項(xiàng)可以用于覆蓋默認(rèn)的 Kernel 頻率
(https://www.xilinx.com/html_docs/xilinx2020_2/vitis_doc/buildtargets1.html#ldh1504034328524)
那么 --kernel_frequency設(shè)置在Compile階段或者Link階段有什么區(qū)別呢?
我們以經(jīng)典 Example design“Vector Addition” 為例探索一下:
1. 打開Vitis 2020.2,創(chuàng)建新的 Application Project
File -》 New -》 Application project
2. 選擇 xilinx_u200_qdma_201910_1 平臺
3. 選擇打開 Example Design “Vector Addition”
4.對 Hardware Flow 在Compile階段設(shè)置“kernel_frequency” 為200MHz,然后編譯工程
注意:默認(rèn)的Kernel頻率只允許改小,不允許改大。
在log看到執(zhí)行的命令是:
v++ --target hw --compile --kernel_frequency 200 …
5. Compile Kernel 完成后可以在Compile Summary中看到“--kernel_frequency 200“ 已經(jīng)設(shè)置成功。
在Kernel Estimate報告中,可以看到,Target Clock已經(jīng)按要求設(shè)置成200Mhz. 說明 Vitis_HLS是按照200Mhz的要求來綜合Kernel的代碼的。
在Link Summary中可以看到,在把Kernel合入平臺后的Implementation中,目標(biāo)時鐘還是平臺默認(rèn)的300Mhz,而不是在Compile 階段設(shè)置的200Mhz.
同時我們也可以翻看Implemented Design的時序報告(Timing Summary)查看Kernel實(shí)際的時鐘要求:
clk_out1_pfm_top_clkwiz_kernel_0_1 {0.000 1.667} 3.333 300.000
6. 在Link階段加上“--kernel_frequency 100” 選項(xiàng)
在log看到執(zhí)行的命令是:
v++ --target hw --link -R2 --kernel_frequency 100 …
7. 完成Hardware Build之后,查看Summary,可以看到這時100Mhz Kernel 頻率的設(shè)置在整個Vitis Platform Link生效, 覆蓋默認(rèn)的300Mhz
和之前一樣翻看Implemented Design的時序報告(Timing Summary)查看Kernel實(shí)際的時鐘要求,kernel的目標(biāo)頻率已經(jīng)被正確修改了。
clk_out1_pfm_top_clkwiz_kernel_0_1 {0.000 5.000} 10.000 100.000
總結(jié):
選項(xiàng)“--kernel_frequency“ 加在Compile階段,影響的是對Kernel做高級綜合的Vitis_HLS的目標(biāo)頻率,不影響Kernel合入平臺后的Implementation的目標(biāo)頻率;
選項(xiàng)“--kernel_frequency” 加在Link階段, 不會影響對Kernel做高級綜合的Vitis_HLS的默認(rèn)目標(biāo)時鐘頻率,但是可以設(shè)置Kernel合入平臺后的Implementation的目標(biāo)頻率
編輯:jq
-
Xilinx
+關(guān)注
關(guān)注
71文章
2167瀏覽量
121490 -
Link
+關(guān)注
關(guān)注
0文章
101瀏覽量
26970 -
代碼
+關(guān)注
關(guān)注
30文章
4790瀏覽量
68646
原文標(biāo)題:開發(fā)者分享 | 如何在Vitis中設(shè)定Kernel 的頻率
文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論