在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

關于數(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)合體的聲明類似結構體,但推斷出的硬件非常不同。結構體是幾個變量的集合。union是單個變量,可以在不同的時間使用不同的數(shù)據(jù)類型。union可以存儲的變量類型列在大括號({})之間,每個變量類型都有一個名稱:

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

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

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

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

同結構體一樣, 聯(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ù)類型的名稱,并用句點(.)分隔(同結構體一樣)。

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)合體和標記的聯(lián)合體

最佳做法準則4-4

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

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

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

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

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

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

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

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

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

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

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

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

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

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

示例4-6:包含結構體和聯(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:帶結構體和聯(lián)合體端口的算術邏輯單元(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顯示了綜合該示例的結果。說明了在RTL模型中使用結構體和聯(lián)合體的兩個重要特征:

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

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

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

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

SystemVerilog-結構體(一)

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

SystemVerilog-結構體(二)

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

文章出處:【微信公眾號:OpenFPGA】歡迎添加關注!文章轉載請注明出處。

審核編輯:彭靜

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

    關注

    13

    文章

    4507

    瀏覽量

    87088
  • 硬件
    +關注

    關注

    11

    文章

    3461

    瀏覽量

    67207
  • 數(shù)據(jù)輸出

    關注

    0

    文章

    14

    瀏覽量

    9264

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

文章出處:【微信號:Open_FPGA,微信公眾號:OpenFPGA】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    C語言中結構體與聯(lián)合體的深度解析:內存布局與應用場景

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

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

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

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

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

    軟通動力亮相福建昇騰AI產業(yè)發(fā)展論壇

    近日,福建昇騰AI產業(yè)發(fā)展論壇在廈門舉辦。軟通動力應邀出席,并作為“福建人工智能自主創(chuàng)新聯(lián)合體”重要成員,與華為及生態(tài)伙伴等多方機構共同宣布了聯(lián)合體的成立,旨在積極布局福建省人工智能產業(yè),培育人工智能新業(yè)態(tài),為數(shù)字經濟注入嶄新活
    的頭像 發(fā)表于 12-23 13:52 ?505次閱讀

    商湯科技與多家廠商共同成立語料終端創(chuàng)新聯(lián)合體

    近日,由中央廣播電視總臺、上海市人民政府共同主辦的2024科創(chuàng)大會在上海落下帷幕。期間,商湯科技與上海庫帕思科技有限公司、上海阡視科技有限公司、以及國產主流芯片等共19家廠商共同成立語料終端創(chuàng)新聯(lián)合體
    的頭像 發(fā)表于 12-16 13:46 ?997次閱讀

    軟通動力發(fā)起精細化工與新材料行業(yè)產業(yè)鏈數(shù)字化轉型生態(tài)聯(lián)合體

    與新材料行業(yè)數(shù)智化轉型高峰論壇",攜手多家企業(yè)發(fā)起精細化工與新材料行業(yè)"1+1+N"產業(yè)鏈數(shù)字化轉型生態(tài)聯(lián)合體,與數(shù)家企業(yè)簽訂戰(zhàn)略合作協(xié)議、達成項目合作意向。 ? 華為云廣東生態(tài)發(fā)展與運營部伙伴成功經理毛煥在致辭中指出,數(shù)智化轉型是一項系統(tǒng)工程,需
    的頭像 發(fā)表于 12-09 15:13 ?391次閱讀
    軟通動力發(fā)起精細化工與新材料行業(yè)產業(yè)鏈<b class='flag-5'>數(shù)字</b>化轉型生態(tài)<b class='flag-5'>聯(lián)合體</b>

    拓維信息參與牽頭組建!長沙新一代信息技術產教聯(lián)合體正式獲批

    近日,由長沙市教育局和長沙市工業(yè)和信息化局聯(lián)合發(fā)布的《2024年長沙市市級市域產教聯(lián)合體名單》正式公布。其中,由長沙高新區(qū)麓谷產業(yè)園(長沙信息產業(yè)園)、拓維信息、湖南商務職業(yè)技術學院共同牽頭組建
    的頭像 發(fā)表于 12-07 01:06 ?789次閱讀
    拓維信息參與牽頭組建!長沙新一代信息技術產教<b class='flag-5'>聯(lián)合體</b>正式獲批

    華為亮相2024年5G創(chuàng)新聯(lián)合體“融創(chuàng)行動”論壇

    近日,由中國移動通信集團研究院、中國移動通信集團江蘇有限公司聯(lián)合主辦的2024年5G創(chuàng)新聯(lián)合體“融創(chuàng)行動”面向工業(yè)生產控制的5G-A確定性關鍵技術研究與應用示范聯(lián)合創(chuàng)新論壇在無錫太湖新城假日酒店舉辦。
    的頭像 發(fā)表于 11-25 10:38 ?912次閱讀

    泰晶科技推動車規(guī)級芯片產業(yè)創(chuàng)新發(fā)展

    日前,湖北省車規(guī)級芯片產業(yè)技術創(chuàng)新聯(lián)合體2024年大會召開,由東風汽車牽頭聯(lián)合國內芯片產業(yè)鏈企業(yè)組建、共建車規(guī)級芯片產業(yè)技術生態(tài)的湖北省車規(guī)級芯片產業(yè)技術創(chuàng)新聯(lián)合體(以下簡稱“創(chuàng)新聯(lián)合體
    的頭像 發(fā)表于 11-18 10:48 ?682次閱讀

    蘇州市人工智能語言計算創(chuàng)新聯(lián)合體活動圓滿舉辦

    活動伊始,園區(qū)企業(yè)發(fā)展服務中心副主任吳小慶與思必馳副總裁李春梅共同為“益企家”企業(yè)服務聯(lián)絡站——人工智能語言計算創(chuàng)新聯(lián)合體站揭牌。截至目前,園區(qū)企服中心已設立20家聯(lián)絡站。未來,聯(lián)絡站將深度賦能聯(lián)合體成員單位企業(yè),為企業(yè)提供“全方位”、“零距離”的服務,助力產業(yè)高質量發(fā)展
    的頭像 發(fā)表于 10-14 14:08 ?628次閱讀

    澎峰科技受聘為“主權級大模型”創(chuàng)新聯(lián)合體學術委員會委員

    日前,“主權級大模型“創(chuàng)新聯(lián)合體揭牌,澎峰科技CEO受聘為”主權級大模型“創(chuàng)新聯(lián)合體學術委員會委員。
    的頭像 發(fā)表于 09-02 17:37 ?1114次閱讀

    長沙角逐算力江湖,長沙市新一代智算產業(yè)生態(tài)聯(lián)合體成立

    算力正成為數(shù)字時代經濟發(fā)展的新引擎。為大力發(fā)展相關產業(yè),8月28日,長沙市新一代智算產業(yè)生態(tài)聯(lián)合體正式成立,新一代智算產業(yè)生態(tài)聯(lián)合體集聚了北京大學長沙計算與數(shù)字經濟研究院、湖南大學、華
    的頭像 發(fā)表于 08-30 11:14 ?844次閱讀

    普源精電入選“2024蘇州民營企業(yè)創(chuàng)新100強”與“2024年度蘇州市創(chuàng)新聯(lián)合體

    近日,蘇州企業(yè)家創(chuàng)新發(fā)展大會順利召開,會上公布了多項獎項,普源精電科技股份有限公司(簡稱:普源精電)憑借在核心技術領域的突破與創(chuàng)新,先后入選“2024蘇州民營企業(yè)創(chuàng)新100強”與“2024年度蘇州市創(chuàng)新聯(lián)合體”名單,充分展現(xiàn)硬核科技實力!
    的頭像 發(fā)表于 08-01 15:44 ?641次閱讀

    匯川技術持續(xù)推動產業(yè)創(chuàng)新和低碳轉型升級

    近日,在蘇州企業(yè)家創(chuàng)新發(fā)展大會上,由蘇州匯川控制技術有限公司牽頭打造的蘇州市低碳零碳數(shù)智化關鍵技術創(chuàng)新聯(lián)合體,以及由蘇州匯川聯(lián)合動力系統(tǒng)股份有限公司牽頭打造的蘇州市新能源汽車先進驅動電機關鍵技術創(chuàng)新聯(lián)合體分別獲蘇州創(chuàng)新
    的頭像 發(fā)表于 07-26 11:25 ?1199次閱讀

    摩爾線程加入商飛智能“工業(yè)元宇宙創(chuàng)新聯(lián)合體

    6月18日,商飛智能技術有限公司攜手摩爾線程智能科技(北京)有限責任公司、北京蔚領時代科技有限公司、北京智譜華章科技有限公司、廈門雅基軟件有限公司在張江人工智能島簽署合作協(xié)議,共創(chuàng)工業(yè)元宇宙創(chuàng)新聯(lián)合體。作為聯(lián)合體成員中的唯一國產GPU算力企業(yè),摩爾線程高級副總裁董龍飛出席
    的頭像 發(fā)表于 06-20 10:09 ?994次閱讀
    主站蜘蛛池模板: 亚洲综合免费 | 久久天天躁狠狠躁夜夜免费观看 | 天天搞夜夜爽 | 四虎在线播放免费永久视频 | 亚洲国产成人精品久久 | 成人精品亚洲 | 可以免费看黄色的网站 | 亚洲第一页国产 | 午夜免费啪在线观看视频网站 | 成 人色 网 站999 | xxxxx日本69| 色婷婷亚洲 | 久草在线免费资源站 | 中出丰满大乳中文字幕 | 国产精品久久久久影院色老大 | 国产呦系列呦交 | 欧美一区精品 | 九九国产精品 | 亚州一级毛片在线 | 永久免费在线播放 | 午夜免费的国产片在线观看 | 久久波多野结衣 | 黄色的网站在线观看 | 天天躁夜夜躁狠狠躁2018a | 男人操女人的网站 | 福利片网站| 黄网站观看 | 免费性bbbb台湾 | 上海一级毛片 | 免费人成黄页在线观看1024 | 中文天堂最新版资源新版天堂资源 | 天天干天天曰 | 激情在线播放免费视频高清 | 色综合天天 | 亚洲成a人片777777久久 | 一级午夜 | 亚洲人成电影在线播放 | 女人张开腿给人桶免费视频 | 51午夜 | 99免费观看视频 | 中国性猛交xxxx乱大交 |