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

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

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

3天內不再提示

SystemVerilog 中各種不同的聯合解析

454398 ? 來源:賽靈思論壇 ? 作者:Alan Schuler ? 2020-11-19 15:16 ? 次閱讀

注意:本文所有內容皆來源于Xilinx工程師

BY Alan Schuler

基本聯合

在 SystemVerilog 中,聯合只是信號,可通過不同名稱和縱橫比來加以引用。

其工作方式為通過 typedef 來聲明聯合,并提供不同標識符用于引用此聯合。 這些標識符稱為“字段”。

例如:

typedef union packed {
     logic [3:0] a;
     logic [3:0] b;
} union_type;

union_type my_union;

以上代碼創建了一種新類型,名為“union_type”。

此類型的位寬為 4 位,可作為“a”或“b”來引用。

此外,代碼最后一行創建了一個新信號,名稱為“my_union”且類型為“union_type”。

其使用語法為“.”。

例如:

always@(posedge clk) begin 
     my_union.a < = in1;
end

always@(posedge clk) begin
     out1 < = my_union.a;
     out2 < = my_union.b;
end

在 Vivado 中運行此代碼時,原理圖如下所示:

圖 1:基本聯合

請注意,my_union 位寬仍僅為 4 位,而以“a”或“b”來引用它的兩項分配均采用相同邏輯。 針對 my_union 的分配使用的是“a”,而此聯合的讀取結果針對 out1 和 out2 則分別使用“a”和“b”。

聯合分兩種類型:打包 (packed) 和解包 (unpacked)。在上述示例中,我們指定的是打包聯合。 默認情況下,如果不指定類型,編譯器將假定它采用解包聯合。打包聯合與解包聯合的差別在于,在打包聯合中,其中所有標識符都必須采用打包類型,并且大小必須相同。 在上述示例中,“a”和“b”位寬均為 4 位。 但如果其中之一為 4 位,而另一個為 2 位,則該工具中將生成錯誤。 而在解包聯合中,標識符可采用解包類型并且大小無需相同。 因此,在上述 4 位和 2 位聯合示例中,刪除“packed”語句將使該工具能夠對 RTL 進行完整審查。 總而言之,打包聯合在綜合工具中所受支持更為廣泛,并且更便于概念化。 對于本文中的前幾個聯合示例,我們使用的是打包聯合,但從此處開始直至文末,我們將展示解包聯合示例。

含多維字段的聯合

上述示例只是簡單演示了聯合的作用。 讓我們來看下較為復雜的聯合示例:

typedef union packed {
     logic [3:0] a;
     logic [1:0][1:0] b;
} union_type;

union_type my_union;

同上,首先對聯合進行聲明,并創建類型為“union_type”的信號。 差別在于,字段“a”位寬為 4 位,另一個字段“b”位寬同樣為 4 位,但后者排列為 2 個 2 位矢量。 由于這兩個字段大小相同,并且字段“b”使用的是打包類型,因此這是一個合法的打包聯合。

其結構如下所示:

圖 2:含多維陣列的聯合

為此結構分配的 RTL 如下所示:

always@(posedge clk) begin
     my_union.a < = in1;
end

always@(posedge clk) begin
     out1 < = my_union.b[0];
     out2 < = my_union.b[1];
end

原理圖如下所示:

圖 3:多維聯合的原理圖

含結構的聯合

聯合還可配合結構一起使用。 就像所有打包聯合一樣,結構大小必須與聯合中的任何其他類型的大小相同。

例如:

typedef union packed {
     logic [9:0] data;
     struct packed {
          bit op1;
          bit [2:0] op2;
          bit [1:0] op3;
          bit op4;
          bit [2:0] op5;
     } op_modes;
} union_type;

union_type my_union;

此 RTL 介紹的聯合包含 2 個位寬均為 10 位的字段。 第一個字段為名為“data”且位寬為 10 位的矢量。 第二個字段采用包含 5 個字段的結構,這些字段的大小總和同樣為 10 位。

為此創建的結構如下所示:

圖 4:含結構的聯合

由于當前聯合中包含結構,因此其正確的引用方式是引用聯合中的結構:

