Verilog语法+:和-:有什么用?

embedded/2024/10/9 3:03:42/

Verilog语法+:和-:主要用于位选择,可以让代码更简洁。

一、位选择基础

在Verilog中,位选择可以通过直接索引来实现,例如:

reg [7:0] data;

wire select_a;

wire [2:0] select_b;

 

assign select_a = data[3];

assign select_b = data[2:0];

二、+: 和 -: 语法的基本概念

在 Verilog 语法中,“+:”和“-:”主要用于进行位选择操作,它们允许我们基于一个基址动态地选择一段连续的位。

其语法形式为: 

reg(base_expr+:width_expr)  

或 reg(base_expr-:width_expr) 。

其中base_expr  表示基址, width_expr  表示位宽。

注意:基址base_expr  可以是变量,但位宽  width_expr  必须是常量。

1、+: 操作符

用于从基址开始,向上(即向更高位)选择指定宽度的位。

reg [7:0] data;
wire [3:0] select;
assign select = data[4+:4];

//等效于assign select = data[7:4];

2、-: 操作符

用于从基址开始,向下(即向更低位)选择指定宽度的位。

reg [7:0] data;
wire [3:0] select;
assign select = data[7-:4];

//等效于assign select = data[7:4];

三、大端序和小端序下的差异

1、大端序(高位在前)

在大端序模式下,位向量的高位在左边,低位在右边,这是我们常用的方式。

例如, reg[15:0] big_value。

big_value[0+:8] 等价于  big_value[7:0] 。

2、小端序(低位在前)

与大端序相反,小端序模式下低位在左边,高位在右边。

例如  reg [0:31] little_value

little_value[0+:8] 等价于  little_value[0:7]
little_value[7-:8]  等价于  little_value[0:7])

640?wx_fmt=jpeg

如果需要更多学习资料和源码,想要学习FPGA实战入门进阶,请阅读下面这篇文章:
 

FPGA入门真的难吗?少走弯路,少踩坑。


http://www.ppmy.cn/embedded/108483.html

相关文章

探讨IP查询技术在金融行业的深度应用

随着互联网技术的飞速发展,金融行业对信息技术的依赖程度日益加深。其中,IP查询技术作为网络安全与风控的重要工具,在金融行业中的应用日益广泛且深入。本文将从多个角度探讨IP查询技术在金融行业间的应用及其重要性。 一、网络安全与监管 在…

K8s中如何使用etcd进行集群信息的备份与恢复

这里写目录标题 ETCD是什么?1. **`etcd`(服务)**2. **`etcdctl`(客户端工具)**如何安装etcdctl(客户端工具)查看目前K8s自带etcd中的版本信息安装对应版本的etcdutl工具下载 `etcdutl` 3.5.7 版本配置环境变量创建备份文件验证一下备份的快照文件备份文件恢复的效果演示…

致远个性化之--发起流程页面,去掉【查看流程】按钮

需求 近期在做的项目中,遇到一个需求,想把发起流程页面中的【查看流程】按钮去掉,只让员工预测流程,知道自己的事项流程走向,不让看全局流程图。包含PC端和移动端,以及微协同端。 如下图效果示例&#xff1…

DFS 算法:洛谷B3625迷宫寻路

我的个人主页 {\large \mathsf{{\color{Red} 我的个人主页} } } 我的个人主页 往 {\color{Red} {\Huge 往} } 往 期 {\color{Green} {\Huge 期} } 期 文 {\color{Blue} {\Huge 文} } 文 章 {\color{Orange} {\Huge 章}} 章 DFS 算法:记忆化搜索DFS 算法&#xf…

VUE 同域 接口请求报302

最近开发项目过程中遇到一个困扰几天的问题,本地运行VUE前端项目,同时连接到本地后端服务,接口出现302,直接重定向到/login接口,十分诡异。 于是乎进行各种搜索研判处理,找到以下相关相同案例,此…

MacOS升级ruby版本

在 Mac 系统中,升级 Ruby 版本是一项重要且有时必要的操作。首先,特定的项目可能对 Ruby 版本有严格的要求。例如,某些新的框架或库可能需要较高版本的 Ruby 才能正常运行和发挥最佳性能。如果我们使用的是较旧的 Ruby 版本,可能会…

android 媒体文件显示时间不对,date_added和date_modified分别代表什么含义。

图片文件对应数据库字段如下: 812 db.execSQL("CREATE TABLE files (_id INTEGER PRIMARY KEY AUTOINCREMENT," 813 "_data TEXT UNIQUE COLLATE NOCASE,_size INTEGER,format INTEGER,parent INTEGER," 814 …

tabBar设置底部菜单选项以及iconfont图标

tabBartabBar属性:设置底部 tab 的表现 ​ ​ ​ ​ 首先在pages.json页面写一个tabBar对象,里面放入list对象数组,里面至少要有2个、最多5个 tab, 如果只有一个tab的话,H5(浏览器)依然可以显示底部有一个导航栏,如果没有,需要重启后才有,小程序则报错,只有2个以上才可以…