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

    文章

    1672

    浏览量

    51895
  • Vivado
    +关注

    关注

    19

    文章

    860

    浏览量

    71388
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    双CMOS调制器AD7724的技术解析与应用指南

    双CMOS调制器AD7724的技术解析与应用指南 在电子设计领域,模数转换器(ADC)是至关重要的组件,它能将模拟信号转换为数字信号,广泛应用于各种测量和控制系统。AD7724作为一款双CMOS
    的头像 发表于 04-07 11:45 164次阅读

    软国际联合华为发布多个解决方案

    3月20日,在华为中国合作伙伴大会2026华为ICT解决方案伙伴峰会中,软国际凭借在智慧园区领域的卓越创新与实践成果,荣获"联合方案孵化奖",同时获颁"优选级ICT服务解决方案伙伴"认证。同期,在
    的头像 发表于 03-24 10:57 285次阅读

    深度协同创新:解析超声切割领域的“联合实验室”合作模式

    在技术快速迭代的行业,头部企业为了保持领先优势,往往需要突破现有供应链的技术边界。当产品创新触及核心部件的性能天花板时,一种超越传统买卖关系的深度协作模式变得至关重要。这种模式,通常被称为“联合
    的头像 发表于 01-28 17:04 1057次阅读
    深度协同创新:<b class='flag-5'>解析</b>超声切割领域的“<b class='flag-5'>联合</b>实验室”合作模式

    一个经典的结构体和联合体共用的实例

    Linux 可以 使用 sizeof 进行获取,默认为字节对齐的大小。 联合联合体的参数共享同一个内存地址,所占的内存大小完全是由联合
    发表于 12-16 07:14

    Labview 解析dxf文件并显示

    上一期开了一个帖子讲Labview导入dxf文件,解析和显示dxf文件,今天继续继续分享常用图元的解析与显示方法。 LINE :用文本方式打开dxf 文件,搜索出直线部分,并摘取,可以得到
    发表于 12-01 11:28

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

    的文本格式,可以参考下面地址里面的介绍,介绍了CAD里面遇到的各种图形单元的文本编辑格式,我们以此来解析出图形参数,用该图像参数,咱们再将图形绘制到XY Graph ,当然也可以绘制图像到IMG或者
    发表于 11-14 22:45

    vcs和vivado联合仿真

    我们可能就需要用到vcs核vivado联合仿真。 1.Vivdao仿真库编译 打开vivado软件,点击Tools–&gt;Compile Simulation Libraries
    发表于 10-24 07:28

    IMU+多相机高速联合自动标定方案

    随着视觉惯性传感器在自动驾驶、机器人、AR/VR 等领域规模化落地,多相机+IMU 联合标定需求呈爆发式增长,多相机+IMU 联合标定领域尚属空白。 感算商城联合知名方案公司推出国内首台量产级
    发表于 10-23 14:04

    请问RT-Thread与stm32cubemx联合开发的原理是什么?

    在使用RT-Thread与stm32cubemx联合开发的原理是什么,cubemx在其中主要起到了哪些功能呢?
    发表于 10-11 15:49

    SMT与DIP在PCBA加工的关键差异解析

    一站式PCBA加工厂家今天为大家讲讲PCBA加工如何选择更适合的工艺?SMT与DIP在PCBA加工的差异解析。在PCBA(印制电路板组装)加工,SMT(表面贴装技术)与DIP(双列直插式封装技术
    的头像 发表于 10-07 10:35 1043次阅读

    AT组件无法正确解析bin文件怎么解决?

    通过ESP32接受网络数据,然后写入MCU,但是发现在解析bin文件的时候,会自动添加字符。应该是换行符号的解析出现了问题。有什么好办法吗?
    发表于 09-28 08:36

    软国际携手华为发布医药联合解决方案

    近日,在华为全联接大会2025“智慧园区与智算圆桌”活动上,软国际华为技术与解决方案集团模型工场业务部总裁张伟受邀出席。会上,在华为智算服务联合方案发布环节,软国际携手华为IT咨询与系统集成部共同发布基于ModelMate的
    的头像 发表于 09-19 14:16 1098次阅读

    mqtt dns解析失败是为什么?

    解析域名的ip地址就能正常连上,而直接解析域名就不行,为什么呢
    发表于 09-16 06:38

    用于各种设备协议间做报文转换的网关是什么

    用于各种设备协议间做报文转换的网关通常被称为协议转换网关,也常被称为工业协议网关(在工业场景)或多协议网关。它是一种专门用于解决不同设备、系统或网络之间因协议不兼容而无法直接通信的中间设备,核心
    的头像 发表于 08-11 14:08 1189次阅读
    用于<b class='flag-5'>各种</b>设备协议间做报文转换的网关是什么

    国际汽车联合会一行到访汽中心

    2025年6月3日,国际汽车联合会首席发展官哈比布·图尔基一行到访汽中心,与汽中心副总经理龚进峰进行了座谈交流。
    的头像 发表于 06-09 16:20 1072次阅读