always@(posedge clk) begin
     my_mult < = my_union.op_modes.op2 * my_union.op_modes.op5;
end

解包聯合

如果聯合中的字段大小不同,或者如果聯合中的字段本身使用的類型為解包類型,那么此類聯合需聲明為解包聯合。

對于前一種情況,如果指定的聯合包含不同大小的字段,那么該聯合本身大小將設置為最大字段的大小。

示例 RTL:

typedef union {
     logic [5:0] a;
     logic [3:0] b;
     logic c;
} union_type;

union_type my_union;

這樣即可創建如下所示結構:

圖 5:含不同大小字段的解包聯合

含結構的解包聯合

與打包聯合相同,解包聯合同樣可以使用結構。

typdef struct {
     bit [3:0] a1;
     bit a2;
} s_1;

typedef union {
     logic [7:0] b1;
     s_1 b2;
} union_type

union_type my_union;

以上示例將創建一個含兩個字段的聯合。其中一個字段為位寬 8 位的矢量“b1”,另一個字段為位寬 5 位的結構,此結構由一個位寬 4 位的矢量 a1 和一個位寬 1 位的矢量 a2 組成。

此聯合將作為位寬 8 位的矢量來創建,如下所示:

圖 6:含結構的解包聯合

同上,由于聯合中包含結構,因此需按如下方式來引用信號:

always@(posedge clk) begin
     my_union.b1 <= in1;
     out1 <= my_union.b2.a1;
     out2 <= my_union.b2.a2;
end

編輯:hfy


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

    關注

    1

    文章

    1634

    瀏覽量

    49133
  • Vivado
    +關注

    關注

    19

    文章

    812

    瀏覽量

    66542
