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

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

数字硬件建模SystemVerilog-结构体

OpenFPGA 来源:OpenFPGA 作者:OpenFPGA 2022-06-30 09:54 次阅读

数字硬件建模SystemVerilog-结构体(二)

ad48a850-f80c-11ec-ba43-dac502259ad0.png

结构体

结构体用于将多个变量组合在一个通用名称下。设计通常具有逻辑信号组,例如总线协议的控制信号,或状态控制器内使用的信号。结构体提供了将这些相关变量捆绑在一起的方法。结构体中的所有变量都可以单个赋值,或者每个变量都可以单独赋值。结构体包可以复制到具有相同定义的另一个结构体,并通过模块端口、任务或函数进出。

结构体复制

一个自定义结构体可以复制到另一个自定义结构体,只要这两个结构体是从同一个自定义结构体定义声明的。以下示例使用了上节中所示的结构体定义和声明。

匿名结构体不能作为一个整体复制,但可以一次复制一个成员:

ad5d799c-f80c-11ec-ba43-dac502259ad0.png

压缩和非压缩结构体

默认情况下,结构体会被非压缩的。这意味着结构体的成员被视为独立变量或常量,并以一个共同的名称分组在一起。SystemVerilog没有指定软件工具应该如何存储非压缩结构体的成员。不同的软件工具具对于结构体的存储分布也是不同的。

通过使用关键字packed,将结构体显式声明为压缩结构体。

ad70cfc4-f80c-11ec-ba43-dac502259ad0.png

压缩结构体以与向量相同的形式将结构体的所有成员存储为连续位。结构体的第一个成员是向量最左边的字段。结构体中最后一个成员的最右边的位是向量的最低有效位,编号为位0。如图4-2所示。

ad8710c2-f80c-11ec-ba43-dac502259ad0.png

图4-2:压缩结构体存储为向量

压缩结构体的所有成员都必须是整数值。整数值是可以表示为向量的值,例如byte、int和使用bit或logic类型创建的向量。如果结构体的任何成员不能表示为向量,则该结构体不能被压缩。这意味着压缩结构体不能包含实数或短实数变量、非压缩结构体、非压缩联合体体或非压缩的数组。

引用压缩结构体和结构体成员。压缩结构体可以复制,或分配一个结构体表达式值列表,方法与非压缩结构体相同。压缩结构体的成员可以通过成员名称引用,方式与非压缩结构体相同。

压缩结构体也可以被视为一个向量。因此,除了结构体分配,向量值还可以分配给压缩结构体

ad9eaf84-f80c-11ec-ba43-dac502259ad0.png

向量赋值是合法的,因为赋值左边的结构体成员已压缩在一起,形成一组连续的位,方式与向量相同。因为压缩结构体存储为一组连续的位,所以对压缩结构体执行向量操作也是合法的,包括位选择和部分选择。以下两个赋值都将分配给data_word的tag成员:

adb4bff4-f80c-11ec-ba43-dac502259ad0.png

可以在向量上执行的数学运算、逻辑运算和任何其他运算也可以在压缩结构体上执行。

有符号压缩结构体。压缩结构体可以用signed和unsigned关键字声明。当在运算或关系运算中用作向量时,这些修饰符会影响整个结构体的识别方式。它们不会影响结构体成员的识别方式。结构体的每个成员都被视为有符号或无符号,这取决于该成员的类型声明。压缩结构体的部分选择是无符号的,与向量的部分选择相同。

adcd0686-f80c-11ec-ba43-dac502259ad0.png

通过端口传递结构体

自定义结构体可以通过模块和接口的端口传递,结构体必须首先使用 typedef 定义为用户自定义数据类型,然后才允许将模块或接口的端口声明为结构体类型。

ade708c4-f80c-11ec-ba43-dac502259ad0.png

非压缩的结构体必须是自定义结构体,才能通过端口传递该结构体。与端口的连接必须是与端口类型完全相同的结构体。也就是说,端口和端口两侧的连接都必须从相同的typedef定义声明。此限制仅适用于非压缩结构体。通过模块端口的压缩结构体被视为向量。端口的外部连接可以是相同类型的压缩结构体,也可以是任何类型的向量。

通过将任务或函数参数声明为结构体类型,自定义结构体也可以作为参数传递给任务或函数。

adfc7dbc-f80c-11ec-ba43-dac502259ad0.png

当调用一个任务或函数时,如果该任务或函数有一个非压缩的结构体作为正式参数菜单,则必须将一个完全相同类型的结构体传递给该任务或函数。压缩结构体形式参数被视为向量,可以传递给任何类型的向量。

传统的Verilog与结构体

最初的Verilog语言没有一种方便的机制来将常见信号收集到一个组中。在传统的Verilog样式的模型中,工程师必须使用特殊的分组方法,例如命名约定,其中一组中的每个信号都以一组公共字符开始或结束。最初的Verilog语言也无法通过模块端口或任务和函数传递信号集合,每个信号都必须通过单独的端口或参数传递。

在原始Verilog语言中添加结构体是一种强大的RTL建模构造,反之亦然。它提供了一种更简洁、更直观、更可重用的复杂模型功能建模方法。包中定义的自定义结构体可以在多个模块中重复使用,也可以在用于验证RTL模型的验证测试台中重复使用。

综合指导

非压缩结构体和压缩结构体都是可综合的。综合工具支持结构体通过模块端口传递 , 也支持作为输入或输出传递给任务和函数 , 也支持使用成员名和值的列表对结构体进行赋值。

