全球最实用的IT互联网信息网站!

AI人工智能P2P分享&下载搜索网页发布信息网站地图

当前位置:诺佳网 > 电子/半导体 > 可编程逻辑 >

FPGA基础篇(一):阻塞与非阻塞赋值,不只是比原

时间:2017-09-19 18:32

人气:

作者:admin

标签:

导读:阻塞与非阻塞赋值 首先从名字上理解,阻塞赋值即赋值没完成,后边的语句将无法执行,非阻塞刚好与其相反,即赋值完不完成并不阻碍后续程序的执行,所以我们常说非阻塞赋值的对...

阻塞与非阻塞赋值

首先从名字上理解,阻塞赋值即赋值没完成,后边的语句将无法执行,非阻塞刚好与其相反,即赋值完不完成并不阻碍后续程序的执行,所以我们常说非阻塞赋值的对象并未立马得到新值,如果从时序来看,被赋值对象会比赋值对象差一个周期。

有了上述理解之后,我们就很容易明白为什么阻塞赋值的对象会立即发生改变,在中我们多接触到的是时序电路,并不希望被赋值对象立即改变,所以有对于组合电路而言,常用阻塞赋值,时序电路常用非阻塞赋值。

先看一个大家都熟悉的例子:

先看非阻塞代码:

01.png

clk为主时钟分频之后的时钟,clk先赋值给a,然后a在赋值给b,看一看生成的电路图

02.png

可以看出是两个触发器,而且前一个触发器的输出是后一个触发器的输入,再来看看阻塞的

03.png

04.png

由于完全为组合电路并未有触发器产生,从结果来看两种的区别

05.png

相信大家能够很容易看出哪个是阻塞的,哪个是非阻塞的,从非阻塞的时序来看,a比clk延迟了一个主时钟,b比a又延迟了一个主时钟,这不是我想说的重点,我想让大家看看a和b是什么时候开始发生变化的,教材上一直说是当整个进程结束时,a和b的值才发生更新,试问你知道什么时候进程结束么?从仿真结果来看,还不如理解为,在每个时钟的上升沿到来时a,b的值立即改变,只不过比原始差一个时钟周期。

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信