《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 可編程邏輯 > 解決方案 > 專家秘笈大放送:Vivado HLS中指針作為top函數(shù)參數(shù)的處理

專家秘笈大放送:Vivado HLS中指針作為top函數(shù)參數(shù)的處理

2013-09-02
關(guān)鍵詞: FPGA Vivado HLS

  Harvest Guo : xilinx

 

    指針作為C語(yǔ)言精華,對(duì)于軟件設(shè)計(jì)者比較好理解,但是在xilinx vivado HLS高級(jí)語(yǔ)言綜合的設(shè)計(jì)中,由于其綜合后對(duì)應(yīng)的硬件元素難以用軟件的概念解釋,常常令程序設(shè)計(jì)者和VHLS工具使用者頭痛。本文采用淺顯易懂的描述方式,結(jié)合具體的c代碼例子,詳細(xì)描述了常用三種指針的設(shè)計(jì)類型,以及其作為頂層函數(shù)參數(shù)時(shí),采用不同的編碼風(fēng)格和HLS約束策略,滿足設(shè)計(jì)者對(duì)指針作為RTL接口的需求。

 

  1. 1.       基本指針類型

基本指針類型指的是指針沒(méi)有運(yùn)算或者沒(méi)有多次的存取(讀寫)。指針作為top函數(shù)的參數(shù)時(shí),指針綜合為wire型或者握手協(xié)議類型接口。如下例子1-1

 

void pointer_basic (dio_t *d) {

static dio_t acc = 0;

acc += *d;

*d = acc;

}

 例子1-1 基本類型指針作為頂層函數(shù)參數(shù)

 

在這個(gè)例子中,只是簡(jiǎn)單的讀寫指針指向的變量值,并沒(méi)有對(duì)指針做偏移或者指針(地址)運(yùn)算,其接口綜合為線型的RTL接口。

 

  1. 2.       指針運(yùn)算類型。

指針作為top層函數(shù)參數(shù),并且函數(shù)中有對(duì)指針運(yùn)算時(shí),我們稱之為指針運(yùn)算類型。指針運(yùn)算常常限制指針可能綜合的接口類型。如下例中,指針做了偏移運(yùn)算用于累加數(shù)據(jù),從第二個(gè)值開始讀出累加,并將每次累加結(jié)果寫入上一個(gè)地址中。

 

void pointer_arith (dio_t *d) {

static int acc = 0;

int i;

for (i=0;i<4;i++) {

acc += *(d+i+1);

*(d+i) = acc;

}

}

  例子1-2 指針運(yùn)算類型作為頂層函數(shù)參數(shù)

 

下面代碼例子1-3是這個(gè)指針運(yùn)算類型仿真的testbench。因?yàn)楹瘮?shù)pointer_arith內(nèi)部的for循環(huán)進(jìn)行數(shù)據(jù)累加,testbench通過(guò)數(shù)組d[5]分配了地址空間并對(duì)數(shù)組賦值。

int main () {

dio_t d[5], ref[5];

int i, retval=0;

FILE *fp;

// Create input data

for (i=0;i<5;i++) {

d[i] = i;

ref[i] = i;

}

// Call the function to operate on the data

pointer_arith(d);

// Save the results to a file

fp=fopen("result.dat","w");

printf(" Din Dout\n", i, d);

for (i=0;i<4;i++) {

fprintf(fp, "%d \n", d[i]);

printf(" %d %d\n", ref[i], d[i]);

}

fclose(fp);

// Compare the results file with the golden results

retval = system("diff --brief -w result.dat result.golden.dat");

if (retval != 0) {

printf("Test failed!!!\n");

retval=1;

} else {

printf("Test passed!\n");

}

// Return 0 if the test

return retval;

}

  例子1-3 指針運(yùn)算類型作為頂層函數(shù)參數(shù)的testbench

 

C編譯環(huán)境下仿真上面例子1-3的代碼,結(jié)果如下:

Din Dout

0 1

1 3

2 6

3 10

Test passed!

 

