《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 嵌入式技術(shù) > 設(shè)計(jì)應(yīng)用 > 如何在SoC設(shè)計(jì)中使用事務(wù)處理(二)
如何在SoC設(shè)計(jì)中使用事務(wù)處理(二)
摘要: 建模,、驗(yàn)證與調(diào)試需要統(tǒng)一標(biāo)準(zhǔn)的符號(hào)和框架,,以便使架構(gòu)師和設(shè)計(jì)工程師能夠協(xié)同進(jìn)行復(fù)雜SoC的開(kāi)發(fā),。事務(wù)處理級(jí)模型(TLM)是進(jìn)行這種分析的理想模型,在片上系統(tǒng)(SoC)設(shè)計(jì)中使用事務(wù)處理級(jí)建模,,可讓設(shè)計(jì)
Abstract:
Key words :
    建模,、驗(yàn)證與調(diào)試需要統(tǒng)一標(biāo)準(zhǔn)的符號(hào)和框架,以便使架構(gòu)師和設(shè)計(jì)工程師能夠協(xié)同進(jìn)行復(fù)雜SoC的開(kāi)發(fā),。事務(wù)處理級(jí)模型(TLM)是進(jìn)行這種分析的理想模型,,在片上系統(tǒng)(SoC)設(shè)計(jì)中使用事務(wù)處理級(jí)建模,可讓設(shè)計(jì)從高效率協(xié)同仿真和高產(chǎn)出的分析與調(diào)試中受益,。

    下面是對(duì)圖2所示的事務(wù)處理進(jìn)行建模的一個(gè)簡(jiǎn)單代碼段,。這個(gè)類的旨在于將事務(wù)處理數(shù)據(jù)記錄到作為trans_db instance dump_file類的事務(wù)處理數(shù)據(jù)庫(kù)中。輸出被顯示在圖3最右部分,。

// Inside program or some other OpenVera context

trans_db dump_file;

trans_stream stream1;

trans_type mem_read;

trans_handle h1;

// open a database file

dump_file=new("test");

// create the memory stream under the test.duv.bus scope

stream1=new(dump_file, "test.duv.bus", "memory");

// create the read transaction type in the memory stream

mem_read=new(stream1, "Read");

// define 2 attributes in the read transaction type

mem_read.create_attr("Addr", INTEGER_DT);

mem_read.create_attr("Data", INTEGER_DT);

delay(10);

// begin a memory read transaction at 10

h1=mem_read.begin_now();

h1.log_integer_attr("Addr", 170);

h1.log_integer_attr("Data", 123);

delay(20);

// end h1 transaction at 20

h1.end_now();

// close the database file

dump_file.close();

 

當(dāng) 然,,正如前面針對(duì)SCV所提到的,另一個(gè)有用的類是trans_relation,,它負(fù)責(zé)不同事務(wù)處理之間的關(guān)系,。下面的代碼段顯示出當(dāng) trans_relation為單向時(shí),,類是被怎樣運(yùn)用的。一個(gè)分析與可視化工具也可以具備預(yù)先定義的關(guān)系以便獲得對(duì)分析和顯示的特定表示,。

trans_relation r1;

trans_relation r2;

trans_handle h1;

trans_handle h2;

r1=new(f, "parent");

r2=new(f, "child");

...h1.add_relation(r1, h2); // h2 is the parent of h1

h2.add_relation(r2, h1); // h1 is the child of h2

    為實(shí)現(xiàn)記錄,,類必須封裝事務(wù)處理追蹤和記錄API,使數(shù)據(jù)庫(kù)記錄細(xì)節(jié)對(duì)用戶而言不可見(jiàn),。API必須是開(kāi)放的,,以便在工程師和供應(yīng)商等人之間培養(yǎng)出一種公共增 值文化。在創(chuàng)建,、生成和記錄事務(wù)處理時(shí),,它也必須經(jīng)受得起跨語(yǔ)言應(yīng)用的檢驗(yàn),,從而給設(shè)計(jì)工程師一個(gè)高價(jià)值工具,。而且它必須簡(jiǎn)單、基本,,但是要足夠?qū)挿阂员?覆蓋事務(wù)處理記錄的基本要素,。為獲得某些(特定建模語(yǔ)言)具體功能,可以另外在封裝之上再建立API,。

    程序員們開(kāi)發(fā)出了一種被為“開(kāi)放的 事務(wù)處理接口(OTI)”的API,。這是在Novas公司的FSDB writer層之上構(gòu)建的一層。該API用C語(yǔ)言編寫以獲得高可便攜性,。事實(shí)上前面列出的那些類都是OpenVera事務(wù)處理類函數(shù)庫(kù)的一部分,。它們構(gòu)成 了對(duì)OTI的封裝并且利用DirectC與OpenVera接口。用戶可以從任何地方利用DirectC編碼直接調(diào)用OTI,。但總的來(lái)說(shuō),,提供一個(gè)將建模 語(yǔ)言的接口要求隱藏起來(lái)的OTI封裝是一個(gè)好主意,這樣用戶就可以專注于建模而忽略數(shù)據(jù)庫(kù)記錄的細(xì)節(jié),。


 

