3743|1

6892

帖子

0

TA的资源

五彩晶圆(高级)

楼主
 

关于关于多时钟模块中复位同步器的问题 [复制链接]

异步复位中,典型的复位形式如下面代码所示:
always @ (posedge clk or negedge rst)
    begin ....  end
在这种复位模式下,一般而言是要加入一个synchronizer,代码如下所示:
reg syn_rst, rff1;
always @ (posedge CLK or negedge RESET)
    if (!RESET) {syn_rst, rff1} <= 2'b0;
    else {syn_rst, rff1} <= {rff1, 1'b1};
加入这个synchronizer的目的,是为了避免带复位端口的触发器出现recovery/removal的violation,从而引发的亚稳态的问题。
那如果我这个module有两个时钟输入端口,对于每个时钟端口插入一个synchronizer,然后这两个synchronizer共用一个从 reset端口引入的reset信号,这两个时钟端口对应的时钟周期不妨称为clk1和clk2。那么插入的两个synchronizer的输出的复位信号相比较于从模块的reset端口引入的复位信号就要分别延迟上两个clk1和clk2的周期,由于clk1和clk2的周期和相位的不同,就导致这两个时钟域对应的触发器的完成复位的时间不同,这在我做的这个项目中应该是不允许的。在这种情况下,该如何去处理reset信号呢?
表达的比较冗长,有劳指正。
此帖出自FPGA/CPLD论坛

最新回复

应该用高速时钟的时钟信号去同步复位信号,并且用高速时钟去同步低速时钟。  详情 回复 发表于 2010-8-2 10:25
点赞 关注
个人签名一个为理想不懈前进的人,一个永不言败人!
http://shop57496282.taobao.com/
欢迎光临网上店铺!
 

回复
举报

569

帖子

0

TA的资源

一粒金砂(高级)

沙发
 

应该用高速时钟的时钟信号去同步复位信号,并且用高速时钟去同步低速时钟。

此帖出自FPGA/CPLD论坛
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表