集成电路技术分享

 找回密码
 我要注册

QQ登录

只需一步,快速开始

搜索
查看: 429|回复: 1

Verilog中clk为什么要用posedge,而不用negedge

[复制链接]
dameihuaxia 发表于 2022-8-31 14:52:49 | 显示全部楼层 |阅读模式
posedge是上升沿,电平从低到高跳变
negedge是下降沿,电平从高到低跳变
对于典型的counter逻辑

always @(posedge sys_clk or negedge sys_rst_n) begin
        if(!sys_rst_n)
                counter <= 24'd0;        //十进制0
        else if(counter < led_time) begin
                flag_counter = 1'b0;
                counter <= counter + 1'b1;
        end
        else begin
                counter <= 24'd0;
                flag_counter = 1'b1;
        end
end
clk为什么要用posedge,而不用negedge呢?

查了很多网页,发现源头解释为以下内容:

一般情况下,系统中统一用posedge,避免用negedge,降低设计的复杂度,可以减少出错。
在ModelSim仿真中,时钟是很严格的,但是在真实的晶振所产生的clock却是不严格的,比如高电平和低电平的时间跨度不一样,甚至非周期性的微小波动。如果只使用posedge,则整个系统的节拍都按照clock上升沿对齐,如果用到了negedge,则系统的节拍没有统一到一个点上。上升沿到上升沿肯定是一个时钟周期,但是上升沿到下降沿却很可能不是半个周期。这都会出现问题。
FPGA特有的东西:Global CLK。FPGA内部有专门的CLK“线”,和一般的逻辑门的走法不一样,目的是为了保证整个FPGA片内的时钟一致,这个东西就叫Global CLK





————————————————
版权声明:本文为CSDN博主「小默haa」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/Xiaomo_haa/article/details/104188681
嘿哈嘿哈哈 发表于 2022-9-3 09:07:48 | 显示全部楼层
Verilog中clk为什么要用posedge,而不用negedge
您需要登录后才可以回帖 登录 | 我要注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

QQ|小黑屋|手机版|Archiver|fpga论坛|fpga设计论坛 ( 京ICP备20003123号-1 )

GMT+8, 2025-6-9 02:48 , Processed in 0.061045 second(s), 19 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表