搜索
bottom↓
回复: 179

有限解答C/C++/Xilinx方面的较难问题, 欢迎提问

  [复制链接]

出0入8汤圆

发表于 2020-3-22 10:23:21 | 显示全部楼层
问一个跨时钟域的问题,下面这个跨时钟域的代码能不能可靠工作,将A时钟的flag同步到B时钟
前提条件:
1. clkA和clkB时钟频率差在50%以内。即A为100MHz,那么 50MHz <  B <150Mhz
2. flagA出现频率不会超过 FclkA/4。即flagA最多4个clkA出现一次
3. flagA只会保持1个时钟周期
4. syncB尽量不要扩展为3位,减少延时
module crossflag(
    input clkA,
    input flagA,
    input clkB,
    output flagB
    );
reg toggle = 0;
always @(posedge clkA) toggle <= toggle ^ flagA;
reg [1:0] syncB = 0;
always @(posedge clkB) syncB <= {syncB[0], toggle};
assign flagB = (syncB[1] ^ syncB[0]);
endmodule

出0入8汤圆

发表于 2020-3-22 11:35:45 来自手机 | 显示全部楼层
get500wan 发表于 2020-3-22 10:47
不能吧,flagA最短只有一个clka时钟,clkb又比clka慢,看不到toggle的脉冲吧。


toggle只在flagA上升沿变化,频率最高FclkA/4,这个是低于clkB的
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-29 13:21

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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