收藏 人收藏

    評論

    相關推薦

    OptiSystem與OptiSPICE的聯合使用:收發機電路的眼圖分析

    OptiSPICE傳輸到OptiSystem。一旦OptiSPICE的輸入和輸出被定義(ElecInput_V1和probes;參見圖1),原理圖需要配置為聯合模擬運行。這可以通過點擊
    發表于 12-10 08:59

    ZCAN PRO解析的DBC Singal 起始位與XNET解析的起始位不同;解析的信號不符合大端邏輯

    上圖中的DBC文件使用記事本打開,Data_Field信號,起始位為23,長度為48,大端方式存儲;(按照這個方式存儲,明顯已經溢出) 上圖為該信號在ZCANPRO軟件打開,解析的起始位為23
    發表于 10-18 13:53

    IEC101、IEC103、IEC104、Modbus報文解析工具

    IEC101\IEC104\IEC103\Modebus報文解析軟件,可有效解析上述協議的各種類型報文
    的頭像 發表于 09-02 09:56 ?1236次閱讀
    IEC101、IEC103、IEC104、Modbus報文<b class='flag-5'>解析</b>工具

    SoC布局各種IC簡介

    。SoC各種IP簡介IP核(IntellectualPropertyCore),即知識產權核,在集成電路設計行業中指已驗證、可重復利用、具有某種確定功能的芯片設
    的頭像 發表于 07-17 08:28 ?377次閱讀
    SoC布局<b class='flag-5'>中</b><b class='flag-5'>各種</b>IC簡介

    工程安全監測的振弦采集儀技術解析與應用

    工程安全監測的振弦采集儀技術解析與應用 河北穩控科技振弦采集儀是一種在工程安全監測中廣泛使用的儀器,用于測量和監測結構的振動和應變。它通過采集結構的振弦信號,可以提供詳細的結構運行狀態和變化情況
    的頭像 發表于 07-11 10:19 ?336次閱讀
    工程安全監測<b class='flag-5'>中</b>的振弦采集儀技術<b class='flag-5'>解析</b>與應用

    PLC基本結構解析

    方式和便捷的編程方式,被廣泛應用于各種工業控制系統。本文將詳細解析PLC的基本結構,包括其主要組成部分的功能和特點,以便讀者對PLC有更深入的了解。
    的頭像 發表于 06-25 14:30 ?974次閱讀

    labview聯合Halcon,實時采集的圖像應該如何傳入?

    labview聯合Halcon,實時采集的圖像應該如何傳入?
    發表于 06-25 00:57

    求助,關于串口數據解析疑問求解

    現在手上有一個串口模塊要開發,比較復雜, 功能:接收各種類型不定長度的 字符串,然后解析做出反饋 字符串基本規格: 單條命令 : CMD(X,Y,\'ABC或者中文字符不定長\',W
    發表于 04-29 06:34

    為什么STM32F0 modbus在解析接收不到任何數據?

    我看了很久也找不到為什么我的modbus在解析接收不到任何數據,求大神幫助下,感激不盡
    發表于 04-25 06:28

    光纜防火等級( OFNR OFNP OFNG)解析

    Nonconductive Plenum): 解析: OFNP 是一種光纜防火標識,專門設計用于安裝在空氣流通的空間,如空氣處理設備的空
    的頭像 發表于 03-22 11:01 ?3363次閱讀

    IEEE 1800-2023 SystemVerilog新版本正式發布了!

    2024年3月初,在美國硅谷舉辦的DVCon2024上,IEEE-SA和Accellera聯合宣布通過IEEE Get Program可以免費獲取IEEE 1800-2023 SystemVerilog語言參考手冊。
    的頭像 發表于 03-20 13:52 ?1736次閱讀

    請問Systemverilog如何使用VHDL的package?

    現在需要使用system verilog寫代碼,但是想復用之前VHDL的package,里面有寫的現成的function等,請問如何調用呢。總是報錯說找不到_pkg
    發表于 03-12 15:37

    在Vivado Synthesis怎么使用SystemVerilog接口連接邏輯呢?

    SystemVerilog 接口的開發旨在讓設計中層級之間的連接變得更加輕松容易。 您可以把這類接口看作是多個模塊共有的引腳集合。
    的頭像 發表于 03-04 15:25 ?965次閱讀
    在Vivado Synthesis<b class='flag-5'>中</b>怎么使用<b class='flag-5'>SystemVerilog</b>接口連接邏輯呢?

    XML在HarmonyOS的生成,解析與轉換(下)

    一、XML 解析 對于以 XML 作為載體傳遞的數據,實際使用需要對相關的節點進行解析,一般包括解析 XML 標簽和標簽值、解析 XML
    的頭像 發表于 02-18 10:07 ?741次閱讀

    美國JDAM聯合制導攻擊武器技術解析與實戰應用

    聯合制導攻擊武器一般由Mk-82(500磅)、Mk-83(1000磅)和Mk-84(2000磅)四種規格的常規炸彈改裝而成,改裝后分別編號為GBU-38、GBU-32和GBU-31。其中GBU-32和GBU-31為專用侵徹型炸彈,可用于打擊地堡和堅固目標。
    發表于 01-19 10:32 ?1669次閱讀
    美國JDAM<b class='flag-5'>聯合</b>制導攻擊武器技術<b class='flag-5'>解析</b>與實戰應用
    主站蜘蛛池模板: 欧美乱妇15p| 天天操夜夜操| 日本最好的免费影院| 免费一级网站| 天天做日日爱| xxxx性欧美高清| 五月婷婷之综合激情| 欧美黄色一级片视频| 亚洲午夜久久久精品影院| aaa特级毛片| а8天堂资源在线官网| 伊人成人在线| 久久久久久噜噜噜久久久精品| 夜夜爱视频| 1515hh四虎免费观38com| 午夜dy888理论| 美女免费视频是黄的| 色视频免费| 2021色噜噜狠狠综曰曰曰| 久久青草免费91观看| 欧美肥胖女人bbwbbw视频| 成人a区| 韩国三级中文| 西西人体大胆高清啪啪欧洲| 亚洲韩国在线一卡二卡| 艹逼免费视频| 神马午夜在线观看| 欲色视频| 7m视频精品凹凸在线播放| 亚洲一区二区三区高清视频| 欧美一级视频在线观看欧美| 翘臀白浆| 能在线观看的一区二区三区| 免费网站色| 性欧美1819hd| 久久aa毛片免费播放嗯啊| 亚洲成人午夜影院| 亚洲人成电影在线小说网色| 在线视免费频观看韩国aaa| 日本人六九视频69jzz免费| 人人干人人草|