Verilog中的wire和reg有什么区别

news2024/11/18 18:12:34

大多数初学者还没有真正很难掌握Verilog/SystemVerilog硬件描述语言(HDL)中wire(网络)和reg(变量)的区别。这个概念是每个经验丰富的RTL设计都应该熟悉的。但是现在有许多没有Verilog开发经验的验证工程师都在为他们的验证平台选择SystemVerilog。

验证方法往往专注于验证平台设计的面向对象的编程方面,但很少涉及这个wire和reg的区别,认为它适用于设计。这是不正确的。

如果你需要与DUT通信,那么你就需要了解wire和reg(网络和变量)之间的区别。

任何设计或验证芯片的人都应该具备一些基本的verilog开发技能,并了解wire和reg的概念。你需要获取的关键概念是,你将一个值写入一个变量,该值被保存到该变量的下一次赋值。这个概念被称为过程赋值,是执行代码语句的一部分。HDL可能会在赋值和其他语句之间添加一些时间的概念。

组合逻辑时序逻辑
reg a,b,c;
always @(b or c)
begin
a = b | c;
end
reg a,b,c;
always @(posedge c)
begin
a = a + b;
end

最初,Verilog使用关键字reg来声明表示时序逻辑硬件寄存器。后来,综合工具开始使用reg来表示时序逻辑以及组合逻辑,如上实例所示。所以,最终Verilog文档被更改为说reg只是用于声明变量的,而不仅仅是时序逻辑。

SystemVerilog重命名了reg 为logic,以避免与寄存器混淆——它只是一个数据类型(具体来说是1位,4状态数据类型)。从现在开始,忘掉它,仅使用logic。

HDL的另一个显著特点是,它对大量并行过程进行建模。在数字设计的最低水平上,每个逻辑(AND,OR,DFF)都是一个独立的并发过程。module是代表在不同抽象级别建模的进程的容器,并且通过wire相互传递值。在Verilog中,wire声明表示连接的网络。每个并发进程的输出都驱动一个网络,这被称为连续赋值,因为该进程不断更新它想要在网络上驱动的值。声明连续赋值的方法多种多样,所有这些方法都代表连续赋值行为:

wire A, B, C;
assign A = B| C; // continuous assignment construct.
or(A,B,C); // gate-level instance terminal connection
mymodule m1(A,B,C); // module instance port connection

423dc2fd3f1c0f97a0603cac9bc9b4ce.jpeg

虽然这些都是不同形式的连续赋值结构,但它们都没有像过程赋值那样直接向网络赋值。所有同时驱动到网络上的值会根据驱动强度抉择出最终结果。例如,中断请求信号可能会使用线或(wor)类型的网络来指示至少有一个设备正在驱动为“1”,否则它将解析为“0”。一些信号将具有较弱的上拉/下拉电阻,这些电阻将被更强驱动器的值覆盖。大多数技术不允许在同一网络上驱动不同的值,当这种情况发生时,网络将解析为未知的“x”态。在这种情况下,只有一个驱动程序主动赋值“0”或“1”,而其他驱动程序则通过驱动高阻抗或“z”状态关闭。其结果是,双向端口必须使用wite进行建模,才能在端口两侧有多个驱动器。

86ddb23cfc9a2677f5281e05b3b67783.jpeg

事实证明,设计中的绝大多数网络都只有一个驱动器,因此不需要强度信息。SystemVerilog添加了一项logic类型,仅允许单个连续赋值来驱动变量。每当表达式更改其值时,驱动连续赋值的表达式都会分配给变量。一旦有多个驱动或需要强度信息,必须重新使用wire

不能将过程和连续赋值混合到同一变量。这种限制的原因是,无法确定最后一次变量更新什么时候完成,过程赋值还是连续赋值。

总之,现在应该使用4个状态变量logic(或2个状态变量的bit)的逻辑来表示所有单个驱动器的信号。任何具有多个或可能存在多个驱动的信号都应声明为wire。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1882080.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

mybatis延迟加载

mybatis延迟加载 1、延迟加载概述 应用场景 ​ 如果查询订单并且关联查询用户信息。如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息。把对用户信息的按需去查询就是延迟加载。 延迟加载的好处 ​ 先从单表查询、需要时再从关联表去关联查…

最短路模型——AcWing 188. 武士风度的牛

最短路模型 定义 最短路模型是图论中的一个经典问题,旨在寻找从图中一个顶点到另一个顶点的路径,使得这条路径上的边(或边的权重)之和最小。这一模型在许多实际问题中有着广泛的应用,比如网络路由、地图导航、物流配…

音频转文字怎么转?4个音频转文字的方法一定要知道

随着夏日脚步的到来,各类活动和准备工作也随之增多。 在这样一个忙碌的时期,整理会议的音频记录变得尤为关键。然而,单单依靠手动整理,不仅耗时耗力,还可能出现错漏。 但也不用太着急,下面将为大家介绍几…

生产者发送数据,kafka服务器接收数据异常的问题记录

现象: 某个客户要求审计日志用kafka的方式传输给他们,使用了第三方的librdkafka库来开发。 往客户提供的kafka服务器上的一个topic发送数据,这个topic有三个分区,客户反馈接收到的数据和发送端发送的实际数量对不上,他…

韩顺平0基础学java——第34天

p675-689 UDP网络编程 1.类 DatagramSocket和 DatagramPacket[数据包/数据报]实现了基于UDP协议网络程序。 2.UDP数据报通过数据报套接字DatagramSocket发送和接收,系统不保证UDP数据报一定能够安全送到目的地,也不能确定什么时候可以抵达。 3.DatagramPacket对象…

