首页 > 代码库 > verilog小感
verilog小感
今天同学给我说FIR滤波器的时序对不上,他说乘法器延迟太大,就用左移了,可是仿真时左移还是2周期才能移完,移位寄存器代码如下:
always @(posedge clk)
begin
a <= {in[8:0],0};
out <= a;
end
看见这段代码之后我立即认识到这是通过两个周期完成的事情,第一个周期中,虽然给a赋了值,可是,out获得的数据却是上一个周期的数据,那么归根结底,这是一个阻塞赋值与非阻塞赋值的问题。
从这个问题中,我对阻塞与非阻塞有了更深层的看法了。其实就是在clk上升沿来临时,把数据当前的值全部lanch到了等号左边。
verilog小感
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。