指針運(yùn)算帶來(lái)的問(wèn)題是,通常情況下,指針偏移是不規(guī)則的,不能按順序存取指針數(shù)據(jù)。而Wire,握手類型或者Fifo接口類型沒(méi)有辦法亂序存取數(shù)據(jù)。

對(duì)于wire類型接口來(lái)說(shuō),當(dāng)設(shè)計(jì)本身準(zhǔn)備好接收數(shù)據(jù)時(shí)可以讀入數(shù)據(jù),或者當(dāng)數(shù)據(jù)準(zhǔn)備好ready時(shí),可以寫出數(shù)據(jù)。對(duì)握手和Fifo類型接口,當(dāng)控制信號(hào)允許操作進(jìn)行時(shí),讀入或?qū)懗鰯?shù)據(jù)。

 

在上面wire,握手或者FIFO類型接口的情況下,數(shù)據(jù)從0元素開始,必須按順序到達(dá)(寫入)。在指針運(yùn)算的例子1-2中,第一個(gè)數(shù)據(jù)從索引1開始讀入(i0開始,0+1=1),對(duì)應(yīng)于testbench中數(shù)據(jù)d[5]的第二個(gè)元素。

當(dāng)這種情況在硬件應(yīng)用時(shí),需要某種格式的數(shù)據(jù)索引,這種情況對(duì)于wire類型,或者握手類型還是Fifo類型來(lái)說(shuō),都不支持。像上例1-2指針運(yùn)算的代碼,只能綜合成ap_bus接口,因?yàn)檫@種接口帶有地址,當(dāng)數(shù)據(jù)存取(讀寫)時(shí),用于對(duì)應(yīng)的數(shù)據(jù)索引指示。

還有一種方法,代碼必須修改成如下例子1-4的風(fēng)格,用數(shù)據(jù)array作為接口替代指針。這種方法應(yīng)用了array作為top層參數(shù)時(shí)綜合成RAM接口(ap_memory)的原理,memory接口可以用地址作為數(shù)據(jù)的索引并且可以亂序執(zhí)行,不必順序存取操作。

void array_arith (dio_t d[5]) {

static int acc = 0;

int i;

for (i=0;i<4;i++) {

acc += d[i+1];

d[i] = acc;

}

}

例子1-4 指針運(yùn)算類型作為頂層函數(shù)參數(shù)修改為array

Wire類型、握手類型或Fifo類型接口僅僅可用在數(shù)據(jù)流方式,因此不能用在與指針運(yùn)算相關(guān)的地方(除非數(shù)據(jù)從索引0開始并順序處理)。同時(shí)注意,如果想綜合為FIFO接口,Fifo接口類型必須是只讀或者只寫,不能有讀又有寫操作。

 

  1. 3.       多次讀寫(存取)指針類型

多次讀寫指針類型一般用作描述一個(gè)數(shù)據(jù)流方式的接口。

當(dāng)top層函數(shù)參數(shù)使用指針,函數(shù)體對(duì)指針進(jìn)行多次存取操作時(shí),必須仔細(xì)考慮。在同一函數(shù)中對(duì)一個(gè)指針多次的讀或者寫,就會(huì)有多次指針存取發(fā)生,從而引起下列問(wèn)題:

  1. 1.       對(duì)任何函數(shù)指針參數(shù)的多次存取要使用volatile限定符。
  2. 2.       對(duì)于Top層函數(shù),如果要做RTL代碼的混合仿真(co-sim),任何這種指針參數(shù)必須有這個(gè)接口存取次數(shù)的詳細(xì)說(shuō)明。
  3. 3.       確保在綜合前驗(yàn)證C功能,確定符合功能要求,保證C模型正確。

 

如果設(shè)計(jì)模型要求函數(shù)參數(shù)指針多次存取,推薦使用數(shù)據(jù)流模式模型化設(shè)計(jì),使用數(shù)據(jù)流模型可以避免我們將會(huì)在下面討論到的,使用多次讀寫指針帶來(lái)的一些問(wèn)題。

