精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

關于數字硬件建模SystemVerilog聯合體

OpenFPGA ? 來源:OpenFPGA ? 作者:OpenFPGA ? 2022-07-07 09:05 ? 次閱讀

數字硬件建模SystemVerilog-聯合體(union)

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

聯合體(union)

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

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

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

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

自定義和匿名聯合體

同結構體一樣, 聯合體可以使用 typedef 來定義, 按這種方式定義的是自定義聯合體。如果沒有使用 typedef,就是匿名聯合體.

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

匿名聯合體和自定義聯合體都是可綜合的,但自定義聯合體在RTL建模方面有優勢。自定義聯合體可以是:

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

用作模塊端口類型。

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

分配和讀取聯合體變量

引用聯合體的數據類型時,使用聯合體的名稱,后跟表示數據類型的名稱,并用句點(.)分隔(同結構體一樣)。

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

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

非壓縮聯合體和標記的聯合體

最佳做法準則4-4

在RTL建模中僅使用壓縮聯合體。

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

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

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

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

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

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

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

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

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

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

通過端口將壓縮聯合體傳遞給任務和函數

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

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

示例4-6:包含結構體和聯合體定義的包

//
//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:帶結構體和聯合體端口的算術邏輯單元(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模型中使用結構體和聯合體的兩個重要特征:

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

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

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

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

SystemVerilog-結構體(一)

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

SystemVerilog-結構體(二)

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

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

審核編輯:彭靜

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

    關注

    13

    文章

    4266

    瀏覽量

    85686
  • 硬件
    +關注

    關注

    11

    文章

    3260

    瀏覽量

    66131
  • 數據輸出
    +關注

    關注

    0

    文章

    14

    瀏覽量

    9198

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

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

收藏 人收藏

    評論

    相關推薦

    華為亮相2024年5G創新聯合體“融創行動”論壇

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

    蘇州市人工智能語言計算創新聯合體活動圓滿舉辦

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

    澎峰科技受聘為“主權級大模型”創新聯合體學術委員會委員

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

    長沙角逐算力江湖,長沙市新一代智算產業生態聯合體成立

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

    摩爾線程加入商飛智能“工業元宇宙創新聯合體

    6月18日,商飛智能技術有限公司攜手摩爾線程智能科技(北京)有限責任公司、北京蔚領時代科技有限公司、北京智譜華章科技有限公司、廈門雅基軟件有限公司在張江人工智能島簽署合作協議,共創工業元宇宙創新聯合體。作為聯合體成員中的唯一國產GPU算力企業,摩爾線程高級副總裁董龍飛出席
    的頭像 發表于 06-20 10:09 ?672次閱讀

    智芯公司入選MEMS器件可靠性試驗創新聯合體首批成員單位

    近日,MEMS器件可靠性試驗創新聯合體(以下簡稱“聯合體”)成立大會在京召開,智芯公司、北京大學、清華大學、哈工大、北航、中科院微電子所、中科院空天研究院、中電科三十八所等23家單位入選聯合體首批
    的頭像 發表于 05-15 18:45 ?726次閱讀
    智芯公司入選MEMS器件可靠性試驗創新<b class='flag-5'>聯合體</b>首批成員單位

    芯原科技牽頭的RISC-V創新聯合體獲正式認定授牌

    在近日以“臨港科創 新質未來”為主題的2024臨港科創大會上,芯原科技牽頭組建的RISC-V創新聯合體正式獲得認定授牌。這一創新聯合體是由芯原科技聯合芯來科技等10家上下游企業及3所高校共同發起,展現了多維度、多層次、多元化的合
    的頭像 發表于 03-28 09:19 ?468次閱讀

    天津車聯網技術創新聯合體,正式成立!

    3月22日,天津經緯恒潤有限公司攜手12家京津冀三地優質企業及高校共同成立的車聯網技術創新聯合體舉行揭牌儀式。大會介紹了各成員單位的業務情況、研發計劃和2024年度聯合體的整體工作計劃,為聯合體
    的頭像 發表于 03-26 10:00 ?516次閱讀
    天津車聯網技術創新<b class='flag-5'>聯合體</b>,正式成立!

    天津經緯攜優質企業及高校成立的車聯網技術創新聯合體舉行揭牌儀式

    3月22日,天津經緯恒潤有限公司攜手12家京津冀三地優質企業及高校共同成立的車聯網技術創新聯合體舉行揭牌儀式。
    的頭像 發表于 03-25 10:22 ?468次閱讀
    天津經緯攜優質企業及高校成立的車聯網技術創新<b class='flag-5'>聯合體</b>舉行揭牌儀式

    華為聯合24家企事業單位發起“大模型應用產業聯合體

    華為聯合24家企事業單位發起“大模型應用產業聯合體” 據央視《新聞聯播》報道 日前,華為聯合智譜AI、醫渡科技、百川智能、中國科學院自動化研究所、中軟國際、首都在線、第四范式、格靈深瞳、中科創達、軟
    的頭像 發表于 03-02 15:55 ?1277次閱讀

    北京24家企事業單位組建&quot;大模型應用產業聯合體&quot;?

    據悉,此聯合體旨在利用華為鯤鵬硬件底座與軟件底層資源,推動人工智能產業生態合作,確立相關行業標準,并實現人工智能產業的快速升級。
    的頭像 發表于 03-01 14:44 ?728次閱讀

    思必馳入選“2023年度江蘇省創新聯合體建設試點”名單

    近日,江蘇省科技廳公布了2023年度江蘇省創新聯合體擬建設試點名單,其中,由思必馳科技股份有限公司(以下簡稱:思必馳)牽頭組建的江蘇省人工智能語言計算創新聯合體成功入選,也是全省5家省創新聯合體建設試點之一。
    的頭像 發表于 01-22 13:47 ?797次閱讀

    經典 C 語言編程,結構體和聯合體如何共用?

    中可以 使用 sizeof 進行獲取,默認為字節對齊的大小。 聯合體 聯合體的參數共享同一個內存地址,所占的內存大小完全是由聯合體中參數類型決定字長,然后數據共享,內存共享等。 結構體和聯合
    的頭像 發表于 01-11 18:24 ?1272次閱讀
    經典 C 語言編程,結構體和<b class='flag-5'>聯合體</b>如何共用?

    優必選科技參與成立“人形機器人創新發展聯合體

    在2023年的一場足式、人形機器人生態峰會上,一個名為“移動機器人產業聯盟人形機器人創新發展聯合體”的全新組織正式亮相。作為人形機器人行業的佼佼者,優必選科技不僅積極參與,更是與其他11家在人形機器人產業鏈上具有代表性的企業共同發起了這一聯合體
    的頭像 發表于 12-29 15:03 ?811次閱讀

    【喜訊】芯盾時代當選“北京市高級別自動駕駛示范區智能網聯汽車市域產教聯合體”理事單位

    近日,北京市高級別自動駕駛示范區智能網聯汽車市域產教聯合體(以下簡稱“產教聯合體”)成立大會在北京經開區舉行,由66家政產學研單位共同組成的產教融合平臺正式成立。芯盾時代作為產教聯合體中唯一的業務
    的頭像 發表于 12-22 14:40 ?413次閱讀
    【喜訊】芯盾時代當選“北京市高級別自動駕駛示范區智能網聯汽車市域產教<b class='flag-5'>聯合體</b>”理事單位