與OTI相似的APIs可以很容易 地使設(shè)計(jì)工程師能夠采用能與C語(yǔ)言接口的語(yǔ)言來(lái)開(kāi)發(fā)并記錄事務(wù)處理數(shù)據(jù),。這包括其它流行的硬件驗(yàn)證語(yǔ)言,例如e語(yǔ)言,。事實(shí)上,,通過(guò)恰當(dāng)?shù)姆庋b系統(tǒng)任務(wù)以及 軟件C/C++代碼,API也可以在硬件描述語(yǔ)言中使用以直接將事務(wù)處理數(shù)據(jù)從實(shí)現(xiàn)中卸載出去,。圖4是一個(gè)帶有所有這些模塊的系統(tǒng),。

     SystemVerilog(3.1a版)(www.systemverilog.org) 是新型的設(shè)計(jì)建模與測(cè)試臺(tái)語(yǔ)言。它目前沒(méi)有如SystemC里的內(nèi)置事務(wù)處理類別,,但是它存在的目的就是將Verilo電路和寄存器數(shù)據(jù)抽象化并封裝至更 有意義的分組數(shù)據(jù)中,。這使得我們有必要看看如何才能建模然后記錄事務(wù)處理數(shù)據(jù)。事實(shí)上,,可以采用多種方法在SystemVerilog實(shí)現(xiàn)這一點(diǎn):a)等 待增添內(nèi)置類的標(biāo)準(zhǔn)化努力,。這也許會(huì)最終發(fā)生,,不過(guò)SystemVerilog今天就可以達(dá)到這一目的。因此何必還要等待概念產(chǎn)生然后再期待供應(yīng)商去支持 它呢,?b)創(chuàng)建你自己的事務(wù)處理類和方法(任務(wù)和功能),,然后也許再將其作為一個(gè)可分享的函數(shù)庫(kù)捐贈(zèng)給業(yè)界。c)透過(guò)直接編程接口(DPI)或編程語(yǔ)言接 口來(lái)與SystemC集成,。d)在建模過(guò)程中調(diào)用“系統(tǒng)任務(wù)”在恰當(dāng)?shù)牡胤酵瓿伞?/p>

    我們認(rèn)為選項(xiàng)(d)是設(shè)計(jì)工程師的一個(gè)很好的出發(fā)點(diǎn),。它囊括了眾多的接口要求并且以一種簡(jiǎn)單、直接而且相當(dāng)彈性的方式完成任務(wù),。設(shè)計(jì)工程師們可以透過(guò)編程語(yǔ)言接口,,或者最好透過(guò)直接編程接口(DPI)來(lái)調(diào)用SystemVerilog “任務(wù)”或C/C++例行程序。就像DirectC一樣,,DPI這種機(jī)制是被設(shè)計(jì)用于簡(jiǎn)單地與用C或C++語(yǔ)言編寫的外部無(wú)時(shí)序模塊進(jìn)行接口,。

    因此這就產(chǎn)生了兩個(gè)問(wèn)題。事務(wù)處理對(duì)象是什么,?設(shè)計(jì)工程師們?cè)撛鯓觿?chuàng)建/生成/記錄事務(wù)處理并開(kāi)發(fā)API,?同樣,我們的答案就是API工具,,如圖3所示的OTI,。它可隱藏執(zhí)行細(xì)節(jié)并且為事務(wù)處理記錄提供一個(gè)健全而完整的基礎(chǔ)。

需要更多的自動(dòng)化

    到目前為止所討論的事務(wù)處理記錄是相當(dāng)有用,、高效的,。可是實(shí)際上它仍然是人工的,,更確切地說(shuō),,用戶必須執(zhí)行事務(wù)處理建模并求助于數(shù)據(jù)庫(kù)記錄。隨著標(biāo)準(zhǔn)越來(lái)越成熟以及工具供應(yīng)商聯(lián)合起來(lái),,業(yè)界構(gòu)可以開(kāi)發(fā)額外的自動(dòng)化生成和記錄工具,。例如,用戶已經(jīng)可以在Vera RVM中(同樣的,,在e語(yǔ)言中)用事務(wù)處理類生成事務(wù)處理,。因此,即將到來(lái)的自動(dòng)化將在創(chuàng)建時(shí)使用這些回叫工具,,這樣用戶就用不著擔(dān)心為事務(wù)處理分開(kāi)建模了,。他們可以擴(kuò)展所提供的基本類,并自動(dòng)獲得所需的記錄功能,。

    另外,,我們發(fā)現(xiàn)SoC通常含有許多模塊,包括專利IP,用于設(shè)計(jì)與驗(yàn)證的建模語(yǔ)言也相當(dāng)?shù)亩?如圖3所示),。因此,,一個(gè)完整的SoC就形成一個(gè)難以破解的數(shù) 據(jù)集合。在這種情況下,,如果工程師采用某種方法將事務(wù)處理從可獲得的數(shù)據(jù)里提取出來(lái),,從而更好地理解系統(tǒng)運(yùn)行的話就再好不過(guò)了。建模,、驗(yàn)證與調(diào)試需要統(tǒng)一 標(biāo)準(zhǔn)的符號(hào)和框架,,以便架構(gòu)師和設(shè)計(jì)工程師合力進(jìn)行復(fù)雜SoC的設(shè)計(jì)與開(kāi)發(fā)。TLM是進(jìn)行這種分析的理想模型,。設(shè)計(jì)工程師們應(yīng)該更加深入地研究事務(wù)處理級(jí) 建模的細(xì)節(jié),,并利用事務(wù)處理級(jí)建模從高效率協(xié)同仿真和高產(chǎn)出的分析與調(diào)試中獲得最大好處。

此內(nèi)容為AET網(wǎng)站原創(chuàng),,未經(jīng)授權(quán)禁止轉(zhuǎn)載,。