集成电路技术分享

 找回密码
 我要注册

QQ登录

只需一步,快速开始

搜索
查看: 1507|回复: 3

请教一个时钟问题(多时钟?)

[复制链接]
vvt 发表于 2011-4-8 05:48:15 | 显示全部楼层 |阅读模式
请教一个时钟问题(多时钟?)
 楼主| vvt 发表于 2011-4-8 05:48:27 | 显示全部楼层
应该是属于多时钟问题吧,不知道大家是怎么处理的,我的设计经验太少了,请点拔一下。
我的一个模块中是个是高速的主时钟mclk(50M),一个是低速的同步时钟sclk(10K),也就是每来一个sclk的上升沿后,进行相应的处理。
process(mclk,reset)
begin
  if(reset……)then
  elsif(mclk'event and mclk='1')then
  ?????
下面怎么捕捉sclk沿?以前是捕捉sclk的电平变化,
用if((sclktmp xor sclk) = '1')then sclktmp <= sclk; 来做的,觉得没有捕捉上升沿好。请给点建议,呵呵
 楼主| vvt 发表于 2011-4-8 05:48:40 | 显示全部楼层
always@(posedge mclk or negedge rstb) begin
  if(rstb) begin
    sclk_sync1 <= 1'b0;
    sclk_sync2 <= 1'b0;
    sclk_sync3 <= 1'b0;
  end
  else begin
    sclk_sync1 <= sclk;
    sclk_sync2 <= sclk_sync1;
    sclk_sycn3 <= sclk_sync2;
  end
end

assign posedge_sclk = sclk_sync2 & ~sclk_sync3;
 楼主| vvt 发表于 2011-4-8 05:48:56 | 显示全部楼层
为避免Flip-flop出现亚稳态
异步信号需要用时钟double-sync以后才能使用
所以判断一个异步信号的沿需要三个Flip-flop
您需要登录后才可以回帖 登录 | 我要注册

本版积分规则

关闭

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

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

GMT+8, 2025-6-22 21:03 , Processed in 0.063689 second(s), 19 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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