這個(gè)章節(jié)使用設(shè)計(jì)例子1-5 糟糕的數(shù)據(jù)流類型指針(pointer_stream_bad)解釋,當(dāng)多次存取指針時(shí),為什么要使用volatile限定符。同時(shí)使用設(shè)計(jì)例子1-8 好的數(shù)據(jù)指針類型(pointer_stream_better)來(lái)說(shuō)明,為什么當(dāng)top層函數(shù)參數(shù)包含有這種指針接口的設(shè)計(jì)時(shí),應(yīng)該用C testbench仿真驗(yàn)證確保設(shè)計(jì)的行為級(jí)模型正確。

在下面的例子1-5中,指針d_i讀了4次并且d_o寫了2次,設(shè)計(jì)的本意是存取操作通過(guò)fifo接口,綜合后的RTL以數(shù)據(jù)流的方式讀入或者寫出數(shù)據(jù)。

void pointer_stream_bad ( dout_t *d_o, din_t *d_i) {

din_t acc = 0;

acc += *d_i;

acc += *d_i;

*d_o = acc;

acc += *d_i;

acc += *d_i;

*d_o = acc;

}

   例子1-5 糟糕的數(shù)據(jù)流指針類型

 

用于驗(yàn)證的C testbench如下:

int main () {

din_t d_i;

dout_t d_o;

int retval=0;

FILE *fp;

// Open a file for the output results

fp=fopen("result.dat","w");

// Call the function to operate on the data

for (d_i=0;d_i<4;d_i++) {

pointer_stream_bad(&d_o,&d_i);

fprintf(fp, "%d %d\n", d_i, d_o);

}

fclose(fp);

// Compare the results file with the golden results

retval = system("diff --brief -w result.dat result.golden.dat");

if (retval != 0) {

 

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無(wú)法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問(wèn)題,請(qǐng)及時(shí)通過(guò)電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
午夜久久tv| 亚洲在线观看免费视频| 一区二区三区毛片| 黄色一区二区三区四区| 国产精品一区久久| 国产精品电影观看| 欧美日韩免费观看中文| 欧美劲爆第一页| 欧美不卡在线视频| 免费在线亚洲欧美| 欧美gay视频激情| 免费观看久久久4p| 农夫在线精品视频免费观看| 久久免费一区| 久久久综合网站| 久久久噜噜噜久久人人看| 久久国产手机看片| 久久精品夜色噜噜亚洲a∨| 欧美在线资源| 久久久久九九九| 久久久青草婷婷精品综合日韩| 欧美在线视频一区二区| 久久成人人人人精品欧| 久久精品国产96久久久香蕉| 欧美一区三区三区高中清蜜桃| 欧美一级二区| 久久九九99| 噜噜噜躁狠狠躁狠狠精品视频| 久久琪琪电影院| 欧美91精品| 欧美另类一区二区三区| 欧美日韩视频在线| 国产精品高潮粉嫩av| 国产农村妇女毛片精品久久麻豆 | 久久一区中文字幕| 欧美国产精品一区| 欧美视频一二三区| 国产欧美日本一区二区三区| 国产在线成人| 亚洲国产一区视频| 一区二区三区国产在线| 亚洲一区综合| 亚洲福利专区| 中文一区字幕| 欧美一区国产在线| 欧美成人精品不卡视频在线观看| 欧美日韩精品在线| 国产美女精品视频免费观看| 激情小说亚洲一区| 亚洲片在线观看| 亚洲一区二区三区色| 久久国产视频网站| 9色精品在线| 欧美在线欧美在线| 欧美精品日韩www.p站| 国产精品久久久久毛片软件| 狠狠色综合色综合网络| 亚洲激情二区| 亚洲在线视频网站| 亚洲精品乱码久久久久久蜜桃麻豆| 在线一区观看| 久久久精品网| 欧美手机在线| 精品电影在线观看| 亚洲视频福利| 亚洲欧洲精品一区| 欧美永久精品| 欧美区在线观看| 国产在线精品二区| 一本色道久久综合狠狠躁篇怎么玩 | 一区二区高清视频在线观看| 欧美综合77777色婷婷| 亚洲私人影院| 久久亚洲精选| 国产精品一区二区你懂得| 亚洲国产电影| 欧美亚洲免费| 亚洲一区国产| 奶水喷射视频一区| 国产目拍亚洲精品99久久精品| 亚洲高清视频一区| 亚洲欧美日韩第一区| 日韩一区二区免费看| 久久国产一区| 国产精品高潮呻吟久久av无限| 亚洲电影免费| 欧美一级二级三级蜜桃| 亚洲午夜久久久| 欧美黑人一区二区三区| 国产亚洲一区精品| 中文日韩在线视频| 亚洲精品欧洲| 久久久久久夜精品精品免费| 国产精品久久国产精麻豆99网站| 亚洲第一福利视频| 香蕉久久久久久久av网站| 一区二区欧美日韩视频| 蜜臀av一级做a爰片久久| 国产日韩亚洲欧美| 国产精品99久久久久久人| 亚洲精品国久久99热| 久久久久综合网| 国产日韩综合| 午夜视频精品| 欧美一区二粉嫩精品国产一线天| 欧美日韩亚洲国产精品| 亚洲娇小video精品| 亚洲国产裸拍裸体视频在线观看乱了| 欧美一区二区三区视频在线观看| 欧美日韩在线播放一区二区| 亚洲精品国产欧美| 亚洲日本视频| 欧美成人高清视频| 亚洲福利视频专区| 亚洲高清在线观看| 老色鬼精品视频在线观看播放| 好看的av在线不卡观看| 欧美永久精品| 久久www成人_看片免费不卡| 国产精品亚发布| 亚洲在线观看免费| 午夜精品久久久久影视 | 好看的av在线不卡观看| 香蕉视频成人在线观看| 欧美一区在线视频| 国产视频精品xxxx| 欧美一区在线看| 久久久亚洲欧洲日产国码αv| 国产欧美一区二区精品性| 亚洲欧美日本伦理| 欧美专区第一页| 国内精品一区二区| 91久久精品美女高潮| 蜜桃av一区二区三区| 亚洲国产精品一区二区第一页 | 99热免费精品在线观看| 欧美日韩成人网| 一区二区久久久久| 亚洲一区二区三区精品动漫| 国产精品分类| 西西裸体人体做爰大胆久久久| 久久成人免费| 狠狠做深爱婷婷久久综合一区| 亚洲日本国产| 欧美视频在线观看视频极品 | 午夜一区二区三区不卡视频| 久久久久久免费| 亚洲高清免费| 亚洲午夜一区二区三区| 国产精品日韩高清| 欧美一区1区三区3区公司| 久久中文欧美| 最新国产成人av网站网址麻豆| 亚洲午夜精品久久| 国产精品视频一| 亚洲国产日韩欧美在线动漫| 欧美日韩国产一中文字不卡| 亚洲图片欧洲图片av| 久久精品夜色噜噜亚洲a∨| 伊人成人在线视频| 亚洲图片欧美一区| 国产亚洲一级高清| 99riav久久精品riav| 国产精品视频你懂的| 亚洲国产女人aaa毛片在线| 欧美日韩亚洲国产精品| 欧美在线国产| 欧美日韩免费观看一区二区三区 | 最新国产の精品合集bt伙计| 欧美日本在线播放| 亚洲欧美精品suv| 免费不卡在线观看| 亚洲线精品一区二区三区八戒| 久久亚洲二区| 夜夜精品视频一区二区| 噜噜噜躁狠狠躁狠狠精品视频| 一区二区三区日韩精品视频| 久久天天躁狠狠躁夜夜av| 日韩视频在线一区二区| 久久久五月婷婷| 一区二区三区视频在线观看| 久久影视精品| 亚洲一二三区在线观看| 免费观看在线综合色| 亚洲一品av免费观看| 欧美成人一区二区三区片免费| 亚洲一区美女视频在线观看免费| 女同一区二区| 亚洲欧美久久久久一区二区三区| 欧美黄色日本| 欧美在线|欧美| 国产精品www994| 亚洲三级免费| 国产在线精品二区| 亚洲免费在线观看| 亚洲青色在线| 免费成人av在线| 午夜视频在线观看一区二区| 欧美日韩一区二区三区在线观看免 | 午夜一区不卡|