数据流建模使用的连续赋值语句由关键词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 = -17%-2=+18%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)对于==!=,会逐位比较两个操作数相应位的值是否相等,如果都相等则相等关系成立,如果有一位是xz,那么结果为x

(2)而===!==,允许操作数某些位为xz,例如:

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数据流建模与运算符的更多相关文章

  1. 【转】Verilog HDL常用建模方式——《Verilog与数字ASIC设计基础》读书笔记(四)

    Verilog HDL常用建模方式——<Verilog与数字ASIC设计基础>读书笔记(四) Verilog HDL的基本功能之一是描述可综合的硬件逻辑电路.所谓综合(Synthesis) ...

  2. 自己动手写处理器之第二阶段(2)——Verilog HDL简单介绍

    将陆续上传本人写的新书<自己动手写处理器>(尚未出版),今天是第六篇.我尽量每周四篇 2.3 Verilog HDL简单介绍 本书实现的OpenMIPS处理器是使用Verilog HDL编 ...

  3. 【黑金教程笔记之003】【建模篇】akuei2的Verilog hdl心路

    Verilog hdl不是“编程”是“建模” Verilog hdl语言是一种富有“形状”的语言. 如果着手以“建模”去理解Verilog hdl语言,以“形状”去完成Verilog hdl语言的设计 ...

  4. Verilog的数据流、行为、结构化与RTL级描述

    Verilog语言可以有多种方式来描述硬件,同时,使用这些描述方式,又可以在多个抽象层次上设计硬件,这是Verilog语言的重要特征. 在Verilog语言中,有以下3种最基本的描述方式: 数据流描述 ...

  5. Verilog HDL程序设计——基本要素

    Verilog基本上熟悉了,继续整理一下Verilog的学习笔记吧.前面记载了Verilog的结构,写Verilog的结构有了,但是该怎么写呢?在写之前就得了解一下Verilog的一些基本要素了,也就 ...

  6. 关于初次使用Verilog HDL语言需要懂的基本语法

    关于初次使用Verilog HDL语言需要懂的基本语法 1.常量 数字表达式全面的描述方式为:<位宽><进制><数字> 8’b10101100,表示位宽为8的二进制 ...

  7. 关于Verilog HDL的一些技巧、易错、易忘点(不定期更新)

    本文记录一些关于Verilog HDL的一些技巧.易错.易忘点等(主要是语法上),一方面是方便自己忘记语法时进行查阅翻看,另一方面是分享给大家,如果有错的话,希望大家能够评论指出. 关键词: ·技巧篇 ...

  8. Verilog HDL的程序结构及其描述

    这篇博文是写给要入门Verilog HDL及其初学者的,也算是我对Verilog  HDL学习的一个总结,主要是Verilog HDL的程序结构及其描述,如果有错,欢迎评论指出. 一.Verilog ...

  9. Verilog HDL数组(存储器)操作

    本文从本人的163博客搬迁至此. 引用了http://blog.sina.com.cn/s/blog_9424755f0101rhrh.html Verilog HDL中常采用数组方式来对存储器进行建 ...

  10. 基于Verilog HDL整数乘法器设计与仿真验证

    基于Verilog HDL整数乘法器设计与仿真验证 1.预备知识 整数分为短整数,中整数,长整数,本文只涉及到短整数.短整数:占用一个字节空间,8位,其中最高位为符号位(最高位为1表示为负数,最高位为 ...

随机推荐

  1. 使用 python 快速搭建http服务

    python -m SimpleHTTPServer 8888 使用上面的命令可以把当前目录发布到8888端口. 直接浏览器访问 但是这条命令是当前运行的,不是后台运行的,也就是说如果Ctrl + C ...

  2. HTML5CSS3提高

    1 HTML5新特性 1.1 概述 HTML5 的新增特性主要是针对于以前的不足,增加了一些新的标签.新的表单和新的表单属性等. 这些新特性都有兼容性问题,基本是 IE9+ 以上版本的浏览器才支持,如 ...

  3. Ubuntu安装后续工作

    更新源: sudo gedit /etc/apt/sources.list 清华的源 deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu/ xenial ma ...

  4. 原神盲盒风格:AI绘画Stable Diffusion原神人物公仔实操:核心tag+lora模型汇总

    本教程收集于:AIGC从入门到精通教程汇总 在这篇文章中,我们将深入探讨原神盲盒的艺术风格,以及如何运用AI绘画技术(Stable Diffusion)--来创造原神角色公仔.我们将通过实践操作让读者 ...

  5. Go 上下文的理解与使用

    为什么需要 context 在 Go 程序中,特别是并发情况下,由于超时.取消等而引发的异常操作,往往需要及时的释放相应资源,正确的关闭 goroutine.防止协程不退出而导致内存泄露.如果没有 c ...

  6. Eclipse修改Web项目名称

    Eclipse修改Web项目名称需要两步: 1:修改该项目目录下:.project文件 <projectDescription><name>SpringMVC-Annotati ...

  7. PHP判断是否是微信打开, 浏览器打开

    #问题 项目中遇到的问题, 如果用户是使用微信访问的. 那么进行友好提示"如何使用浏览器打开/告诉用户使用浏览器打开" 方案 useragent是浏览器标识, 带有一些客户信息. ...

  8. [htmlayout] csss! 改变值/文本

    <input type="text" value="123" /> <div class="test">内容内容&l ...

  9. python一键过杀软

    python过杀软新 利用python加载shellcode过360.火绒等杀软 先上代码 将以下代码保存到 mt.py import base64 import os import shutil b ...

  10. OGG-Postgres实时同步到Kafka

    (一)数据同步信息 名称 源端 名称 目标端 数据库类型 Postgresql 12.4 组件类型 Kafka IP地址 20.2.127.23 Broker地址 20.2.125.52:9092, ...