色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

SystemVerilog中的聯(lián)合(union)介紹

FPGA之家 ? 來源:FPGA之家 ? 2023-10-08 15:45 ? 次閱讀

基本聯(lián)合

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

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

例如:


wKgZomUiXlyAX_iLAAAhIiPxz_8340.jpg

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

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

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

其使用語法為“.”。

例如:

wKgaomUiXm-AXQy-AAAoTeEqc5o077.jpg

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

80d5ea60-65ae-11ee-939d-92fbcf53809c.png

圖 1:基本聯(lián)合

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

聯(lián)合分兩種類型:打包 (packed) 和解包 (unpacked)。在上述示例中,我們指定的是打包聯(lián)合。默認情況下,如果不指定類型,編譯器將假定它采用解包聯(lián)合。

打包聯(lián)合與解包聯(lián)合的差別在于,在打包聯(lián)合中,其中所有標識符都必須采用打包類型,并且大小必須相同。

在上述示例中,“a”和“b”位寬均為 4 位。但如果其中之一為 4 位,而另一個為 2 位,則該工具中將生成錯誤。而在解包聯(lián)合中,標識符可采用解包類型并且大小無需相同。

因此,在上述 4 位和 2 位聯(lián)合示例中,刪除“packed”語句將使該工具能夠對 RTL 進行完整審查。

總而言之,打包聯(lián)合在綜合工具中所受支持更為廣泛,并且更便于概念化。對于本文中的前幾個聯(lián)合示例,我們使用的是打包聯(lián)合,但從此處開始直至文末,我們將展示解包聯(lián)合示例。

含多維字段的聯(lián)合

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

wKgZomUiXoeAK2fBAAAay0r8Ty8031.jpg

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

其結構如下所示:

80e3fd3a-65ae-11ee-939d-92fbcf53809c.png

圖 2:含多維陣列的聯(lián)合

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

wKgaomUiXpuASRTEAAAqGzvcKzU043.jpg

原理圖如下所示:

80f30b22-65ae-11ee-939d-92fbcf53809c.png

圖 3:多維聯(lián)合的原理圖

含結構的聯(lián)合

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

例如:

wKgZomUiXrGALW8gAAA1bBhuiPc970.jpg

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

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

80fa047c-65ae-11ee-939d-92fbcf53809c.png

圖 4:含結構的聯(lián)合

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

wKgaomUiXsKAK42xAAAfoypBdW0368.jpg

解包聯(lián)合

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

對于前一種情況,如果指定的聯(lián)合包含不同大小的字段,那么該聯(lián)合本身大小將設置為最大字段的大小。 示例 RTL:

wKgZomUiXtGAZjeeAAAb_EADTEM481.jpg

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

8105de46-65ae-11ee-939d-92fbcf53809c.png

圖 5:含不同大小字段的解包聯(lián)合

含結構的解包聯(lián)合

與打包聯(lián)合相同,解包聯(lián)合同樣可以使用結構。

wKgaomUiXuKADDVvAAAjTsQ8Lgg247.jpg

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

此聯(lián)合將作為位寬 8 位的矢量來創(chuàng)建,如下所示:

8109851e-65ae-11ee-939d-92fbcf53809c.png

圖 6:含結構的解包聯(lián)合

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

wKgZomUiXviAMTLMAAAbu4ijY4E317.jpg







審核編輯:劉清

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

    關注

    1

    文章

    386

    瀏覽量

    60169
  • Verilog語言
    +關注

    關注

    0

    文章

    113

    瀏覽量

    8340

原文標題:SystemVerilog 中的聯(lián)合 (union)

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

