码迷,mamicode.com
首页 > 其他好文 > 详细

verilog小感

时间:2014-12-16 18:25:30      阅读:171      评论:0      收藏:0      [点我收藏+]

标签:os   sp   数据   问题   log   bs   代码   nbsp   第一个   

今天同学给我说FIR滤波器的时序对不上,他说乘法器延迟太大,就用左移了,可是仿真时左移还是2周期才能移完,移位寄存器代码如下:

always @(posedge clk)

begin

     a   <= {in[8:0],0};

     out <= a;

end

 

    看见这段代码之后我立即认识到这是通过两个周期完成的事情,第一个周期中,虽然给a赋了值,可是,out获得的数据却是上一个周期的数据,那么归根结底,这是一个阻塞赋值与非阻塞赋值的问题。

    从这个问题中,我对阻塞与非阻塞有了更深层的看法了。其实就是在clk上升沿来临时,把数据当前的值全部lanch到了等号左边。

 

verilog小感

标签:os   sp   数据   问题   log   bs   代码   nbsp   第一个   

原文地址:http://www.cnblogs.com/blogernice/p/4167475.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!