dc概论之IO约束

版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明
http://bb2hh.blogbus.com/logs/39654476.html 

注明:如需转载,请注明作者出处,谢谢~,Author:pythonlong

 以下根据资料和个人体会整理,如果错误,疑问欢迎请指正,讨论!!

用dc综合过程中需要对输入输出端口进行约束。
一般的约束出发点有两种,一种是dc,一种是ac。
所谓的dc是指已知输入延迟,或者输出延迟。这个要从系统考虑。
所谓的ac是指输入输出延迟未知,但是知道器件输入需要的保持,建立时间的关系。

下面我们看下对于输入,根据dc,ac如何约束。

1.DC
 如果我们知道Tdelay的max,min那么很容易的写出约束
 set_input_delay -max Tmax -clock Clk DIN
 set_input_delay -min Tmin -clock Clk DIN
 但是如果我们不知道输入延迟的最大最小值。那么如何约束呢。
 先看下最大最小延迟对于器件的建立,保持检查起到的影响

 如上图所示:Tdelay_min对信号的影响可用从T3出看出。
 Tdelay_max对信号的影响可用从T1处看出。
 所以信号的变化只能在斜线的阴影区。
2.AC
 基于上图的认识,如果我们对于设计的芯片的输入信号的建立,保持有所了解。
 可用使用AC来约束,如上图,我们知道对输入信号的要求是建立要在Setup之前,
 保持要在Hold之后。那么约束可用写成:
 set_input_delay -max Tperiod-Setup -clock Clk DIN
 set_input_delay -min Hold -clock Clk DIN
再看下对于输出,根据dc,ac如何约束。

1.DC
 如果我们知道pcb板上信号延迟的最大,最小,也很容易写出约束。
 (这里的最大最小延迟仅指路径上的信号延迟,不包含器件如上图中D2本身的建立时间,保持时间要求,
 所以设置约束的时候要主意下)
 set_output_delay -max Tdelay_max + Tsetup -clock Clk DOUT
 set_output_delay -min Tdelay_min - Thold -clock Clk DOUT
下面再看下输出最大最小延迟对于建立,保持检查起到的影响

 如上图所示,最大延迟影响如T1所示,最小延迟影响如T3所示,这里假设器件的setup,hold均为0,可用容易理解。
这里要主意,最小延迟的影响,因为任何延迟都会满足要求。最小延迟影响,要求信号在细条阴影区变化,但是考虑到launch边沿在T2,
所以信号的允许变化范围如阴影区显示(大条)。
2.AC
但是通常设计的chip外接可能还是chip或者其他器件,这些器件都有建立,保持要求。
所以如果上图的时序改成下面这种基于外围器件的建立,保持要求的。则更为理解。

约束也就相应的改成:

 set_output_delay -max Setup -clock Clk DOUT
 set_output_delay -min -Hold -clock Clk DOUT

 如果注意观察就会发现上如对于信号的要求都是要求信号在相关时钟沿附件保持稳定。
 有的时候我们要求信号在相关时钟沿附近是需要变化的。
 这里要用到零多周期路径。
 下面看下对于一般的单周期路径,如何写成多周期路径

 

那么如果对于零多周期路径,建立,保持如何检查:

当设置set_multicycle_path -setup 0 的检查如下:

当再次设置set_multicycle_cycle -hold -1 ..时序检查如下:

 再如下图,我们要求信号在S1,H1区域内变化。
 如何约束呢。

 首先是设置0多周期路径。
 set_multicycle_path -setup 0 .....
 set_multicycle_path -hold -1 .....
 然后根据要求设置最大最小延迟。
 有了上面的认识,我们大约可用了解:
 如果设置了最大延迟,那么信号只能在最大延迟前变化,
 如果设置了最小延迟,那么信号只能在最小延迟后变化。
 所以我们设置成:
 set_output_delay -max -S1 .....
 set_output_delay -min H1 .....
 注意符号:)

 接着我们来考虑下源同步接口,所谓源同步接口就是输入输出带有时钟线。
 同时数据的变化和时钟沿对齐(或上升沿,或下降沿,或双沿)。
 如下图,单边沿对齐的源同步接口。数据DQ和时钟SCK对齐,CAC地址控制信号

 

 当然我们不知道pcb走线延迟,但是我们知道链接的器件的建立,保持要求分别为Th_ext,Ts_ext
 我们自己chip的建立保持要求为Th,Ts
 我们可用约束如下:
 create_generated_clock -name clkx1 -multiply_by 1 -source clk PLL/clkx1
 create_generated_clock -name SCK -divide_by 1 -source PLL/clkx1 SCK

 set_input_delay -max T-Ts -clock clkx1 DQ  
 set_input_delay -min Th -clock clkx1 DQ

 set_output_delay -max Ts_ext -clock SCK {DQ CAC}
 set_output_delay -min -Th_ext -clock SCK {DQ CAC}


 如果数据和时钟是双边沿对齐的,建立,保持条件如上,同时下降沿和上升沿要求一样。

 

  create_generated_clock -name clkx1 -multiply_by 1 -source clk PLL/clkx1
 create_generated_clock -name SCK -divide_by 1 -source PLL/clkx1 SCK

 set_output_delay -max Ts_ext -clock SCK CAC
 set_output_delay -min -Th_ext -clock SCK CAC

 set_input_delay -max T-Ts -clock clkx1 {DQ DQS}
 set_input_delay -max T-Ts -add_delay -clock clkx1 -clock_fall clkx1 {DQ DQS}
 set_input_delay -min Th -clock clkx1 {DQ DQS}
 set_input_delay -min Th -add_delay -clock clkx1 -clock_fall clkx1 {DQ DQS}

 set_output_delay -max Ts_ext -clock SCK {DQ DQS}
 set_output_delay -max Ts_ext -add_delay -clock SCK -clock_fall {DQ DQS}

 set_output_delay -min -Th_ext -clock SCK {DQ DQS}
 set_output_delay -min -Th_ext -add_delay -clock SCK -clock_fall {DQ DQS}