收藏 人收藏

    評論

    相關推薦

    SystemVerilog 各種不同的聯(lián)合解析

    聯(lián)合分兩種類型:打包 (packed) 和解包 (unpacked)。在上述示例,我們指定的是打包聯(lián)合
    的頭像 發(fā)表于 11-19 15:16 ?2197次閱讀
    <b class='flag-5'>SystemVerilog</b> <b class='flag-5'>中</b>各種不同的<b class='flag-5'>聯(lián)合</b>解析

    SystemVerilog的Virtual Methods

    SystemVerilog多態(tài)能夠工作的前提是父類的方法被聲明為virtual的。
    發(fā)表于 11-28 11:12 ?766次閱讀

    聯(lián)合union在labview如何建立

    typedef union{Driver_up_Status DuS; Driver_down_Status Dds;}Driver_Status;Driver_up_Status 和 Driver_down_Status都是定義的枚舉類型。請問大神們,這個聯(lián)合體在lab
    發(fā)表于 08-09 11:28

    如何定義了這個聯(lián)合體?

    我先定義一個聯(lián)合體數(shù)據(jù)類型,然后接著定義了一些聯(lián)合體變量,定義聯(lián)合體部分如下:我在sys_config.c文件定義如下聯(lián)合體數(shù)據(jù)類型和變量
    發(fā)表于 07-12 04:28

    結構體struct和聯(lián)合union的區(qū)別?

    結構體struct和聯(lián)合union的區(qū)別?
    發(fā)表于 10-11 08:21

    單片機編程之聯(lián)合體(union)的妙用

    單片機編程之聯(lián)合體(union)的妙用
    發(fā)表于 11-13 18:36 ?13次下載
    單片機編程之<b class='flag-5'>聯(lián)合</b>體(<b class='flag-5'>union</b>)的妙用

    union 的概念及在嵌入式編程的應用

    union 在中文的叫法又被稱為共用體,聯(lián)合或者聯(lián)合體,它定義的方式與 struct 是相同的,但是意義卻與 struct 完全不同,下面是 un
    發(fā)表于 02-07 11:30 ?0次下載
    <b class='flag-5'>union</b> 的概念及在嵌入式編程<b class='flag-5'>中</b>的應用

    Xilinx SystemVerilog的基本聯(lián)合

    SystemVerilog 聯(lián)合體只是信號,可通過不同名稱和縱橫比來加以引用。 其工作方式為通過 typedef 來聲明聯(lián)合,并提供不同標識符用于引用此
    的頭像 發(fā)表于 02-19 19:01 ?1279次閱讀
    Xilinx <b class='flag-5'>SystemVerilog</b><b class='flag-5'>中</b>的基本<b class='flag-5'>聯(lián)合</b>體

    Systemverilogunion

    SystemVerilog union允許單個存儲空間以不同的數(shù)據(jù)類型存在,所以union雖然看起來和struct一樣包含了很多個成員,實際上物理上共享相同的存儲區(qū)域。
    的頭像 發(fā)表于 11-09 09:41 ?1003次閱讀

    SystemVerilog的tagged Unions是什么

    tagged union包含一個隱式成員,該成員存儲tag,也就是標記,它表示這個union最終存儲的到底是哪一個成員。
    的頭像 發(fā)表于 11-10 10:02 ?1562次閱讀

    SystemVerilog的Unpacked Unions

    unpacked union各個成員的大小可以是不同的。
    的頭像 發(fā)表于 11-11 09:33 ?762次閱讀

    SystemVerilog的Packed Union

    packed union相比unpacked union最大的一個區(qū)別就是,在packed union,所有成員的大小必須相同,這就保證了不管un
    的頭像 發(fā)表于 11-12 09:05 ?1234次閱讀

    SystemVerilog的Shallow Copy

    SystemVerilog的句柄賦值和對象復制的概念是有區(qū)別的。
    的頭像 發(fā)表于 11-21 10:32 ?1000次閱讀

    關鍵字union的基本定義和使用

    關鍵字union,又稱為聯(lián)合體、共用體,聯(lián)合體的聲明和結構體類似,但是它的行為方式又和結構體不同,這里的行為方式主要指的是其在內存的體現(xiàn),結構體
    的頭像 發(fā)表于 04-15 11:18 ?3213次閱讀
    關鍵字<b class='flag-5'>union</b>的基本定義和使用

    unionunion all有什么區(qū)別

    UnionUnion All是SQL的兩個關鍵字,它們用于將兩個或多個SELECT語句的結果集合并在一起。這兩個關鍵字雖然有相似的功能,但在實際使用中有一些重要的區(qū)別。下面將詳細介紹
    的頭像 發(fā)表于 12-06 10:22 ?1250次閱讀
    主站蜘蛛池模板: 亚洲视频无码高清在线 | 国产成人在线播放视频 | Zoofilivideo人馿交 | 99re这里只有精品视频 | 亚洲欧美日韩高清专区 | 激情床戏视频片段有叫声 | 久久欧洲AV无码精品色午夜麻豆 | 亚洲区欧美日韩综合 | 狠狠干女人| 晚夜免费禁用十大亏亏 | 久久偷拍免费2017 | 国产成人精品久久一区二区三区 | 亚洲中文日韩日本在线视频 | 国产女人91精品嗷嗷嗷嗷 | 久久综合久久伊人 | 国产午夜精品自在自线之la | 1a级毛片免费观看 | 久久偷拍国2017的 | vidosgratis tv少女| 男人J桶女人P视频无遮挡网站 | 国精一区二区AV在线观看网站 | a久久99精品久久久久久蜜芽 | 久久伊人草 | 偷窥自拍性综合图区 | 国产电影一区二区三区 | 免费精品一区二区三区在线观看 | 亚洲 自拍 欧洲 视频二区 | 亚洲成人在线免费观看 | 久久毛片网站 | 超清无码波多野吉衣与黑人 | 少妇被躁爽到高潮无码久久 | 越南女 黑人 痛苦 大叫 | 免费A级毛片无码无遮挡内射 | 日韩欧美精品有码在线播放免费 | 调教椅上的调教SM总裁被调教 | 天美传媒在线观看完整高清 | 午夜一区欧美二区高清三区 | 免费人成在线观看视频不卡 | av老司机色爱区综合 | 乌克兰肛交影视 | 国产成a人片在线观看视频99 |