综合编译器可能比压缩结构体更好地优化非压缩结构体。非压缩结构体允许软件工具确定存储或实现每个结构体成员的最佳方式,而压缩结构体则决定如何组织每个成员。

ae189c40-f80c-11ec-ba43-dac502259ad0.jpg

审核编辑 :李倩

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

    关注

    0

    文章

    613

    浏览量

    28558
  • 控制信号
    +关注

    关注

    0

    文章

    169

    浏览量

    12081
  • 结构体
    +关注

    关注

    1

    文章

    130

    浏览量

    10906

原文标题:SystemVerilog-结构体(二)

文章出处:【微信号:Open_FPGA,微信公众号:OpenFPGA】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    相关推荐

    VirtualLab Fusion应用:用于抑制高衍射级次的角滤波光栅

    ,以抑制不需要的高衍射阶数。为此,首先分析了光栅的角度灵敏度。 最后,通过使用 VirtualLab Fusion 进行仿真,显示了对不期望的高衍射级次的抑制效果。 建模任务 volume
    发表于 12-09 12:51

    结构成员的顺序会影响结构的大小吗

    相同的结构成员,如果把顺序调整一下,会不会影响结构的大小? 答案是会的,这主要跟字节对齐有关。 比如这样的结构
    的头像 发表于 11-25 16:24 316次阅读

    C语言和C++中结构的区别

    同样是结构,看看在C语言和C++中有什么区别?
    的头像 发表于 10-30 15:11 419次阅读

    使用C2000 MCU对用于数字控制的双向降压/升压转换器进行建模

    电子发烧友网站提供《使用C2000 MCU对用于数字控制的双向降压/升压转换器进行建模.pdf》资料免费下载
    发表于 10-12 11:48 0次下载
    使用C2000 MCU对用于<b class='flag-5'>数字</b>控制的双向降压/升压转换器进行<b class='flag-5'>建模</b>

    ota升级的库中,结构upgrade_server_info中pespconn的作用是什么?

    check_cb; struct espconn *pespconn; }; 这个结构中已经有ip,port,pespconn这个结构
    发表于 07-12 06:33

    请问esp-idf&amp;vscode结构索引不到对应的成员如何解决?

    兄弟们,我用VSCode 初始化结构时,索引不到对应的成员,并且索引会出现不属于结构体内的东西,有解决办法吗,球球了
    发表于 06-14 06:42

    隧道BIM如何设计和建模

    、协作工作、优化设计,并最大程度地提高项目效率和质量。下面是关于如何设计和建模隧道BIM的详细内容: 1.数据采集与建模需求确定:在设计之初,需要收集并整合地形、地质、气象等方面的数据,并确定设计需求和目标。这些数据将为后续BIM建模
    的头像 发表于 06-04 15:54 503次阅读

    你是否真的了解结构占用了多少字节?

    结构成员所占内存空间大小一般情况下,如果想知道结构成员的内存占用情况需要:1、先用结构在内
    的头像 发表于 06-04 08:04 637次阅读
    你是否真的了解<b class='flag-5'>结构</b><b class='flag-5'>体</b>占用了多少字节?

    硬件特殊功能寄存器编程思路和RAM使用的问题求解?

    看了一下STM32的库,对于其中的关于硬件的特殊功能寄存器的设置都是通过:1、定义一个和实际硬件地址相镜像的全局结构变量。 2、设置结构
    发表于 05-17 12:24

    泰来三维|三维扫描服务_三维激光扫描仪测量山体滑坡点云建模

    点云建模是将测量得到的点云数据进行拟合、优化与处理,生成真实的三维模型的过程。它能够全面、准确地显示被扫描的外形与内部结构,从而在山体滑坡地质灾害的防治中发挥着重要作用。 在山体滑坡地质灾害防治
    的头像 发表于 05-15 16:32 360次阅读
    泰来三维|三维扫描服务_三维激光扫描仪测量山体滑坡点云<b class='flag-5'>建模</b>

    数字源表的基本原理与结构组成

    在电子测试与测量领域,数字源表(Digital SourceMeter)作为一种集电源、测量和分析功能于一的精密仪器,发挥着至关重要的作用。其高精度、高稳定性和可编程性等特点,使得数字源表在半导体
    的头像 发表于 05-15 15:48 1343次阅读

    嵌入式中C语言结构基本实现

    C语言中的数组只能允许程序员定义存储相同类型数据。但是结构是C语言编程中允许您存储不同数据类型的数据。 结构的定义     要想定义结构,必须用到 struct 关键字,struct
    的头像 发表于 05-11 08:49 1182次阅读
    嵌入式中C语言<b class='flag-5'>结构</b><b class='flag-5'>体</b>基本实现

    智慧城市电网的新选择:讯维数字孪生可视化系统优化电力网络

    可视化系统利用先进的三维扫描和建模技术,可以实现对城市电网的高精度数字建模。这种模型不仅包含了电网的物理结构,还集成了电网的运行数据、设备状态等信息,形成了电网的
    的头像 发表于 05-07 16:46 479次阅读

    C语言结构史上最详细的讲解【软件干货】

    struct结构数据类型 前言 我们知道,在C语言中有一些基本的数据类型,如 char int float long double string(c99) 等等数据类型,他们可以表示一些事物
    的头像 发表于 03-28 17:52 929次阅读

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

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