转载于:https://www.cnblogs.com/liuokay/archive/2011/04/05/2005699.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/261479.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

普通调幅(AM)与抑制载波双边带调幅(DSB)matlab编程实现

实验任务 实现单频信号的AM、DSB调制,绘制调制前后的波形和频谱 实验原理 matlab代码 AM调制 clear all; ts 0.0025; %信号抽样时间间隔 fs 1/ts; %抽样频率 t 0:ts:10-ts; %时间向量 df fs/length(t); %fft的频率分辨率 msg2 cos(2*pi*2*t); Pn fft(msg2…

MySQL中MySQL X.X Command Line Client一闪而过的问题

问题介绍:我安装完MySQL(我安装的是5.5)后,使用MySQL 5.5 Command Line Client,每次点击,总是一闪而过。解决方法如下:首先进入cmd 切入MySQL的安装目录,然后切入 bin 目录 ,输入mysqld-nt --sk…

4pam调制与解调(matlab实现)

实验原理 这是一种使用脉冲幅度调制技术的线路编码。PAM4信号有四个电压电平,每个幅度电平分别对应逻辑比特00、01、10和11。换言之,PAM4编码的每个符号由2个比特组成,它们对应一个电压电平,即幅度。 00对应-3,01对应-1,10对应1,…

普通调幅(AM)与包络检波(matlab实现)

普通调幅(AM)与包络检波 1.实验任务 采用matlab实现普通调幅信号的包络检波,并绘制包络检波后的信号的波形与频谱。 2.实验原理(请读者参见matlab通信仿真文件夹) 3.matlab代码 time.33;%采样时长 Ts1/10000;%采样…

免费Google地图API使用说明(转)

转自:http://www.cnblogs.com/mypig/articles/1936154.html01事件监视 02 03GEvent.addListener用来注册事件监视器,在这个例子中,在用户移动或拖拽地图后,输出地图中心点的经/纬. 04 05 06var map new GMap(document.getElem…

双栈共享存储空间(C++代码实现)

理论部分 理论来源&#xff1a;b站up主:跟懒猫老师快乐数据结构 C代码 #include<iostream> using namespace std; const int STACKSIZE 6; //两栈共享存储空间编程 //使用类模板编程 template<class DataType> class BothStack { private:DataType *data;//属性…

毕业三年

2013年6月&#xff0c;毕业整整3年了。曾经的同伴&#xff0c;有人创业了&#xff0c;有人升职加薪&#xff0c;也有人职场失利。而我&#xff0c;做了2年多的独立开发者。 在大学的时候我学的是.net&#xff0c;在毕业前还去考了微软的认证&#xff0c;考过了&#xff0c;但考…

Muduo 网络编程示例之五: 测量两台机器的网络延迟

Muduo 网络编程示例之五&#xff1a; 测量两台机器的网络延迟 陈硕 (giantchen_AT_gmail) Blog.csdn.net/Solstice t.sina.com.cn/giantchen 这是《Muduo 网络编程示例》系列的第五篇文章。 Muduo 全系列文章列表&#xff1a; http://blog.csdn.net/Solstice/category/779646.…

数据结构表达式求值(C++)

实验原理 代码思路 使用两个顺序栈编程&#xff0c;一个顺序栈用来存储操作数&#xff0c;一个顺序栈用来存储操作符 关键为表达式求值函数的编写 对该函数&#xff0c;循环结束条件为栈顶元素为’#’,且读入的字符也为’#’ 循环体 &#xff08;1&#xff09;判断是否为操作…

中国互联网大佬江湖拼什么?拼财力拼出身拼前景拼造势

创业者千千万&#xff0c;大佬的椅子却有限。 马云、李彦宏、马化腾、雷军、周鸿祎、丁磊、张朝阳……大浪淘沙之中&#xff0c;他们挺住了&#xff0c;前进了&#xff0c;成功了。纵观互联网大佬修炼过程&#xff0c;虽然有机缘巧合&#xff0c;背后仍然有道可依。 表面风平浪…

Javascript中正则表达式的全局匹配模式

先看一道JavaScript题目&#xff0c;据说是国内某知名互联网企业的JavaScript笔试题&#xff0c;如果对正则的全局匹配模式不了解的话可能会对下面的输出结果感到疑惑。 View Code varstr "123#abc";varre /abc/ig;console.log(re.test(str)); //输出tureconsole.lo…

捕捉所有异常_详解Java中异常的分类

下面介绍几种常见的异常类型&#xff0c;便于在出错时对程序进行查错&#xff1a;&#xff08;1&#xff09;Exception 各种异常的根类如果你不知道将发生的异常集体属于哪&#xff0c;而可以肯定种这个地方会出现异常时&#xff0c;可以把异常类型定义为Exception。&#xff0…

2ASK调制与解调(包含maltab代码)

实验原理 实验代码 信噪比为20db时代码: clear all; close all; %%%%%%% parameter settings %%%%% Rb 1000;%比特率 Rs 1000;%符号率 Fs 10000;%采样频率 N 100000;%原始消息信号的长度 UpSampleRate Fs/Rs; % 一个符号周期内采样点数 RollOff 0.25; Spa…

数据结构银行排队问题

实验任务 银行排队模拟程序功能 假设某银行有四个窗口对外接待客户,从早晨银行开门起不断有客户进入银行。由于每个窗口只能接待一个客户&#xff0c;因此在客户人数众多时需在每个窗口前顺次排队&#xff0c;对于刚进入银行的客户&#xff0c;如果某个窗口的业务员正在空闲&a…

通讯中断 pc_S7程序RFID 与PC连接区别FB 65/UDT65

同样是使用使用FB65但RFID与PC的连接DB用法有一定的区别:首先说一下什么是FB65:通过TCP和ISO on TCP使用两个通信伙伴都调用FB 65 "TCON"来设置和建立通信连接。在这些参数中&#xff0c;您要指定哪个伙伴是主动通信传输点、哪个伙伴是被动通信传输点。设置并建立连接…

JavaScript 设计模式之构造函数模式

一、构造函数模式概念解读 1.构造函数模式概念文字解读 构造函数用于创建特定类型的对象——不仅声明了使用的对象&#xff0c;构造函数还可以接受参数以便第一次创建对象的时候设置对象的成员值。你可以自定义自己的构造函数&#xff0c;然后在里面声明自定义类型对象的属性或…

列表异步线程加载图片

手机客户端以列表形式展示数据是非常常见的一种方式。然而列表中要显示图片&#xff08;比如&#xff1a;头像&#xff09;就要采用异步线程加载的方式&#xff0c;这样做是为了防止加载图片数据的时候&#xff0c;花费时间过长&#xff0c;阻塞UI线程&#xff0c;从而达到保持…

matlab连续卷积动画实现(gui编程)

一.代码运行结果 二.代码 function varargout tianqi(varargin) % TIANQI MATLAB code for tianqi.fig % TIANQI, by itself, creates a new TIANQI or raises the existing % singleton*. % % H TIANQI returns the handle to a new TIANQI or the handle t…

Ubuntu GNOME 15.10升级16.4LTS

为什么80%的码农都做不了架构师&#xff1f;>>> 当Ubuntu GNOME官方已经发送16.4后&#xff0c;执行以下命令 sudo do-release-upgrade 显示没有新系统更新 在网上找到另一种方法是执行以下命令&#xff1a; sudo ppa-purge ppa:gnome3-team/gnome3-staging sudo p…

matplotlib plot 分组_小白学 Python 数据分析(16):Matplotlib(一)坐标系

人生苦短&#xff0c;我用 Python前文传送门&#xff1a;小白学 Python 数据分析(1)&#xff1a;数据分析基础小白学 Python 数据分析(2)&#xff1a;Pandas (一)概述小白学 Python 数据分析(3)&#xff1a;Pandas (二)数据结构 Series小白学 Python 数据分析(4)&#xff1a;Pa…