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

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

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

3天內不再提示

Xilinx SystemVerilog中的基本聯合體

C29F_xilinx_inc ? 來源:賽靈思 ? 作者:賽靈思 ? 2022-02-19 19:01 ? 次閱讀

基本聯合體
在 SystemVerilog 中,聯合體只是信號,可通過不同名稱和縱橫比來加以引用。 其工作方式為通過 typedef 來聲明聯合,并提供不同標識符用于引用此聯合體。 這些標識符稱為“字段”。

例如:

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

union_type my_union;
復制代碼

以上代碼創(chuàng)建了一種新類型,名為“union_type”。

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

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

其使用語法為“.”。

例如:

always@(posedge clk) begin
my_union.a end

always@(posedge clk) begin
out1 out2 end
復制代碼

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

Xilinx SystemVerilog中的基本聯合體

圖 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
復制代碼

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

Xilinx SystemVerilog中的基本聯合體

圖 2:含多維陣列的聯合體

為此結構賦值的 RTL 如下所示:

always@(posedge clk) begin
my_union.a end

always@(posedge clk) begin
out1 out2 end
復制代碼

原理圖如下所示:

Xilinx SystemVerilog中的基本聯合體

圖 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 位。

為此創(chuàng)建的結構體如下所示:

Xilinx SystemVerilog中的基本聯合體

圖 4:含結構體的聯合體

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

always@(posedge clk) begin
my_mult end
復制代碼

解包聯合體
如果聯合體中的字段大小不同,或者如果聯合體中的字段本身使用的類型為解包類型,那么此類聯合體需聲明為解包聯合體。 對于前一種情況,如果指定的聯合體包含不同大小的字段,那么該聯合體本身大小將設置為最大字段的大小。 示例 RTL:

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

union_type my_union;
復制代碼

這樣即可創(chuàng)建如下所示結構:

poYBAGIQzu2AKO9EAABJGb3R8ag626.jpg

圖 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;
復制代碼

以上示例將創(chuàng)建一個含兩個字段的聯合體。其中一個字段為位寬 8 位的矢量“b1”,另一個字段為位寬 5 位的結構體,此結構體由一個位寬 4 位的矢量 a1 和一個位寬 1 位的矢量 a2 組成。 此聯合體將作為位寬 8 位的矢量來創(chuàng)建,如下所示:

Xilinx SystemVerilog中的基本聯合體

圖 6:含結構體的解包聯合體

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

always@(posedge clk) begin
my_union.b1 out1 out2 end
復制代碼

審核編輯:湯梓紅

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

    關注

    73

    文章

    2183

    瀏覽量

    124460
  • 代碼
    +關注

    關注

    30

    文章

    4891

    瀏覽量

    70305
  • 編譯器
    +關注

    關注

    1

    文章

    1657

    瀏覽量

    49919
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    Cubeide1.18.1在線調試改變\"現場表達式\"的值提示找不到地址,為什么?

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

    Cubeide1.18.1在線調試改變\"現場表達式\"的值提示找不到地址是怎么回事?

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

    Cubeide1.18.1在線調試改變\"現場表達式\"的值提示找不到地址,怎么解決?

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

    Cubeide1.18.1在線調試改變\"現場表達式\"的值提示找不到地址怎么解決?

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

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

    4字節(jié)對齊) 成員訪問:通過.運算符獨立操作 生命周期:所有成員同時存在 1.2 聯合體(Union)的奧秘 聯合體通過內存共享機制實現數據復用,其內存大小由最大成員決定: union Data
    發(fā)表于 04-08 09:18

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    6月18日,商飛智能技術有限公司攜手摩爾線程智能科技(北京)有限責任公司、北京蔚領時代科技有限公司、北京智譜華章科技有限公司、廈門雅基軟件有限公司在張江人工智能島簽署合作協議,共創(chuàng)工業(yè)元宇宙創(chuàng)新聯合體。作為聯合體成員的唯一國產
    的頭像 發(fā)表于 06-20 10:09 ?1003次閱讀
    主站蜘蛛池模板: 天天免费 | www射射一区 | 亚洲成人在线免费观看 | 国产成人午夜片在线观看 | 午夜小视频在线播放 | 国产色婷婷精品综合在线 | 精品视频一二三区 | 五月婷婷婷婷 | 四虎永久在线精品国产免费 | 欧美啪啪小视频 | 国内色视频 | 久久精品国产99精品最新 | 黄 色 录像成 人播放免费99网 | 国产成人精品一区二区三区 | 亚洲精品www | 在线免费视频网站 | 欧美潘金莲一级风流片a级 欧美片欧美日韩国产综合片 | 中文字幕一区在线 | 成人网中文字幕色 | 天堂网www中文天堂在线 | 国产www在线播放 | 在线观看网站国产 | 在线观看免费午夜大片 | 91国内在线| 日本三级在线播放线观看2021 | 久综合色 | 日韩a无吗一区二区三区 | 日本黄色片www | 97在线人人| 一区二区三区四区在线 | www.妖精视频| 日本一二区视频 | 寡妇影院首页亚洲图片 | 夜夜操国产 | 九九视频这里只有精品 | 最近在线视频免费观看2019 | 久久鬼| jinv在线视频 | 日韩三级毛片 | 色婷婷视频在线 | 午夜精品视频在线观看美女 |