Verilog HDL数据流建模与运算符
数据流建模使用的连续赋值语句由关键词assign
开始,一般用法如下:
wire [位宽说明]变量名1, 变量名2, ..., 变量名n;
assign 变量名 = 表达式;
只要等号右边的值发生变化,则立即更新等号左边的值。
注意,连续赋值语句只能对wire
型变量进行赋值,所以等号左边必须是wire
型。
把2线-4线译码器用数据流描述风格的代码写出来就是:
module Decoder2x4_gates(
input [1:0]A,
input En,
output [3:0]Y);
assign Y[0] = ~(~A[1] & ~A[0] & En);
assign Y[1] = ~(~A[1] & A[0] & En);
assign Y[2] = ~(A[1] & ~A[0] & En);
assign Y[3] = ~(A[1] & A[0] & En);
endmodule
然后就是介绍数据流风格中设计的运算符了。
1.算数运算符+ - * / %(取余) **(指数)
(1)进行算数运算符时,如果某个操作数中某一位是x
或者z
,那么整个表达式运算结果也是x
,例如`b101x + `b0111 = `bxxxx。
(2)取余后,余数的符号与第一个操作数的符号相同。例如:-7%2 = -1
,7%-2=+1
,8%4=0
。
2.关系运算符< > <= >=
(1)结果为真1或者假0。
(2)如果操作数中有一个为x
或者z
,那么结果为x
。
(3)两个有符号数进行比较时,如果操作数位宽不同,那么用符号位将位数较小操作数的位数补齐。例如:
4'sb1011 <= 8'sh1A //等价于8'sb1111_1011 <= 8'sh1A = 8'sb0001_1010,结果为1.
(4)如果表达式有一个操作数为无符号数,则该表达式的其余操作数均被当作无符号处理。例如:
(4'sd9 * 4'd2) < 4 //18 < 4, 结果为假0。
(4'sd9 * 2) < 4 //-7 * 2 < 4,结果为真1.
3.相等运算符==(逻辑相等), !=(逻辑不等), ===(条件全等), !==(条件不全等)
(1)对于==
和!=
,会逐位比较两个操作数相应位的值是否相等,如果都相等则相等关系成立,如果有一位是x
或z
,那么结果为x
。
(2)而===
和!==
,允许操作数某些位为x
或z
,例如:
0 === x为0
0 === z为0
1 === x为0
1 === z为0
x === x为0
x === z为0
z === z为0
z === x为0
4.逻辑运算符!, &&, ||
需要注意的是,如果操作数中有一位是x
或者z
,那么运算结果为x
,而仿真器一般将其作为假处理。其他都与C语言一样。
5.按位运算符~, &, |, ^, ^~(同或)
(1)如果两个操作数位宽不相等,仿真软件自动将短操作数的左端高位部分以0补足,如果最高位为x,那么补x。
(2)如果操作数中的某一位是x
或者z
,那么结果的那一位为x
。
6.缩位运算符&, ~&(缩位与非), |, ~|(缩位或非), ^, ^~
都只有一个操作数,操作数从右边位一次往左边每一位运算,例如reg [3:0]A
,那么运算规则为A[1]与A[0],然后这个结果再与A[2],然后再与A[3]运算,最后得到的结果为1位。
7.移位运算符<<(左移), >>(右移), <<<(算数左移), >>>(算数右移)
。
(1)逻辑移位,当移位后,所产生的空余位总是0填充。
(2)算数移位,向左移动时,空余位用0补充;向右移动时,如果是无符号数,那么用0补充,否则用符号位补充。
8.条件运算符,用法如下:
condition_expr ? true_expr : false_expr;
9.拼接和复制运算符
拼接运算符{}
,要求每个操作数必须有确定位宽。
reg A;
reg [1:0]B, C;
A=1'b1, B=2'b00, C=2'b10;
Y={B,C};
Y={A,B[0],C[1],1'b1};
Z={A,B,5}; //非法,5的位宽不确定。
如果需要多次拼接,直接再{}
前加一个数,就是拼接几次。
reg A;
reg [1:0]B, C;
A=1'b1, B=2'b00, C=2'b10;
Y={4{A}}; //把A复制4次
Y={2{A},2{B},C}; //把A复制2次,把B复制2次,然后与C拼接一起
重复的次数可以参数化,例如:
parameter LENGTH=8;
Y = {LENGTH{1'B0}};
10.运算符优先级
感觉没太有必要记,加括号就完事了。。。
Verilog HDL数据流建模与运算符的更多相关文章
- 【转】Verilog HDL常用建模方式——《Verilog与数字ASIC设计基础》读书笔记(四)
Verilog HDL常用建模方式——<Verilog与数字ASIC设计基础>读书笔记(四) Verilog HDL的基本功能之一是描述可综合的硬件逻辑电路.所谓综合(Synthesis) ...
- 自己动手写处理器之第二阶段(2)——Verilog HDL简单介绍
将陆续上传本人写的新书<自己动手写处理器>(尚未出版),今天是第六篇.我尽量每周四篇 2.3 Verilog HDL简单介绍 本书实现的OpenMIPS处理器是使用Verilog HDL编 ...
- 【黑金教程笔记之003】【建模篇】akuei2的Verilog hdl心路
Verilog hdl不是“编程”是“建模” Verilog hdl语言是一种富有“形状”的语言. 如果着手以“建模”去理解Verilog hdl语言,以“形状”去完成Verilog hdl语言的设计 ...
- Verilog的数据流、行为、结构化与RTL级描述
Verilog语言可以有多种方式来描述硬件,同时,使用这些描述方式,又可以在多个抽象层次上设计硬件,这是Verilog语言的重要特征. 在Verilog语言中,有以下3种最基本的描述方式: 数据流描述 ...
- Verilog HDL程序设计——基本要素
Verilog基本上熟悉了,继续整理一下Verilog的学习笔记吧.前面记载了Verilog的结构,写Verilog的结构有了,但是该怎么写呢?在写之前就得了解一下Verilog的一些基本要素了,也就 ...
- 关于初次使用Verilog HDL语言需要懂的基本语法
关于初次使用Verilog HDL语言需要懂的基本语法 1.常量 数字表达式全面的描述方式为:<位宽><进制><数字> 8’b10101100,表示位宽为8的二进制 ...
- 关于Verilog HDL的一些技巧、易错、易忘点(不定期更新)
本文记录一些关于Verilog HDL的一些技巧.易错.易忘点等(主要是语法上),一方面是方便自己忘记语法时进行查阅翻看,另一方面是分享给大家,如果有错的话,希望大家能够评论指出. 关键词: ·技巧篇 ...
- Verilog HDL的程序结构及其描述
这篇博文是写给要入门Verilog HDL及其初学者的,也算是我对Verilog HDL学习的一个总结,主要是Verilog HDL的程序结构及其描述,如果有错,欢迎评论指出. 一.Verilog ...
- Verilog HDL数组(存储器)操作
本文从本人的163博客搬迁至此. 引用了http://blog.sina.com.cn/s/blog_9424755f0101rhrh.html Verilog HDL中常采用数组方式来对存储器进行建 ...
- 基于Verilog HDL整数乘法器设计与仿真验证
基于Verilog HDL整数乘法器设计与仿真验证 1.预备知识 整数分为短整数,中整数,长整数,本文只涉及到短整数.短整数:占用一个字节空间,8位,其中最高位为符号位(最高位为1表示为负数,最高位为 ...
随机推荐
- 使用 python 快速搭建http服务
python -m SimpleHTTPServer 8888 使用上面的命令可以把当前目录发布到8888端口. 直接浏览器访问 但是这条命令是当前运行的,不是后台运行的,也就是说如果Ctrl + C ...
- HTML5CSS3提高
1 HTML5新特性 1.1 概述 HTML5 的新增特性主要是针对于以前的不足,增加了一些新的标签.新的表单和新的表单属性等. 这些新特性都有兼容性问题,基本是 IE9+ 以上版本的浏览器才支持,如 ...
- Ubuntu安装后续工作
更新源: sudo gedit /etc/apt/sources.list 清华的源 deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial ma ...
- 原神盲盒风格:AI绘画Stable Diffusion原神人物公仔实操:核心tag+lora模型汇总
本教程收集于:AIGC从入门到精通教程汇总 在这篇文章中,我们将深入探讨原神盲盒的艺术风格,以及如何运用AI绘画技术(Stable Diffusion)--来创造原神角色公仔.我们将通过实践操作让读者 ...
- Go 上下文的理解与使用
为什么需要 context 在 Go 程序中,特别是并发情况下,由于超时.取消等而引发的异常操作,往往需要及时的释放相应资源,正确的关闭 goroutine.防止协程不退出而导致内存泄露.如果没有 c ...
- Eclipse修改Web项目名称
Eclipse修改Web项目名称需要两步: 1:修改该项目目录下:.project文件 <projectDescription><name>SpringMVC-Annotati ...
- PHP判断是否是微信打开, 浏览器打开
#问题 项目中遇到的问题, 如果用户是使用微信访问的. 那么进行友好提示"如何使用浏览器打开/告诉用户使用浏览器打开" 方案 useragent是浏览器标识, 带有一些客户信息. ...
- [htmlayout] csss! 改变值/文本
<input type="text" value="123" /> <div class="test">内容内容&l ...
- python一键过杀软
python过杀软新 利用python加载shellcode过360.火绒等杀软 先上代码 将以下代码保存到 mt.py import base64 import os import shutil b ...
- OGG-Postgres实时同步到Kafka
(一)数据同步信息 名称 源端 名称 目标端 数据库类型 Postgresql 12.4 组件类型 Kafka IP地址 20.2.127.23 Broker地址 20.2.125.52:9092, ...