ljc24156313的个人空间 https://blog.eetop.cn/848177 [收藏] [复制] [分享] [RSS]

空间首页 动态 记录 日志 相册 主题 分享 留言板 个人资料

日志

多路时钟选择设计

已有 1547 次阅读| 2013-8-2 09:53 |个人分类:clock design

好好 的采集流程,突然时序就不对了,并且烧入 .sof 和 .jic 的现象还不一样。想了想,可能是多路时钟选择的问题,自己写的代码不能做到 glitch-free clock multiplexer。

问题描述:
程序中需要转换 50MHz 和16MHz 时钟,我直接用一个信号来控制两个时钟的切换,而
这个信号是被 8MHz 时钟同步的。结果就悲剧了。

解决方法:
一、使用器件内建 多路时钟选择器。
xilinx 器件中提供了 BUFGMUX,altera 中Cyclone II 以上提供 ALTCLKCTRL。两者都是 glitch-free clock multiplexer。
【参见 Ensure glitch-free switchover implementation

二、自己设计多路时钟选择器
很不幸,我用的是 Cyclone,木有 ALTCLKCTRL。
法一:
先使用三态 TRI 单元,控制时钟的输出,然后再让时钟通过一般的 MUX,这样子的话,次序应该是首先把原来的时钟通过三态电路Disable掉,然后打开另外一个三态电路,输出时钟,同时,Mux 根据控制信号选择新的时钟。
【参见 Alter FPGA 与 Xilinx FPGA 的优缺点比较
法二:
更为具体的做法,我准备尝试。但是难点在于:时钟要经过多路时钟选择器,而该时钟域的使能、地址和数据信号也要分别经过多路选择器,那么如何让经过多路选择器后的时钟、使能、地址和数据信号依然保持同步是一个问题。
这个还需要请教高人
【参见 Techniques to make clock switching glitch free


点赞

评论 (0 个评论)

facelist

您需要登录后才可以评论 登录 | 注册

  • 关注TA
  • 加好友
  • 联系TA
  • 0

    周排名
  • 0

    月排名
  • 0

    总排名
  • 0

    关注
  • 1

    粉丝
  • 0

    好友
  • 0

    获赞
  • 1

    评论
  • 764

    访问数
关闭

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

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-5-21 02:06 , Processed in 0.027720 second(s), 16 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
返回顶部