在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 10912|回复: 13

[求助] 异步时钟域的TIG约束问题

[复制链接]
发表于 2013-1-25 01:40:20 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
spartan6,ise14.2。两异步时钟域一个快时钟域,一个慢时钟域,因能保证慢时钟域采样数据是快时钟域的数据肯定保持稳定,则 HDL直接描述:
      ...
  slow_d<=fast_d;   // 注:slow_d寄存器 在慢时钟域读写,fast_d 在快时钟域写,此条语句把逻辑运算后的结果传到慢时钟域的寄存器

在UCF里加上如下约束:
NET "u1/slow_d*" TNM = "sl";
NET "u2/fast_d*" TNM = "fa";
TIMESPEC TS_fa_sl = FROM "fa" TO "sl" TIG;

此约束本意是想ise 分析时序时不用分析“ slow_d<=fast_d”路径的时序,但par时ise 居然分析了这条路径的时序并报错(不满足setup)。
请问这是啥原因,我ucf哪没写对?
发表于 2013-1-25 15:35:58 | 显示全部楼层
要不直接写成这样
INST "u2/fast_d*" TIG;

你写的方法更接近SDC的格式,如果用 synplify的话,直接在里面约束下?
define_false_path -FROM "fa" -TO "sl"
 楼主| 发表于 2013-1-25 17:52:11 | 显示全部楼层
直接 "INST "u2/fast_d*" TIG; "不行, 因为这样把快时钟域的 fast_d的路径也ignore了
发表于 2013-1-25 18:43:07 | 显示全部楼层
INST "u1/slow_d*" TNM = "sl";
INST "u2/fast_d*" TNM = "fa";
TIMESPEC TS_fa_sl = FROM "fa" TO "sl" TIG;
 楼主| 发表于 2013-1-26 13:13:55 | 显示全部楼层
都试过,加INST 和NET 是一样的,ISE都要分析这条路径
 楼主| 发表于 2013-1-29 17:45:51 | 显示全部楼层
期待解答
 楼主| 发表于 2013-1-30 11:13:05 | 显示全部楼层
谢谢
对,目的是的。
楼上的约束时钟方法是行的,但为啥直接约束数据寄存器不行想知道原因
发表于 2013-1-30 13:04:50 | 显示全部楼层
进来学习。

时钟约束不就是约束时钟么?还可以约束寄存器么?
发表于 2013-1-30 15:38:53 | 显示全部楼层
INST "/*/u1/slow_d*" TNM = "sl";
INST "/*/u2/fast_d*" TNM = "fa";
TIMESPEC TS_fa_sl = FROM "fa" TO "sl" TIG;
发表于 2013-7-12 10:05:34 | 显示全部楼层
回复 1# yangchao1t

最近也在搞类似的问题,请教下楼主。为什么要设置TIG啊,这样怎么保证慢时钟域正确可以采到快时钟域的数据呢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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


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

GMT+8, 2024-12-23 00:39 , Processed in 0.029703 second(s), 8 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表