Verilog_Day2_Plus
内容为书中第4章
等式运算符
“==” 与 “===” 的区别
Verilog中存在4种等式运算符:
- == (等于);
- != (不等于);
- === (等于);
- !== (不等于)。
“==”与"==="的异同。
“==” 在操作数的某些位是不定值x或高阻值z时,结果可能为不定值;
“===”也对x和z进行比较,只有两个操作数完全一致时,输出1,否则输出0.
等式运算符的真值
| == | 0 | 1 | x | z |
| 0 | 1 | 0 | x | x |
| 1 | 0 | 1 | x | x |
| x | x | x | x | x |
| z | x | x | x | x |
| === | 0 | 1 | x | z |
| 0 | 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 | 0 |
| x | 0 | 0 | 1 | 0 |
| z | 0 | 0 | 0 | 1 |
在“===”表达式种,输出只可能是 1 或者 0 。在“==”表达式中,输出可能是 0、1或 x 中的一种。
使用移位运算符 “>>”和"<<"的一点注意事项
要注意移位前后变量的位数。
eg: (1) 4'b1001<<1 = 5'b10010 (2) 4'b1001<<2 = 6'b100100 (3) 1<<6 = 32'b1000000...
(4) 4’b1001>>1 = 4'b0100 (5) 4'b1001>>4 = 4'b0000
可以看出在右移过程中,会改变移位以后的值的位数。但是如果事先声明了存储值的变量的长度。则右移位后的位数仍然为声明的位数。如(3)中,由于系统默认32位。相当于预先声明数据长度是32位,则移位后仍然为32位。
位拼接运算符{}
位拼接运算符 “{}” 可以把两个或多个信号的某些位拼接起来进行位运算。
{信号1的某几位,信号2的某几位.....} eg: {a,b[3:0],w,3'b101} 也等于 {a,b[3],b[2],b[1],b[0],w,1'b1,1'b0,1'b1}
{4{w}} 等于 {w,w,w,w}
{b,{3{a,b}}} 等于 {b,a,b,a,b,a,b}
书中P22上方代码就运用了位拼接运算符。
缩减运算符
缩减运算的与、或、非计算是对单个操作数进行或、与、非递推运算。最后结果是1位的二进制数。
缩减运算的具体过程为:第一步先将操作数的第一位与第二位进行或、与、非运算;第二步将运算结果与第三位进行或、与、非运算,依次类推,直至最后1位。
reg [:] B;
reg C;
C=&B;
类似于:
C = ((B[]&B[])&B[])&B[];
问题1:在缩减运算符中,如何进行 非 的运算?
回答:

在缩减(归约)运算符中,只有上面的6种运算符,没有 ~ 运算符。书中有误。参考:(1)http://blog.sina.com.cn/s/blog_88c9ddc5010182mj.html
(2)http://forum.eepw.com.cn/thread/182573/1
赋值语句
非阻塞赋值(b<=a)
非阻塞赋值语句只有当块语句结束后才能完成这次赋值操作;在编写可综合的时序逻辑模块时,常用非阻塞赋值。
阻塞赋值(b=a)
赋值语句执行结束后,块采结束。
例子分析:
always @(posedge clk)
begin
b<=a;
c<=b;
end
在上面例子中使用了非阻塞赋值方法。那么当块语句块执行结束后,才会执行3,4行赋值代码。又因为verilog在块外是并行执行。所以最后结果是,把原来a的值赋给b,同时将原来b的值赋给c(因为并行执行,在将b的值赋给c时,b的值没有更新。)。
问题2:这里面的 “块”是指的begin-end块还是always块?
块语句
快语句有两种: 1:begin_end : 标识顺序执行语句; 2 :fork_join : 用来标识并行执行语句。
在begin-end语句块中,begin-end和fork-join块可以相互嵌套,也可以自我嵌套。如果begin-end中包含有局部声明,则他必须被命名(必须有一个标志)。如果要禁止一个begin-end块,那么被禁止(disasble语句)的begin-end必须有名字。
取块名: begin:块名 fork: 块名 注意:有冒号 :
在Veriloog语言中,所有的变量都是静态的,所有的变量都只有一个唯一的存储地址,因此进入或跳出块并不影响存储在变量内的值。
块名可以允许被其他的语句调用,也可以通过层次名进行调用; 问题2:块名的具体使用方法?,块的嵌套运行时间顺序?
Verilog_Day2_Plus的更多相关文章
随机推荐
- 手动搭建 redis 集群
转自http://meia.fun/article/1544161420745 手动搭建 redis 集群 redis 基本命令: 启动 redis 服务:redis-server xxx.conf ...
- springMVC入门-08
这一讲介绍用户登录实现以及两种异常处理controller控制器的方法,最后提一下在springMVC中对静态资源访问的实现方法. 用户登录需要一个登录页面login.jsp,对应代码如下所示: &l ...
- SQLServer SELECT @@IDENTITY 遇到的坑
经常在写存储过程的时候获取当前插入后的ID都会用 @@IDENTITY 但是今天在用 @@IDENTITY的时候涉及到当前数据的插入会有insert触发器发生时,发现与实际插入的ID值对不上,网上查 ...
- 转:C# 线程同步技术 Monitor 和Lock
原文地址:http://www.cnblogs.com/lxblog/archive/2013/03/07/2947182.html 今天我们总结一下 C#线程同步 中的 Monitor 类 和 Lo ...
- Centos7.3 坑爹网络配置
1.目的: 我想在Vmvare配置成NAT模式的上网,因为这个模式宿主机可以访问虚拟机,虚拟机也可以访问宿主机,但仅主机模式只能是宿主机能访问虚拟机,但虚拟机不能访问宿主机.所以我为了能在虚拟机里面上 ...
- 使用js插件进行设备检测
一.分析新浪网是怎么做的 如新浪网有两种版本,一种是pc版,存放在www.sina.com.cn这个服务器上:另外一种是手机版,存放在www.sina.cn这个服务器上 原理是当用户输入网址www ...
- 51nod 1444 破坏道路(bfs+枚举)
1444 破坏道路 题目来源: CodeForces 基准时间限制:1.5 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 收藏 关注 在某一个国家,那儿有n个城市,他们通过m条双向 ...
- 1068. [SCOI2007]压缩【区间DP】
Description 给一个由小写字母组成的字符串,我们可以用一种简单的方法来压缩其中的重复信息.压缩后的字符串除了小 写字母外还可以(但不必)包含大写字母R与M,其中M标记重复串的开始,R重复从上 ...
- 「GXOI / GZOI2019」旅行者
题目 我还是太傻了 考虑每一条边的贡献,对于一条有向边\((u,v,w)\),我们求出\(k\)个关键点中到\(u\)最近的距离\(dis_1\),以及\(v\)到\(k\)个关键点中最近的距离\(d ...
- Java并发编程--7.Java内存操作总结
主内存和工作内存 工作规则 Java内存模型, 定义变量的访问规则, 即将共享变量存储到内存和取出内存的底层细节 所有的变量都存储在主内存中,每条线程有自己的工作内存,工作内存中用到的变量, 是从主 ...