日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

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

454398 ? 來源:賽靈思論壇 ? 作者:Alan Schuler ? 2020-11-19 15:16 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

注意:本文所有內(nèi)容皆來源于Xilinx工程師

BY Alan Schuler

基本聯(lián)合

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

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

例如:

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 < = in1;
end

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

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

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

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

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

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

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

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

union_type my_union;

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

其結(jié)構(gòu)如下所示:

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

為此結(jié)構(gòu)分配的 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:多維聯(lián)合的原理圖

含結(jié)構(gòu)的聯(lián)合

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

例如:

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 介紹的聯(lián)合包含 2 個位寬均為 10 位的字段。 第一個字段為名為“data”且位寬為 10 位的矢量。 第二個字段采用包含 5 個字段的結(jié)構(gòu),這些字段的大小總和同樣為 10 位。

為此創(chuàng)建的結(jié)構(gòu)如下所示:

圖 4:含結(jié)構(gòu)的聯(lián)合

由于當(dāng)前聯(lián)合中包含結(jié)構(gòu),因此其正確的引用方式是引用聯(lián)合中的結(jié)構(gòu):

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

解包聯(lián)合

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

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

示例 RTL:

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

union_type my_union;

這樣即可創(chuàng)建如下所示結(jié)構(gòu):

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

含結(jié)構(gòu)的解包聯(lián)合

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

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)建一個含兩個字段的聯(lián)合。其中一個字段為位寬 8 位的矢量“b1”,另一個字段為位寬 5 位的結(jié)構(gòu),此結(jié)構(gòu)由一個位寬 4 位的矢量 a1 和一個位寬 1 位的矢量 a2 組成。

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

圖 6:含結(jié)構(gòu)的解包聯(lián)合

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

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

