OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 9529|回复: 5

[ALTERA] 代码出现时序违规,怎么解决?

[复制链接]

52

主题

147

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
316
金钱
316
注册时间
2019-4-1
在线时间
118 小时
发表于 2021-2-27 17:55:20 | 显示全部楼层 |阅读模式
1金钱
工程中使用了乘除法计算,
cnt<=cnt*1015/12300;


编译时,提示setup slack时序违规,如下:
Info (332146): Worst-case setup slack is -51.577
    Info (332119):     Slack       End Point TNS Clock
    Info (332119): ========= =================== =====================
    Info (332119):   -51.577            -375.434 FPGA_CLK

我的晶振是50MHz的,时钟时序约束是
create_clock -name "FPGA_CLK" -period 20.000ns [get_ports {FPGA_CLK}] -waveform {0.000 10.000}


请问应该怎样解决这个问题?谢谢指教!


最佳答案

查看完整内容[请看2#楼]

那个是非阻塞赋值!
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

97

帖子

0

精华

高级会员

Rank: 4

积分
669
金钱
669
注册时间
2015-5-23
在线时间
128 小时
发表于 2021-2-27 17:55:21 | 显示全部楼层
聚东风 发表于 2021-3-1 11:19
你那小于号是要干吗?
如果是判断的话,这个不是恒不成立吗?

那个是非阻塞赋值!
回复

使用道具 举报

3

主题

1979

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
5520
金钱
5520
注册时间
2018-10-21
在线时间
1561 小时
发表于 2021-3-1 09:17:08 | 显示全部楼层
可以把乘和除分成两个时钟周期,分别计算下试试
回复

使用道具 举报

80

主题

931

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3337
金钱
3337
注册时间
2013-5-28
在线时间
467 小时
发表于 2021-3-1 11:19:26 | 显示全部楼层
你那小于号是要干吗?
如果是判断的话,这个不是恒不成立吗?
回复

使用道具 举报

80

主题

931

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3337
金钱
3337
注册时间
2013-5-28
在线时间
467 小时
发表于 2021-3-2 08:05:34 | 显示全部楼层
denike 发表于 2021-3-1 16:21
那个是非阻塞赋值!

呃,受教,原来又跑错了,哈哈,应该多学点了
回复

使用道具 举报

52

主题

147

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
316
金钱
316
注册时间
2019-4-1
在线时间
118 小时
 楼主| 发表于 2021-3-2 21:44:00 来自手机 | 显示全部楼层
QinQZ 发表于 2021-3-1 09:17
可以把乘和除分成两个时钟周期,分别计算下试试

分成两个时钟周期可以减少违规时序的数值。除了这个还有没别的方法?例如有些运算不好拆分开来
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-10-3 18:18

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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