下列 时序检查语句 错误的是()
A. $setup(posedge clk, data, tSU)
B. $hold(posedge clk, data, tHLD)
C. $setuphold(posedge clk, data, tSU, tHLD)
答案:A
解析:
在时序检查函数中,$setup 函数比较特殊,格式是:
$setup(data_event, reference_event, limit);
其他常见的检查是:
$.。..。.(reference_event, data_event, limit);
假设信号名称为 data,时钟 clk 的上升沿触发 posedge clk,要求 setup 满足 tSU,则
$setup(data, posedge clk, tSU);
常用的时序检查语句
(1)setup 建立时间检查
$setup(data, posedge clk, tSU);
(2)hold 保持时间检查
$hold(posedge clk, data, tHLD);
(3)setuphold 建立/保持时间检查
$setuphold(posedge clk, data, tSU, tHLD);
(4)width 脉冲宽度检查
$width(posedge clk, 4);
(5)skew 时钟歪斜检查
$skew(posedge clk1, posedge clk2, 4);
(6)period 时钟周期检查
$period(posedge clk, 5);
(7)recovery 复位信号的恢复时间检查
$recovery(posedge rst, posedge clk, 3);
(8)removal 复位信号的移除时间检查
$removal(posedge rst, posedge clk, 3);
(9)recrem 复位信号的恢复/移除时间检查
$recrem(posedge rst, posedge clk, recovery_limit, removal_limit);
四个基础的时序分析
(1)对于时钟和数据信号,分析setup建立时间和hold保持时间
setup 建立时间:在有效的时钟沿来临前,数据需要保持稳定的最短时间,简写为Tsu;
hold 保持时间:在有效的时钟沿来临后,数据需要保持稳定的最短时间,简写为 Th;
(2)对于时钟和异步复位信号,分析recovery恢复时间和removal移除时间
recovery 恢复时间:在有效的时钟沿来临前,异步复位信号保持稳定的最短时间;
removal 移除时间:在有效的时钟沿来临后,异步复位信号保持稳定的最短时间,在这个时间以后,才可以移除复位信号;
责任编辑:haq
全部0条评论
快来发表一下你的评论吧 !