91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

關(guān)于數(shù)字硬件建模SystemVerilog聯(lián)合體

OpenFPGA ? 來源:OpenFPGA ? 作者:OpenFPGA ? 2022-07-07 09:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

數(shù)字硬件建模SystemVerilog-聯(lián)合體(union)

3af5b30c-fd8d-11ec-ba43-dac502259ad0.png

聯(lián)合體(union)

聯(lián)合體是一個可以有多個數(shù)據(jù)類型表示的單個存儲元素,聯(lián)合體的聲明類似結(jié)構(gòu)體,但推斷出的硬件非常不同。結(jié)構(gòu)體是幾個變量的集合。union是單個變量,可以在不同的時間使用不同的數(shù)據(jù)類型。union可以存儲的變量類型列在大括號({})之間,每個變量類型都有一個名稱:

3b0a69c8-fd8d-11ec-ba43-dac502259ad0.png

在本例中,變量是data。data變量有兩種可能的數(shù)據(jù)類型:名為s的有符號整數(shù)類型,或名為u的無符號整數(shù)值。

在RTL建模中,聯(lián)合體的一個典型應(yīng)用是,一個值可以表示為幾種不同的類型,但在任何特定的時鐘周期中只能表示為一種類型。例如,數(shù)據(jù)總線有時可能使用用戶網(wǎng)絡(luò)接口(UNI,User NetworkInterface)電信協(xié)議發(fā)送數(shù)據(jù)包,而在其他時間,同一數(shù)據(jù)總線可能使用網(wǎng)絡(luò)到網(wǎng)絡(luò)接口(NNI,Network to Network Interface)電信協(xié)議發(fā)送數(shù)據(jù)包。SystemVerilog聯(lián)合體可以代表同一總線的這種雙重用途。聯(lián)合體的另一個用途是表示共享硬件資源,例如可以在不同時間存儲不同類型數(shù)據(jù)的硬件寄存器。

自定義和匿名聯(lián)合體

同結(jié)構(gòu)體一樣, 聯(lián)合體可以使用 typedef 來定義, 按這種方式定義的是自定義聯(lián)合體。如果沒有使用 typedef,就是匿名聯(lián)合體.

3b1de534-fd8d-11ec-ba43-dac502259ad0.png

匿名聯(lián)合體和自定義聯(lián)合體都是可綜合的,但自定義聯(lián)合體在RTL建模方面有優(yōu)勢。自定義聯(lián)合體可以是:

用于聲明多個變量,如上例中的數(shù)據(jù)輸入和數(shù)據(jù)輸出。

用作模塊端口類型。

在一個包中定義,然后在多個模塊中使用。

分配和讀取聯(lián)合體變量

引用聯(lián)合體的數(shù)據(jù)類型時,使用聯(lián)合體的名稱,后跟表示數(shù)據(jù)類型的名稱,并用句點(diǎn)(.)分隔(同結(jié)構(gòu)體一樣)。

3b281cd4-fd8d-11ec-ba43-dac502259ad0.png

在本例中,變量數(shù)據(jù)有兩種可能的數(shù)據(jù)類型,每個表示中都存儲了-5。data.s數(shù)據(jù)類型將打印為-5,一個有符號整數(shù)值。data.u數(shù)據(jù)類型將打印為4294967291,一個無符號整數(shù)值。

非壓縮聯(lián)合體和標(biāo)記的聯(lián)合體

最佳做法準(zhǔn)則4-4

在RTL建模中僅使用壓縮聯(lián)合體。

SystemVerilog有三種類型的聯(lián)合體:非壓縮聯(lián)合體、壓縮聯(lián)合體和標(biāo)簽聯(lián)合體,大多數(shù)綜合編譯器只支持壓縮聯(lián)合體。

大多數(shù)綜合編譯器不支持非壓縮和標(biāo)簽聯(lián)合體。這些聯(lián)合體類型可以代表任何數(shù)據(jù)類型的存儲,包括不可綜合的數(shù)據(jù)類型。非壓縮的聯(lián)合體體和標(biāo)簽聯(lián)合體體可用于建模測試臺和高級抽象模型,但不應(yīng)用于RTL建模。

通過在union關(guān)鍵字后添加關(guān)鍵字Packed來定義壓縮聯(lián)合體:

3b3a6e66-fd8d-11ec-ba43-dac502259ad0.png

