0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取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;
复制代码

以上代码创建了一种新类型,名为“union_type”。

此类型的位宽为 4 位,可作为“a”或“b”来引用。

此外,代码最后一行创建了一个新信号,名称为“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
复制代码

同上,首先对联合体进行声明,并创建类型为“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 位。

为此创建的结构体如下所示:

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;
复制代码

这样即可创建如下所示结构:

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;
复制代码

以上示例将创建一个含两个字段的联合体。其中一个字段为位宽 8 位的矢量“b1”,另一个字段为位宽 5 位的结构体,此结构体由一个位宽 4 位的矢量 a1 和一个位宽 1 位的矢量 a2 组成。 此联合体将作为位宽 8 位的矢量来创建,如下所示:

Xilinx SystemVerilog中的基本联合体

图 6:含结构体的解包联合体

同上,由于联合体中包含结构体,因此需按如下方式来引用信号:

always@(posedge clk) begin
my_union.b1 out1 out2 end
复制代码

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Xilinx
    +关注

    关注

    71

    文章

    2153

    浏览量

    120796
  • 代码
    +关注

    关注

    30

    文章

    4708

    浏览量

    68176
  • 编译器
    +关注

    关注

    1

    文章

    1614

    浏览量

    49002
收藏 人收藏

    评论

    相关推荐

    苏州市人工智能语言计算创新联合体活动圆满举办

    活动伊始,园区企业发展服务中心副主任吴小庆与思必驰副总裁李春梅共同为“益企家”企业服务联络站——人工智能语言计算创新联合体站揭牌。截至目前,园区企服中心已设立20家联络站。未来,联络站将深度赋能联合体成员单位企业,为企业提供“全方位”、“零距离”的服务,助力产业高质量发展
    的头像 发表于 10-14 14:08 204次阅读

    澎峰科技受聘为“主权级大模型”创新联合体学术委员会委员

    日前,“主权级大模型“创新联合体揭牌,澎峰科技CEO受聘为”主权级大模型“创新联合体学术委员会委员。
    的头像 发表于 09-02 17:37 710次阅读

    长沙角逐算力江湖,长沙市新一代智算产业生态联合体成立

    算力正成为数字时代经济发展的新引擎。为大力发展相关产业,8月28日,长沙市新一代智算产业生态联合体正式成立,新一代智算产业生态联合体集聚了北京大学长沙计算与数字经济研究院、湖南大学、华为技术有限公司
    的头像 发表于 08-30 11:14 485次阅读

    摩尔线程加入商飞智能“工业元宇宙创新联合体

    6月18日,商飞智能技术有限公司携手摩尔线程智能科技(北京)有限责任公司、北京蔚领时代科技有限公司、北京智谱华章科技有限公司、厦门雅基软件有限公司在张江人工智能岛签署合作协议,共创工业元宇宙创新联合体。作为联合体成员的唯一国产
    的头像 发表于 06-20 10:09 566次阅读

    智芯公司入选MEMS器件可靠性试验创新联合体首批成员单位

    近日,MEMS器件可靠性试验创新联合体(以下简称“联合体”)成立大会在京召开,智芯公司、北京大学、清华大学、哈工大、北航、中科院微电子所、中科院空天研究院、电科三十八所等23家单位入选联合体
    的头像 发表于 05-15 18:45 687次阅读
    智芯公司入选MEMS器件可靠性试验创新<b class='flag-5'>联合体</b>首批成员单位

    芯原科技牵头的RISC-V创新联合体获正式认定授牌

    在近日以“临港科创 新质未来”为主题的2024临港科创大会上,芯原科技牵头组建的RISC-V创新联合体正式获得认定授牌。这一创新联合体是由芯原科技联合芯来科技等10家上下游企业及3所高校共同发起,展现了多维度、多层次、多元化的合
    的头像 发表于 03-28 09:19 436次阅读

    天津车联网技术创新联合体,正式成立!

    3月22日,天津经纬恒润有限公司携手12家京津冀三地优质企业及高校共同成立的车联网技术创新联合体举行揭牌仪式。大会介绍了各成员单位的业务情况、研发计划和2024年度联合体的整体工作计划,为联合体
    的头像 发表于 03-26 10:00 493次阅读
    天津车联网技术创新<b class='flag-5'>联合体</b>,正式成立!

    天津经纬携优质企业及高校成立的车联网技术创新联合体举行揭牌仪式

    3月22日,天津经纬恒润有限公司携手12家京津冀三地优质企业及高校共同成立的车联网技术创新联合体举行揭牌仪式。
    的头像 发表于 03-25 10:22 448次阅读
    天津经纬携优质企业及高校成立的车联网技术创新<b class='flag-5'>联合体</b>举行揭牌仪式

    华为联合24家企事业单位发起“大模型应用产业联合体

    华为联合24家企事业单位发起“大模型应用产业联合体” 据央视《新闻联播》报道 日前,华为联合智谱AI、医渡科技、百川智能、中国科学院自动化研究所、软国际、首都在线、第四范式、格灵深瞳
    的头像 发表于 03-02 15:55 1249次阅读

    北京24家企事业单位组建&quot;大模型应用产业联合体&quot; 

    据悉,此联合体旨在利用华为鲲鹏硬件底座与软件底层资源,推动人工智能产业生态合作,确立相关行业标准,并实现人工智能产业的快速升级。
    的头像 发表于 03-01 14:44 686次阅读

    思必驰入选“2023年度江苏省创新联合体建设试点”名单

    近日,江苏省科技厅公布了2023年度江苏省创新联合体拟建设试点名单,其中,由思必驰科技股份有限公司(以下简称:思必驰)牵头组建的江苏省人工智能语言计算创新联合体成功入选,也是全省5家省创新联合体建设试点之一。
    的头像 发表于 01-22 13:47 761次阅读

    经典 C 语言编程,结构体和联合体如何共用?

    可以 使用 sizeof 进行获取,默认为字节对齐的大小。 联合体 联合体的参数共享同一个内存地址,所占的内存大小完全是由联合体参数类
    的头像 发表于 01-11 18:24 1215次阅读
    经典 C 语言编程,结构体和<b class='flag-5'>联合体</b>如何共用?

    优必选科技参与成立“人形机器人创新发展联合体

    在2023年的一场足式、人形机器人生态峰会上,一个名为“移动机器人产业联盟人形机器人创新发展联合体”的全新组织正式亮相。作为人形机器人行业的佼佼者,优必选科技不仅积极参与,更是与其他11家在人形机器人产业链上具有代表性的企业共同发起了这一联合体
    的头像 发表于 12-29 15:03 722次阅读

    【喜讯】芯盾时代当选“北京市高级别自动驾驶示范区智能网联汽车市域产教联合体”理事单位

    近日,北京市高级别自动驾驶示范区智能网联汽车市域产教联合体(以下简称“产教联合体”)成立大会在北京经开区举行,由66家政产学研单位共同组成的产教融合平台正式成立。芯盾时代作为产教联合体
    的头像 发表于 12-22 14:40 385次阅读
    【喜讯】芯盾时代当选“北京市高级别自动驾驶示范区智能网联汽车市域产教<b class='flag-5'>联合体</b>”理事单位

    科沃斯组建的苏州市机器人前沿智能技术创新联合体成功获批

    近日,苏州市科技局公示了2023年度第二批(总第四批)苏州市创新联合体立项名单,由科沃斯机器人股份有限公司牵头组建的苏州市机器人前沿智能技术创新联合体成功获批。
    的头像 发表于 11-28 09:28 1321次阅读