python-docx 设置水印字体

本文目录 前言一、水印的XML在哪里1、Word内置水印设置2、自定义XML部件3、Header or Footer二、确认位置三、水印表前解释1、水印XML源代码2、水印结构解析3、关于style的详解三、修改水印样式前言 本文我们来完成一个有趣的玩意儿:在Python中通过操作Word文档的XML来设置整…

MeterSphere v3.0全新启航,让软件测试工作更简单、更高效

2024年7月1日,MeterSphere v3.0版本正式发布。MeterSphere v3.0是新一代的测试管理和接口测试工具,致力于让软件测试工作更简单、更高效,不再成为持续交付的瓶颈。 在团队协作方面,针对目前企业软件测试团队所面临的测试工具不统…

【SpringBoot3学习 | 第2篇】SpringBoot3整合+SpringBoot3项目打包运行

文章目录 一. SpringBoot3 整合 SpringMVC1.1 配置静态资源位置1.2 自定义拦截器(SpringMVC配置) 二. SpringBoot3 整合 Druid 数据源三. SpringBoot3 整合 Mybatis3.1 Mybatis整合3.2 声明式事务整合配置3.3 AOP整合配置 四. SpringBoot3 项目打包和运行…

ROS学习笔记(17):建图与定位(1)

目录 0.前言 1.定位和建图 1.里程计(Odometry) 2.扫描匹配(Scan Matching) 3.结尾 0.前言 好久不见各位,前段时间忙着考试(6级和一些专业课)和摆烂断更了近30天,现在哥们回来更…

LaMa Image Inpainting 图像修复 OnnxRuntime-GPU版 Demo

目录 介绍 效果 模型信息 项目 代码 下载 LaMa Image Inpainting 图像修复 OnnxRuntime-GPU版 Demo 介绍 gihub地址:GitHub - advimman/lama: 🦙 LaMa Image Inpainting, Resolution-robust Large Mask Inpainting with Fourier Convolutions, …

昇思25天学习打卡营第八天|保存与加载

背景 提供免费算力支持,有交流群有值班教师答疑的华为昇思训练营进入第八天了。 今天是第八天,前七天的学习内容可以看链接 昇思25天学习打卡营第一天|快速入门 昇思25天学习打卡营第二天|张量 Tensor 昇思25天学习打卡营第三天|数据集Dataset 昇思25天…

Python对象不可哈希?教你几招解决!

目录 1、什么是可哈希?🚀 1.1 哈希基础理论 1.2 可哈希对象定义🔍 示例代码: 1.3 Python中哈希的作用 1.4 哈希表与性能提升📈 应用实例代码: 2、Python中的哈希特性🔑 2.1 不变性与哈希值🔄 示例代码展示: 2.2 实现细节深入探讨📚 深入代码细节:…

深度学习论文: VanillaNet: the Power of Minimalism in Deep Learning

深度学习论文: VanillaNet: the Power of Minimalism in Deep Learning VanillaNet: the Power of Minimalism in Deep Learning PDF:https://arxiv.org/pdf/2305.12972 PyTorch: https://github.com/shanglianlm0525/PyTorch-Networks 1 概述 提出的VanillaNet通过简化设计&…

【机器学习】Python sorted 函数

目录: 什么是sorted()函数列表降序排序应用到字符串自定义排序规则实际应用 Python中的内置函数——sorted()。 1. 什么是sorted()函数 在Python中,sorted()是一个内置函数,用于对任何可迭代对象(如列表、元组、字符串等&…

绿联NAS进入SSH的方法

1. 进入【设备管理】,在调试功能中,开启远程调试功能,发送手机验证码,你将得到一个3天有效期的验证码,就是ssh登录密码。 2. 使用终端工具或ssh命令直接登录SSH。 端口是922,账号是:root&#…

七月论文审稿GPT第5版:拿我司七月的早期paper-7方面review数据集微调LLama 3

前言 llama 3出来后,为了通过paper-review的数据集微调3,有以下各种方式 不用任何框架 工具 技术,直接微调原生的llama 3,毕竟也有8k长度了 效果不期望有多高,纯作为baseline通过PI,把llama 3的8K长度扩展…

李沐深度学习知识点—数值稳定性、模型激活函数、全连接层到卷积、卷积层

数值稳定性 其中h是一个向量,向量关于向量的倒数是一个矩阵,因此求梯度是求矩阵乘法 矩阵乘法带来了 梯度爆炸,梯度消失 模型初始化和激活函数 归一化:不管梯度多大,我都把梯度拉回来,否的出现梯度爆炸和梯…

【基础篇】第4章 Elasticsearch 查询与过滤

在Elasticsearch的世界里,高效地从海量数据中检索出所需信息是其核心价值所在。本章将深入解析查询与过滤的机制,从基础查询到复合查询,再到全文搜索与分析器的定制,为你揭开数据检索的神秘面纱。 4.1 基本查询 4.1.1 Match查询…

内容个性化的智能引擎:Kompas.ai如何满足用户需求

在数字化时代,用户对内容的消费趋向个性化和定制化。个性化内容不仅能提升用户体验,还能增强品牌与用户之间的互动。Kompas.ai作为一款先进的智能引擎,正通过其独特的技术满足用户的个性化需求。 个性化内容的重要性 个性化内容在提升用户体验…

2024 vue3入门教程:01vscode终端命令创建第一个vue项目

参考vue官网手册:https://cn.vuejs.org/guide/quick-start.html 一、找个盘符,新建文件夹存储以后得vue项目 我的是e盘下创建了vueproject 二、使用vscode打开存储vue项目的文件夹 因为我生成过项目,所以有文件,你们初次是没有…