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

    文章

    1624

    浏览量

    49112
  • Vivado
    +关注

    关注

    19

    文章

    812

    浏览量

    66482
收藏 人收藏

    评论

    相关推荐

    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 1132次阅读
    IEC101、IEC103、IEC104、Modbus报文<b class='flag-5'>解析</b>工具

    SoC布局各种IC简介

    。SoC各种IP简介IP核(IntellectualPropertyCore),即知识产权核,在集成电路设计行业中指已验证、可重复利用、具有某种确定功能的芯片设
    的头像 发表于 07-17 08:28 368次阅读
    SoC布局<b class='flag-5'>中</b><b class='flag-5'>各种</b>IC简介

    工程安全监测的振弦采集仪威廉希尔官方网站 解析与应用

    工程安全监测的振弦采集仪威廉希尔官方网站 解析与应用 河北稳控科技振弦采集仪是一种在工程安全监测中广泛使用的仪器,用于测量和监测结构的振动和应变。它通过采集结构的振弦信号,可以提供详细的结构运行状态和变化情况
    的头像 发表于 07-11 10:19 325次阅读
    工程安全监测<b class='flag-5'>中</b>的振弦采集仪威廉希尔官方网站
<b class='flag-5'>解析</b>与应用

    PLC基本结构解析

    方式和便捷的编程方式,被广泛应用于各种工业控制系统。本文将详细解析PLC的基本结构,包括其主要组成部分的功能和特点,以便读者对PLC有更深入的了解。
    的头像 发表于 06-25 14:30 944次阅读

    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 3326次阅读

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

    2024年3月初,在美国硅谷举办的DVCon2024上,IEEE-SA和Accellera联合宣布通过IEEE Get Program可以免费获取IEEE 1800-2023 SystemVerilog语言参考手册。
    的头像 发表于 03-20 13:52 1716次阅读

    请问Systemverilog如何使用VHDL的package?

    现在需要使用system verilog写代码,但是想复用之前VHDL的package,里面有写的现成的function等,请问如何调用呢。总是报错说找不到_pkg
    发表于 03-12 15:37

    在Vivado Synthesis怎么使用SystemVerilog接口连接逻辑呢?

    SystemVerilog 接口的开发旨在让设计中层级之间的连接变得更加轻松容易。 您可以把这类接口看作是多个模块共有的引脚集合。
    的头像 发表于 03-04 15:25 955次阅读
    在Vivado Synthesis<b class='flag-5'>中</b>怎么使用<b class='flag-5'>SystemVerilog</b>接口连接逻辑呢?

    XML在HarmonyOS的生成,解析与转换(下)

    一、XML 解析 对于以 XML 作为载体传递的数据,实际使用需要对相关的节点进行解析,一般包括解析 XML 标签和标签值、解析 XML
    的头像 发表于 02-18 10:07 736次阅读

    美国JDAM联合制导攻击武器威廉希尔官方网站 解析与实战应用

    联合制导攻击武器一般由Mk-82(500磅)、Mk-83(1000磅)和Mk-84(2000磅)四种规格的常规炸弹改装而成,改装后分别编号为GBU-38、GBU-32和GBU-31。其中GBU-32和GBU-31为专用侵彻型炸弹,可用于打击地堡和坚固目标。
    发表于 01-19 10:32 1643次阅读
    美国JDAM<b class='flag-5'>联合</b>制导攻击武器威廉希尔官方网站
<b class='flag-5'>解析</b>与实战应用