壓縮聯(lián)合體是可綜合的。壓縮聯(lián)合體對聯(lián)合體可以表示的數(shù)據(jù)類型有很多限制。這些限制與硬件行為密切相關(guān)。在壓縮聯(lián)合體中,它只能表示向量類型,并且聯(lián)合體可以存儲的每個數(shù)據(jù)類型的向量寬度必須相同。這確保了無論存儲值的數(shù)據(jù)類型如何,壓縮聯(lián)合體都將以相同的位數(shù)表示其存儲。

壓縮聯(lián)合體允許使用一種格式寫入數(shù)據(jù),并使用另一種格式讀回?cái)?shù)據(jù)。設(shè)計(jì)模型不需要進(jìn)行任何特殊處理來跟蹤數(shù)據(jù)的存儲方式,這是因?yàn)閴嚎s聯(lián)合體中的數(shù)據(jù)總是使用相同的位數(shù)存儲。下面的示例定義了一個壓縮聯(lián)合體,其中一個值可以用兩種方式表示:數(shù)據(jù)包(使用壓縮結(jié)構(gòu)體)或連續(xù)字節(jié)數(shù)組,

3b566616-fd8d-11ec-ba43-dac502259ad0.png

圖4-3說明了dreg的兩種數(shù)據(jù)類型是如何表示的。

圖4-3:具有相同存儲的兩種表示形式的壓縮聯(lián)合體 3b6dbfa0-fd8d-11ec-ba43-dac502259ad0.png

因?yàn)槁?lián)合體是壓縮的,所以無論使用哪種聯(lián)合體表示,信息都將使用相同的位對齊來存儲。這意味著可以使用bytes格式(可能來自字節(jié)的串行輸入流)加載一個值,然后使用data_packet格式讀取相同的值,

通過端口將壓縮聯(lián)合體傳遞給任務(wù)和函數(shù)

自定義聯(lián)合體(使用typedef定義的聯(lián)合體)可以用作模塊端口和任務(wù)/函數(shù)參數(shù)的數(shù)據(jù)類型。非壓縮的聯(lián)合體要求將相同的聯(lián)合體類型用于端口的外部連接,或用于傳遞給任務(wù)或函數(shù)參數(shù)的外部信號。壓縮聯(lián)合體只能表示壓縮數(shù)據(jù)類型,這允許任何向量類型用于外部連接或外部值。

示例4-6顯示了一個包含結(jié)構(gòu)體和聯(lián)合體定義的包。示例4-7在一個簡單算術(shù)邏輯單元(ALU)模型中使用了這個包,ALU可以對有符號或無符號的值進(jìn)行操作,但不能同時對兩者進(jìn)行操作,一個標(biāo)志用于指示操作數(shù)據(jù)是有符號的還是無符號的。ALU操作碼、兩個操作數(shù)和一個有符號標(biāo)志作為單個指令字傳遞到ALU中,用結(jié)構(gòu)體表示。ALU輸出是單個值,可以表示有符號或無符號值,建模為這兩種類型的并集。這允許相同的輸出端口用于不同的數(shù)據(jù)類型:

示例4-6:包含結(jié)構(gòu)體和聯(lián)合體定義的包

//
//Packagewithunionandstructuredefinitions
//
//`begin_keywords"1800-2012"http://useSystemVerilog-2012keywords
`define_4bit//use4-bitdatafortestingsynthesis
//`define_32bit//use32-bitdatawordsize
//`define_64bit//use64-bitdatawordsize
packagedefinitions_pkg;
`ifdef_4bit
typedeflogic[3:0]uword_t;
typedeflogicsigned[3:0]sword_t;
`elsif_64bit
typedeflogic[63:0]uword_t;
typedeflogicsigned[63:0]sword_t;
`else//defaultis32-bitvectors
typedeflogic[31:0]uword_t;
typedeflogicsigned[31:0]sword_t;
`endif

typedefenumlogic[2:0]{ADD,SUB,MULT,DIV}op_t;
typedefenumlogic{UNSIGNED,SIGNED}operand_type_t;

//Packedunionrepresentsavariablethatcanstore
//differenttypes
typedefunionpacked{
uword_tu_data;
sword_ts_data;
}data_t;

//Packedstructurerepresentsacollectionofvariables
//thatcanreferencedandpassedthroughportsasagroup
typedefstructpacked{
op_topcode;
operand_type_top_type;
data_top_a;
data_top_b;
}instruction_t;
endpackage:definitions_pkg
//`end_keywords
示例4-7:帶結(jié)構(gòu)體和聯(lián)合體端口的算術(shù)邏輯單元(ALU)
//
//Modulewithstructureinputportandunionoutputport
//
//`begin_keywords"1800-2012"http://useSystemVerilog-2012keywords
modulealu
importdefinitions_pkg::*;//wildcardimportthepackage
(inputlogicclk,rstN,
inputinstruction_tiw,//inputisastructure
outputdata_talu_out//outputisaunion
);
timeunit1ns;timeprecision1ns;