編輯:hfy


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

    關(guān)注

    1

    文章

    1673

    瀏覽量

    51958
  • Vivado
    +關(guān)注

    關(guān)注

    19

    文章

    860

    瀏覽量

    71423
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    雙CMOS調(diào)制器AD7724的技術(shù)解析與應(yīng)用指南

    雙CMOS調(diào)制器AD7724的技術(shù)解析與應(yīng)用指南 在電子設(shè)計領(lǐng)域,模數(shù)轉(zhuǎn)換器(ADC)是至關(guān)重要的組件,它能將模擬信號轉(zhuǎn)換為數(shù)字信號,廣泛應(yīng)用于各種測量和控制系統(tǒng)。AD7724作為一款雙CMOS
    的頭像 發(fā)表于 04-07 11:45 ?204次閱讀

    軟國際聯(lián)合華為發(fā)布多個解決方案

    3月20日,在華為中國合作伙伴大會2026華為ICT解決方案伙伴峰會中,軟國際憑借在智慧園區(qū)領(lǐng)域的卓越創(chuàng)新與實踐成果,榮獲"聯(lián)合方案孵化獎",同時獲頒"優(yōu)選級ICT服務(wù)解決方案伙伴"認(rèn)證。同期,在
    的頭像 發(fā)表于 03-24 10:57 ?326次閱讀

    深度協(xié)同創(chuàng)新:解析超聲切割領(lǐng)域的“聯(lián)合實驗室”合作模式

    在技術(shù)快速迭代的行業(yè),頭部企業(yè)為了保持領(lǐng)先優(yōu)勢,往往需要突破現(xiàn)有供應(yīng)鏈的技術(shù)邊界。當(dāng)產(chǎn)品創(chuàng)新觸及核心部件的性能天花板時,一種超越傳統(tǒng)買賣關(guān)系的深度協(xié)作模式變得至關(guān)重要。這種模式,通常被稱為“聯(lián)合
    的頭像 發(fā)表于 01-28 17:04 ?1090次閱讀
    深度協(xié)同創(chuàng)新:<b class='flag-5'>解析</b>超聲切割領(lǐng)域的“<b class='flag-5'>聯(lián)合</b>實驗室”合作模式

    一個經(jīng)典的結(jié)構(gòu)體和聯(lián)合體共用的實例

    Linux 可以 使用 sizeof 進行獲取,默認(rèn)為字節(jié)對齊的大小。 聯(lián)合聯(lián)合體的參數(shù)共享同一個內(nèi)存地址,所占的內(nèi)存大小完全是由聯(lián)合
    發(fā)表于 12-16 07:14

    Labview 解析dxf文件并顯示

    上一期開了一個帖子講Labview導(dǎo)入dxf文件,解析和顯示dxf文件,今天繼續(xù)繼續(xù)分享常用圖元的解析與顯示方法。 LINE :用文本方式打開dxf 文件,搜索出直線部分,并摘取,可以得到
    發(fā)表于 12-01 11:28

    Labview 解析dxf文件并顯示<一>

    的文本格式,可以參考下面地址里面的介紹,介紹了CAD里面遇到的各種圖形單元的文本編輯格式,我們以此來解析出圖形參數(shù),用該圖像參數(shù),咱們再將圖形繪制到XY Graph ,當(dāng)然也可以繪制圖像到IMG或者
    發(fā)表于 11-14 22:45

    vcs和vivado聯(lián)合仿真

    我們可能就需要用到vcs核vivado聯(lián)合仿真。 1.Vivdao仿真庫編譯 打開vivado軟件,點擊Tools–&gt;Compile Simulation Libraries
    發(fā)表于 10-24 07:28

    IMU+多相機高速聯(lián)合自動標(biāo)定方案

    隨著視覺慣性傳感器在自動駕駛、機器人、AR/VR 等領(lǐng)域規(guī)?;涞兀嘞鄼C+IMU 聯(lián)合標(biāo)定需求呈爆發(fā)式增長,多相機+IMU 聯(lián)合標(biāo)定領(lǐng)域尚屬空白。 感算商城聯(lián)合知名方案公司推出國內(nèi)首臺量產(chǎn)級
    發(fā)表于 10-23 14:04

    請問RT-Thread與stm32cubemx聯(lián)合開發(fā)的原理是什么?

    在使用RT-Thread與stm32cubemx聯(lián)合開發(fā)的原理是什么,cubemx在其中主要起到了哪些功能呢?
    發(fā)表于 10-11 15:49

    SMT與DIP在PCBA加工的關(guān)鍵差異解析

    一站式PCBA加工廠家今天為大家講講PCBA加工如何選擇更適合的工藝?SMT與DIP在PCBA加工的差異解析。在PCBA(印制電路板組裝)加工,SMT(表面貼裝技術(shù))與DIP(雙列直插式封裝技術(shù)
    的頭像 發(fā)表于 10-07 10:35 ?1093次閱讀

    AT組件無法正確解析bin文件怎么解決?

    通過ESP32接受網(wǎng)絡(luò)數(shù)據(jù),然后寫入MCU,但是發(fā)現(xiàn)在解析bin文件的時候,會自動添加字符。應(yīng)該是換行符號的解析出現(xiàn)了問題。有什么好辦法嗎?
    發(fā)表于 09-28 08:36

    軟國際攜手華為發(fā)布醫(yī)藥聯(lián)合解決方案

    近日,在華為全聯(lián)接大會2025“智慧園區(qū)與智算圓桌”活動上,軟國際華為技術(shù)與解決方案集團模型工場業(yè)務(wù)部總裁張偉受邀出席。會上,在華為智算服務(wù)聯(lián)合方案發(fā)布環(huán)節(jié),軟國際攜手華為IT咨詢與系統(tǒng)集成部共同發(fā)布基于ModelMate的
    的頭像 發(fā)表于 09-19 14:16 ?1137次閱讀

    mqtt dns解析失敗是為什么?

    解析域名的ip地址就能正常連上,而直接解析域名就不行,為什么呢
    發(fā)表于 09-16 06:38

    用于各種設(shè)備協(xié)議間做報文轉(zhuǎn)換的網(wǎng)關(guān)是什么

    用于各種設(shè)備協(xié)議間做報文轉(zhuǎn)換的網(wǎng)關(guān)通常被稱為協(xié)議轉(zhuǎn)換網(wǎng)關(guān),也常被稱為工業(yè)協(xié)議網(wǎng)關(guān)(在工業(yè)場景)或多協(xié)議網(wǎng)關(guān)。它是一種專門用于解決不同設(shè)備、系統(tǒng)或網(wǎng)絡(luò)之間因協(xié)議不兼容而無法直接通信的中間設(shè)備,核心
    的頭像 發(fā)表于 08-11 14:08 ?1241次閱讀
    用于<b class='flag-5'>各種</b>設(shè)備協(xié)議間做報文轉(zhuǎn)換的網(wǎng)關(guān)是什么

    國際汽車聯(lián)合會一行到訪汽中心

    2025年6月3日,國際汽車聯(lián)合會首席發(fā)展官哈比布·圖爾基一行到訪汽中心,與汽中心副總經(jīng)理龔進峰進行了座談交流。
    的頭像 發(fā)表于 06-09 16:20 ?1099次閱讀
    上蔡县| 建水县| 阳新县| 凌海市| 离岛区| 徐水县| 朝阳市| 阿巴嘎旗| 敦化市| 邳州市| 东兴市| 耒阳市| 富平县| 富顺县| 汶上县| 饶阳县| 德兴市| 丹凤县| 开封市| 福海县| 登封市| 花莲县| 双鸭山市| 剑川县| 武安市| 新绛县| 如皋市| 南雄市| 尉犁县| 高碑店市| 德清县| 东阿县| 开化县| 高安市| 忻城县| 西安市| 上蔡县| 车致| 九龙坡区| 宁明县| 霸州市|