always_ff@(posedgeclkornegedgerstN)//asyncreset
if(!rstN)//active-low
alu_out<=?'0;
???else?begin:?alu_operations?
?????if?(iw.op_type?==?SIGNED)?begin:?signed_ops?
???????case?(iw.opcode)
?????????ADD?:?alu_out.s_data?<=?iw.op_a.s_data
?????????????????????????????????+?iw.op_b.s_data;
?????????SUB?:?alu_out.s_data?<=?iw.op_a.s_data
?????????????????????????????????-?iw.op_b.s_data;
?????????MULT:?alu_out.s_data?<=?iw.op_a.s_data
?????????????????????????????????*?iw.op_b.s_data;
?????????DIV?:?alu_out.s_data?<=?iw.op_a.s_data
?????????????????????????????????/?iw.op_b.s_data;
???????endcase?
?????end:?signed_ops?
?????else?begin:?unsigned_ops?
???????case?(iw.opcode)
?????????ADD?:?alu_out.u_data?<=?iw.op_a.u_data
?????????????????????????????????+?iw.op_b.u_data;
?????????SUB?:?alu_out.u_data?<=?iw.op_a.u_data
?????????????????????????????????-?iw.op_b.u_data;
?????????MULT:?alu_out.u_data?<=?iw.op_a.u_data
?????????????????????????????????*?iw.op_b.u_data;
?????????DIV?:?alu_out.u_data?<=?iw.op_a.u_data
?????????????????????????????????/?iw.op_b.u_data;
???????endcase?
?????end:?unsigned_ops?
???end:?alu_operations?
endmodule:?alu
`end_keywords?

圖4-4顯示了綜合該示例的結(jié)果。說明了在RTL模型中使用結(jié)構(gòu)體和聯(lián)合體的兩個重要特征:

結(jié)構(gòu)體和聯(lián)合體可以簡潔地仿真大量功能。用更少的代碼行仿真更多功能的能力是在原始Verilog中添加結(jié)構(gòu)體和聯(lián)合體等功能的原因之一,

當(dāng)與本節(jié)所述的RTL編碼準(zhǔn)則一起使用時,聯(lián)合體可以表示多路復(fù)用功能,允許多個資源(本例中的有符號和無符號加法器、減法器、乘法器和除法器)共享相同的硬件寄存器。圖4-4中的圓圈代表通用算法 操作,梯形符號代表多路復(fù)用器:

圖4-4:示例4-7的綜合結(jié)果:具有結(jié)構(gòu)體和聯(lián)合體端口的ALU 3b7b6ca4-fd8d-11ec-ba43-dac502259ad0.png

3ba5825a-fd8d-11ec-ba43-dac502259ad0.jpg

SystemVerilog-結(jié)構(gòu)體(一)

3bbfb29c-fd8d-11ec-ba43-dac502259ad0.jpg

SystemVerilog-結(jié)構(gòu)體(二)

原文標(biāo)題:SystemVerilog-聯(lián)合體(union)

文章出處:【微信公眾號:OpenFPGA】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

審核編輯:彭靜

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 存儲
    +關(guān)注

    關(guān)注

    13

    文章

    4791

    瀏覽量

    90065
  • 硬件
    +關(guān)注

    關(guān)注

    11

    文章

    3595

    瀏覽量

    69014
  • 數(shù)據(jù)輸出
    +關(guān)注

    關(guān)注

    0

    文章

    20

    瀏覽量

    9358

原文標(biāo)題:SystemVerilog-聯(lián)合體(union)

文章出處:【微信號:Open_FPGA,微信公眾號:OpenFPGA】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    嵌入式開發(fā)中一些少用的C語言用法分享

    的電子產(chǎn)品開發(fā)系統(tǒng)。 2、#pragma anon_unions 支持匿名結(jié)構(gòu)體/聯(lián)合體匿名結(jié)構(gòu)體/聯(lián)合體指的是沒有命名的結(jié)構(gòu),因?yàn)闆]有對應(yīng)的名字,所以也不會直接創(chuàng)建這個對象或者變量,一般都是在嵌套結(jié)構(gòu)中使
    發(fā)表于 01-05 08:19

    一個經(jīng)典的結(jié)構(gòu)體和聯(lián)合體共用的實(shí)例

    Linux 中可以 使用 sizeof 進(jìn)行獲取,默認(rèn)為字節(jié)對齊的大小。 聯(lián)合體 聯(lián)合體的參數(shù)共享同一個內(nèi)存地址,所占的內(nèi)存大小完全是由聯(lián)合體中參數(shù)類型決定字長,然后數(shù)據(jù)共享,內(nèi)存共享等。 結(jié)構(gòu)體和
    發(fā)表于 12-16 07:14

    浙江省腦機(jī)接口重大科技專項(xiàng)與創(chuàng)新聯(lián)合體將開啟,相關(guān)腦機(jī)接口立項(xiàng)國際標(biāo)準(zhǔn)啟動

    來源:維度網(wǎng)-全球簡訊 ? 2025“智聯(lián)·未來”腦機(jī)接口國際會議暨第二屆中國腦機(jī)智能大會將于12月11日至12日舉行。會上,將舉行浙江省腦機(jī)接口重大科技專項(xiàng)與創(chuàng)新聯(lián)合體啟動儀式。 啟動浙江省腦機(jī)
    的頭像 發(fā)表于 12-11 16:40 ?659次閱讀

    中科曙光入選首批天津市卓越工程師培養(yǎng)聯(lián)合體成員單位

    11月23日,天津市卓越工程師培養(yǎng)聯(lián)合體成立儀式暨天津大學(xué)國家卓越工程師學(xué)院高質(zhì)量建設(shè)發(fā)展會議在天津大學(xué)北洋園校區(qū)隆重舉行。中科曙光作為聯(lián)合體首批成員單位受邀出席,總裁助理?xiàng)铠欆幋砥髽I(yè)參會,與政府、高校及產(chǎn)業(yè)界代表共同見證聯(lián)合體
    的頭像 發(fā)表于 11-28 16:42 ?693次閱讀

    C語言的編程技巧

    一個成員是一個未知大小的數(shù)組,適用于動態(tài)分配內(nèi)存并關(guān)聯(lián)一個可變長度的數(shù)組。? ?3、匿名結(jié)構(gòu)體和聯(lián)合體?:C語言允許在結(jié)構(gòu)體或聯(lián)合體中定義不帶標(biāo)簽的內(nèi)部結(jié)構(gòu)體或聯(lián)合體,簡化代碼結(jié)構(gòu)。 ?4
    發(fā)表于 11-27 06:46

    開鴻智谷加入創(chuàng)新聯(lián)合體,共推先進(jìn)制造業(yè)與人力資源服務(wù)融合發(fā)展

    為深入貫徹人才強(qiáng)國與制造強(qiáng)國戰(zhàn)略,助力構(gòu)建現(xiàn)代化產(chǎn)業(yè)體系,湖南湘江新區(qū)正式啟動“人力資源服務(wù)助力先進(jìn)制造業(yè)高質(zhì)量發(fā)展創(chuàng)新聯(lián)合體”(以下簡稱“創(chuàng)新聯(lián)合體”)建設(shè)工作,并于11月1日在長沙人力資源服務(wù)
    的頭像 發(fā)表于 11-03 17:21 ?1273次閱讀
    開鴻智谷加入創(chuàng)新<b class='flag-5'>聯(lián)合體</b>,共推先進(jìn)制造業(yè)與人力資源服務(wù)融合發(fā)展

    元蘿卜破局智能養(yǎng)老:攜聯(lián)合體攻堅(jiān)場景,以“心價(jià)比”升級情緒價(jià)值

    近日,在工業(yè)和信息化部、民政部聯(lián)合推動的智能養(yǎng)老服務(wù)機(jī)器人結(jié)對攻關(guān)與場景應(yīng)用試點(diǎn)工作背景下,商湯科技旗下家用機(jī)器人品牌“元蘿卜”成功入選試點(diǎn)名錄,并受邀加入由潤澤牽頭打造的“智能養(yǎng)老機(jī)器人創(chuàng)新聯(lián)合體
    的頭像 發(fā)表于 09-15 11:52 ?422次閱讀
    元蘿卜破局智能養(yǎng)老:攜<b class='flag-5'>聯(lián)合體</b>攻堅(jiān)場景,以“心價(jià)比”升級情緒價(jià)值

    行芯科技簽約組建EDA創(chuàng)新聯(lián)合體

    活動中,行芯科技參與了《2025浙江省EDA產(chǎn)業(yè)白皮書》發(fā)布儀式。該白皮書以“精準(zhǔn)串鏈、生態(tài)筑圈、決策賦能”三大主線為核心,系統(tǒng)梳理了當(dāng)前產(chǎn)業(yè)發(fā)展現(xiàn)狀與未來方向,為政府決策、企業(yè)布局和產(chǎn)業(yè)創(chuàng)新提供了前瞻性的參考依據(jù),具有重要的行業(yè)指導(dǎo)價(jià)值。
    的頭像 發(fā)表于 09-03 10:41 ?3025次閱讀

    Cubeide1.18.1在線調(diào)試改變\"現(xiàn)場表達(dá)式\"中的值提示找不到地址,為什么?

    from target 我新建工程,排除其他程序,只添加一個變量,依然存在這個問題。 這個問題,有時候會導(dǎo)致我用聯(lián)合體定義的控制寄存器錯亂。感覺這個版本IDE,內(nèi)存調(diào)試處理的有些混亂。望能快速改進(jìn)
    發(fā)表于 06-12 06:50

    Cubeide1.18.1在線調(diào)試改變\"現(xiàn)場表達(dá)式\"中的值提示找不到地址是怎么回事?

    from target 我新建工程,排除其他程序,只添加一個變量,依然存在這個問題。 這個問題,有時候會導(dǎo)致我用聯(lián)合體定義的控制寄存器錯亂。感覺這個版本IDE,內(nèi)存調(diào)試處理的有些混亂。望能快速改進(jìn)
    發(fā)表于 06-10 08:26

    Cubeide1.18.1在線調(diào)試改變\"現(xiàn)場表達(dá)式\"中的值提示找不到地址,怎么解決?

    from target 我新建工程,排除其他程序,只添加一個變量,依然存在這個問題。 這個問題,有時候會導(dǎo)致我用聯(lián)合體定義的控制寄存器錯亂。感覺這個版本IDE,內(nèi)存調(diào)試處理的有些混亂。望能快速改進(jìn)
    發(fā)表于 06-06 08:27

    Cubeide1.18.1在線調(diào)試改變\"現(xiàn)場表達(dá)式\"中的值提示找不到地址怎么解決?

    from target 我新建工程,排除其他程序,只添加一個變量,依然存在這個問題。 這個問題,有時候會導(dǎo)致我用聯(lián)合體定義的控制寄存器錯亂。感覺這個版本IDE,內(nèi)存調(diào)試處理的有些混亂。望能快速改進(jìn)
    發(fā)表于 04-27 06:18

    C語言中結(jié)構(gòu)體與聯(lián)合體的深度解析:內(nèi)存布局與應(yīng)用場景

    : 0, b: 1374389535(浮點(diǎn)數(shù)的二進(jìn)制轉(zhuǎn)換) 原理:通過聯(lián)合體實(shí)現(xiàn)類型雙關(guān)(Type Punning) 四、進(jìn)階應(yīng)用與最佳實(shí)踐 4.1 硬件寄存器映射 typedef struct
    發(fā)表于 04-08 09:18

    長沙新一代信息技術(shù)產(chǎn)教聯(lián)合體正式成立,拓維信息當(dāng)選理事長單位

    3月22日,“長沙新一代信息技術(shù)產(chǎn)教聯(lián)合體成立大會暨第一屆理事會議”在湖南商務(wù)職業(yè)技術(shù)學(xué)院隆重啟幕。會上,長沙新一代信息技術(shù)產(chǎn)教聯(lián)合體正式成立,拓維信息當(dāng)選理事長單位,拓維信息旗下開鴻智谷當(dāng)選
    的頭像 發(fā)表于 03-26 17:48 ?1035次閱讀
    長沙新一代信息技術(shù)產(chǎn)教<b class='flag-5'>聯(lián)合體</b>正式成立,拓維信息當(dāng)選理事長單位

    產(chǎn)教新篇|長沙新一代信息技術(shù)產(chǎn)教聯(lián)合體揚(yáng)帆啟航!

    在深化現(xiàn)代教育體系建設(shè)的主軸推動下,我國職業(yè)教育正以市域產(chǎn)教聯(lián)合體和行業(yè)產(chǎn)教融合共同體為雙翼,構(gòu)建起教育鏈、人才鏈與產(chǎn)業(yè)鏈、創(chuàng)新鏈深度融合的新格局。2025年3月22日,“長沙新一代信息技術(shù)產(chǎn)教
    的頭像 發(fā)表于 03-24 18:09 ?931次閱讀
    產(chǎn)教新篇|長沙新一代信息技術(shù)產(chǎn)教<b class='flag-5'>聯(lián)合體</b>揚(yáng)帆啟航!