一乐电子

一乐电子百科

 找回密码
 请使用微信账号登录和注册会员

QQ登录

只需一步,快速开始

快捷登录

手机号码,快捷登录

搜索
查看: 8252|回复: 7
收起左侧

about Quartus II TimeQuest Timing Analyzer PDF documentation

[复制链接]
发表于 2011-4-1 15:26 | 显示全部楼层 |阅读模式
本帖最后由 kenson 于 2011-4-1 15:34 编辑 + Y) Y: u7 |1 z/ p) q

2 t! l7 [* d% _SDC 命令
" q. C$ j! U6 m2 K3 o mnl_sdctmq.pdf (846.7 KB, 下载次数: 687) 3 ]& q! o7 L) E+ o, P
3 U/ k8 G% s. r
timequest cookbook5 F; f& t" }- a* y' A5 d3 k
mnl_timequest_cookbook.pdf (312.89 KB, 下载次数: 910) 4 b: W- F+ h/ H% v! x
7 R/ Y6 Q$ c; l$ ^9 E" E* N
wp-01047-performing-equivalent-timing-analysis-between-timequest-and-trace.pdf (1.25 MB, 下载次数: 742)
% W" t& N$ X, I! L2 L! W: t. U. r: \: A# Z. S$ U( q; P7 T& h/ ~4 |
qts_qii53024.pdf (1.19 MB, 下载次数: 516) " d/ S3 O8 c& Q4 D' n7 s% G7 G  I

0 X. p, t: B9 W1 d9 i/ c
, ^% o4 d" l# ^
6 j: y3 a* a: W3 t3 j6 }5 v* F$ q  c4 T# }

& Z' h. J) Y6 ~. ?' t- n% b$ t2 P" E2 k+ ~5 g. g* z& L0 b
, [0 f+ Z6 Z  E: `
请不要回复此贴 7 W3 C; ]0 y! T' O" V. k: p* W# |: v
此贴是我自己学习记录用的
 楼主| 发表于 2011-4-3 12:43 | 显示全部楼层
本帖最后由 kenson 于 2011-4-3 12:56 编辑
- {% t" y( L! c- g' {4 J; n
1 v5 O0 K4 `7 x" ~8 q  r+ dFPGA设计中关于分频时钟的考虑# @# [% O1 s5 H! x
FPGA设计中经常会将某个时钟进行分频处理,分频后的信号作为另一个时钟信号驱动设计中的其他模块。看起来这是一种很简单的方法,但是有经验的工程师都不会推荐直接将分频后的信号作为时钟信号使用。为什么呢? 原因主要有以下几个方面。 1. 分频后的时钟相对于原来的时钟有一个延迟,如果用这个时钟去锁存由原时钟驱动的信号,就有可能发生timing error,导致setup time或者hold time不满足。1 f& \' ?! X* S# O/ k- b8 K! P1 _
2 V* T( ^  E. i
1 w; x+ M8 m: m9 @- ~
2. 如果分频后的时钟没有采用全部时钟的布线资源,就会使得该时钟到达FPGA内部各个逻辑块的skew相差较大,给时序分析工具带来很大的困难。如果没有在时序约束文件中将分频得到的始终和原时钟相关联,工具不会分析分频后时钟域和原时钟域之间的路径。 3. 即便是时序分析工具可以完成设计的时序分析,由于这些skew在电压、温度变化的时候也会发生变化,会引入更多的随机因素,从而有可能使得设计的稳定性变差,经常发生一些随机出现的错误,使得时序难以收敛,延误开发的进度。 一般来说如果必须要进行时钟的分频,可以采用时钟使能的方式,另外在Xlinx的FPGA中可以采用DCM实现0 skew的时钟分频。当然Altera的器件可能也有类似的硬件资源。 下面是一个简单的用时钟使能实现2分频的Verilog HDL例子:) R7 j1 l4 k# _" j9 h. I
  1. reg  clk_en;; |, s; ?7 J2 [/ G- G" z  t
  2. always @ (posedge clk)    //clk 为原时钟
    / v6 }3 r% X9 o0 i4 h7 ?
  3. begin
    7 D8 g( x* D& x( l5 a
  4.         clk_en <= ~clk_en; //clk_en在每个clk的上升沿翻转一次,相当于clk的二分频
    5 K& u) G8 j$ [: M+ _) {
  5. end# V! c" W7 A( @! E# w3 }
  6. //时钟使能方式, t. L! e; B3 y$ y$ y& ?! R
  7. always @(posedge clk)
    9 p  L  Z) R+ L) C. E0 g
  8. begin2 b5 b) G( |3 V# E, U1 Y8 f
  9.         if(clk_en). E' Y" I. h. ?& H2 X0 w
  10.                 begin: z5 i$ O5 t$ ]7 r2 ]$ ~
  11.                 //二分频时钟驱动的逻辑; z! \9 v5 {2 P; _: {/ a  p) m
  12.                 end
    & W; b2 W& u  m
  13.         else. y) \3 I( U- X3 @( @
  14.                 begin
    6 h/ L. Q; a  o7 r: Z
  15.                 end
    % E# W& ^6 }7 S) |) x
  16.         end" K" r2 d7 y2 X: y5 X3 q
  17. 1 A- K$ n/ r/ {- T6 T
复制代码

$ S) A: g# T5 E$ |5 b( U* t6 T% a3 Z' [& o- h( y: Z# u# k8 W) H- ~
# ~: D! `6 F( R" M

' v1 Q! m9 c9 Y0 X: j# _: U# r& Q& x
  1. //=============直接分频方式===============& s3 Y( e' [. o1 M- A# n7 y9 z
  2. reg clk_div2;
    , W/ A( L4 |5 u# @3 Q, N/ R' |' @  _
  3. always @ (posedge clk) //clk 为原时钟! C$ h! B, `$ |% C
  4. begin6 h* b5 n6 H- C0 x: R
  5. clk_div2 <= ~clk_div2; //clk_div2在每个clk的上升沿翻转一次,相当于clk的二分频
    " ]: ]+ |9 R) g
  6. end% ~/ w7 i  W7 D5 a/ _% Q' j
  7. always @(posedge clk_div2)( E8 n* U- H* h: f" ~. C
  8. begin& P4 k- J" Z% x# Q. w# J5 e: {
  9. //二分频时钟驱动的逻辑, l+ N3 a& {* A8 z$ a2 J+ F
  10. end
    8 v' e8 S) p9 K0 D

  11. ; ]/ U$ y. c8 i
  12. $ I4 `( P' b: p3 G) \- M
复制代码
 楼主| 发表于 2011-4-3 13:06 | 显示全部楼层
本帖最后由 kenson 于 2011-4-3 16:26 编辑
: \. l. b$ w* L& ?# p! U& [+ G8 u/ D8 o2 n/ I
时钟3分频电路- v6 B! B3 M- r+ y- N+ o9 \7 [1 M
% G. P/ `! _9 ?$ @/ F
  1. module clk_3_odd (clk,reset,clk_out); //占空比为50%
    5 z5 P2 I! J- y* A; F
  2. input clk, reset; , J9 M4 P& B1 H; L6 h  x$ j7 Q
  3. output clk_out; * O, t% c2 Q: Q# h- a0 C
  4. reg[1:0] state;
    ! T$ m1 L5 j! U3 i/ y7 D2 Q
  5. reg clk1;
    9 ?- T* T( p/ x: E# `; Y0 x" M' y$ F
  6. parameter s0=2'b00;  _. V, K- o4 {* `0 F& l" C0 h
  7. s1=2'b01;
    6 a$ ?+ t6 C) G" w
  8. s2=2'b11;6 t( D( a& d/ L6 F0 Y2 j
  9. always @(posedge clk or negedge reset) 1 r' I& g* u  s& W% d# c
  10. if(!reset)
    + A3 r& X3 P6 `( d  B
  11. state<=s0;
    2 ?6 _5 T! p0 {' O9 h% v! u
  12. else
    : W$ f7 R1 V/ m. X
  13. case(state)
    7 V3 w- b* z8 E9 ^5 r. W% S
  14. s0:state<=s1; 1 R  G) h8 G9 x0 R
  15. s1:state<=s2;
    3 P* P* i- p& q, y: A6 k& X
  16. s2:state<=s0;
    9 A1 d, H* b/ m0 C% R; ]  b; A  o
  17. default:state<=s0;
    6 f! t' D: N9 G0 I& d
  18. endcase ' l$ p* _/ q) b( {* X/ ]
  19. always @(negedge clk or negedge reset)
    : P  k3 R, n. n) O
  20. if(!reset) : p. v. |( V3 P, Q5 {# J
  21. clk1<=1'b0; $ [) a2 \$ a7 T
  22. else
    $ w6 e1 U( j. {7 @
  23. clk1<=state[0];
    ' A9 Y. R2 _: J
  24. assign clk_out=state[0]&clk1;, n- z, H8 U( S  T; t' F, S
  25. endmodule
复制代码
 楼主| 发表于 2011-4-3 15:58 | 显示全部楼层
标签: FPGA  时钟  0 f* h8 Q, q) S* {( a: s0 T9 U
* M) [0 L3 ^; g! F
FPGA中的时钟使能(转)
( o5 s: Z8 k5 T8 e  时钟使能电路是同步设计的基本电路。在很多设计中,虽然内部不同模块的处理速度不同,但由于这些时钟是同源的,可以将它们转化为单一时钟处理。在ASIC中可以通过STA约束让分频始终和源时钟同相,但FPGA由于器件本身和工具的限制,分频时钟和源时钟的Skew不容易控制(使用锁相环分频是个例外),难以保证分频时钟和源时钟同相,因此推荐的方法是使用时钟使能,通过使用时钟使能可以避免时钟“满天飞”的情况,进而避免了不必要的亚稳态发生,在降低设计复杂度的同时也提高了设计的可靠性。 $ P5 Y- g: I3 e- h: y
/ ^. e8 d5 ]/ b, Z% `$ v4 k6 [
    带使能端的D触发器,比一般D触发器多了使能端,只有在使能信号ENA有效时,数据才能从D端被打入D触发器,否则Q端输出不改变。1 l- Z7 O6 Z: F4 e/ ^

- K( E# q" C/ d* N    我们可以用带使能端的D触发器来实现时钟使能的功能。' t  @" r& ^) a5 c9 Z' ~
% v1 k" o, h* O
. D' X) s3 M! X6 C. K2 ^
verilog模型举例9 M! U$ l3 O8 M2 V
8 _8 n3 Y& W* N8 C# \% H
    在某系统中,前级数据输入位宽为8位,而后级的数据输出位宽为32,我们需要将8bit数据转换为32bit,由于后级的处理位宽为前级的4倍,因此后级处理的时钟频率也将下降为前级的1/4,若不使用时钟使能,则要将前级的时钟进行4分频来作后级处理的时钟。这种设计方法会引入新的时钟域,处理上需要采取多时钟域处理的方式,因而在设计复杂度提高的同时系统的可靠性也将降低。为了避免以上问题,我们采用了时钟使能以减少设计复杂度。5 y% j' Q4 G' l. N  C- I" B- Y7 J- Q

6 @0 Z! m2 B2 F- J' d/ @+ n  F- M) o例1:采用时钟使能, e3 ^# b/ F6 ^% N1 |

( E- w9 v$ J+ U6 w. x6 W6 S8 tmodule clk_en(clk, rst_n, data_in, data_out);
5 ^3 A9 Z' o% l& M- S7 tinput clk;
5 D  ?, Q9 l- {input rst_n;8 ]9 g) D8 d5 |7 l+ K# }
input [7:0] data_in;
3 |& Z+ S. x3 W0 J7 L5 E- n. A2 zoutput [31:0] data_out;
9 b" j+ @6 j5 i9 A$ V9 E3 u# V3 e! [5 {) h$ g# e( P
reg [31:0] data_out;
0 ^# ^2 E# `9 H0 @( U( @0 a  u! G* Ereg [31:0] data_shift;
, D  Z' j! ?9 v1 z, Sreg [1:0] cnt;2 I/ p0 ^' d* |5 K: E
reg clken;) }/ p! }% m# G1 k6 \( k- ?* f& X

/ m7 l% ]  e, m9 {1 Ealways @(posedge clk or negedge rst_n)9 _; |# z5 |( Q+ C# I
begin
' }" I+ P) {3 D* j; g* [5 B+ ?2 M/ Z   if (!rst_n)
6 ], L% D  M7 e      cnt <= 0;
# |, S: j6 k) D8 B% F6 [   else
1 W, H8 f% V: U/ @  S      cnt <= cnt + 1;2 c( k/ W9 Y' N9 U; Z% N1 O
end3 x& A( u( c* d7 W$ Q) u2 t2 L

* w! Y5 R7 N; e# P5 F9 E6 xalways @(posedge clk or negedge rst_n)% t: L9 f) B4 W1 O0 R
begin
3 @2 P$ X1 ~$ E% j   if (!rst_n)! t4 ]# p' h0 L7 f2 A
      clken <= 0;
3 c: u; K9 V: K0 G$ C   else if (cnt == 2'b01)+ X# a/ }3 b; E/ ?/ L2 u
      clken <= 1;/ K5 S+ f9 ]# O, ?5 ^" r
   else
+ d% U& x6 E5 b, ]6 Z      clken <= 0;1 ]7 x9 Y% g& k; A' X
end
3 b% E9 B) T! Y. N# E5 {1 C! _; w' C- Y1 {3 D$ e0 N6 p
always @(posedge clk or negedge rst_n)
- o3 Q) X$ M$ q$ Gbegin+ m# G/ k( D/ d: Q' t* T$ R
   if (!rst_n)
9 H) c8 Q/ U1 f      data_shift <= 0;
# d0 B  G1 ]/ X/ O   else
: s, ~% p4 q4 E4 E      data_shift <= {data_shift[23:0],data_in};
) h# E' D1 B- B9 L$ Z  Hend! g* x" R% @+ v. U7 u

+ I4 [9 k% ^, Zalways @(posedge clk or negedge rst_n)3 O: X! w/ d5 Q9 q8 @
begin
5 F9 ]  F  ], w/ d   if (!rst_n)
' {) D  |; h3 B) E) }% \2 R; ~      data_out <= 0;9 Y" ]& b: q$ Y/ D4 u
   else if (clken == 1'b1)( x6 f1 R/ R- o
      data_out <= data_shift;/ G( ^7 G1 m' L" z8 s1 Q/ b
end
6 `% {% B# i) R% ?& j- ?6 l3 p' a0 ?! K# w8 {8 _5 {' B
endmodule
 楼主| 发表于 2011-4-3 16:28 | 显示全部楼层
例2:采用分频方法' c7 W9 x3 o4 f
; K- D! x" R0 C' R+ h- Q  w
module clk_en1(clk, rst_n, data_in, data_out);
3 |2 |+ [1 E# w$ x1 Sinput clk;4 m0 T8 D( G* D3 V; P" d' l
input rst_n;
2 z% x+ s! a6 s0 `input [7:0] data_in;% J9 v, N7 s) s0 [# @- C8 u7 u/ ]
output [31:0] data_out;/ L7 I* m+ Y+ M0 Q4 O; T
4 r) d% ~( ~5 y2 m( f% u( n
reg [31:0] data_out;
4 X7 Z0 z+ k& a7 P! mreg [31:0] data_shift;
8 k. a2 G4 S# Nreg [1:0] cnt;5 I4 L0 q* a, A% p8 x+ B
wire clken;
& q, @; c' ]" e! _+ c; P- [
" i6 ~, x  j) B) galways @(posedge clk or negedge rst_n): m6 R( @2 O: m5 d/ G" i. c/ V
begin& ~$ k8 t) b' B$ i
   if (!rst_n)+ _5 }  t0 S5 E1 ^, u9 I
      cnt <= 0;
. n+ w* N8 q* u; a# v   else# y8 v# ~$ J* ^& _9 p/ a& j
      cnt <= cnt + 1;
+ A  f$ N) w9 ^$ lend
/ F* S# G/ \0 Q3 z# g* A, N. [- X9 _, O8 u/ `
assign clken = cnt[1];
  f  @9 r" F. j; O$ H; P: d% r6 I
* L0 N1 }$ i* `1 I' U  f" qalways @(posedge clk or negedge rst_n)" h) {7 g6 X8 `9 L. [, V+ X
begin  Q5 M. ?7 J! O* z  o
   if (!rst_n)
& J, p+ f: C; L- G' e8 E' k  I5 Z2 e      data_shift <= 0;4 F' C0 ~5 s9 g. f% V& W- H0 J' g
   else 1 F! o& F6 C0 J% M1 q. l' E7 w, T
      data_shift <= {data_shift[23:0],data_in};! h- J! X2 C8 h4 N
end
( q) @8 f# z% p  h4 h  h- q" E, a9 J# K: U2 W  B3 Z. K
always @(posedge clken or negedge rst_n)2 {3 i9 o( G5 U
begin+ Q  x- V; _( R+ F# ~( c
   if (!rst_n). i, E: \. V' D8 Y
      data_out <= 0;
9 ~$ b7 g8 {5 X. T" n3 C   else
  A6 {6 ^, |; ?7 M      data_out <= data_shift;4 i* B( _, \% W# r
end
5 ]% D" g# f5 p9 o, B1 h: k9 l4 [
8 U) u: q" S3 @3 [; K2 V7 [endmodule
 楼主| 发表于 2011-4-3 16:36 | 显示全部楼层
FPGA时钟问题集合
) q  t" J' i" p# S. \0 K
. T. ?; j2 _8 v5 w# I8 j* N' r. N' q
无沦是用离散逻辑、可编程逻辑,还是用全定制硅器件实现的任何数字设计,为了成功地操作,可靠的时钟是非常关键的。设计不良的时钟在极限的温度、电压或制造工艺的偏差情况下将导致错误的行为,并且调试困难、花销很大。在设计PLD/FPGA时通常采用几种时钟类型。时钟可分为如下四种类型:全局时钟、门控时钟、多级逻辑时钟和波动式时钟。多时钟系统能够包括上述四种时钟类型的任意组合。% K% g  I/ N: B' G, K0 z

. G' M' G% D1 h1 n* ?3 ]# {& O1 P0 M3 u* _/ ~6 ]
1.全局时钟
9 ?7 A. h- Z6 q' q1 @$ c% }, I9 r' b  f$ g% c* f
对于一个设计项目来说,全局时钟(或同步时钟)是最简单和最可预测的时钟。在PLD/FPGA设计中最好的时钟方案是:由专用的全局时钟输入引脚驱动的单个主时钟去钟控设计项目中的每一个触发器。只要可能就应尽量在设计项目中采用全局时钟。PLD/FPGA都具有专门的全局时钟引脚,它直接连到器件中的每一个寄存器。这种全局时钟提供器件中最短的时钟到输出的延时。
8 ^# r# L& t: Y  n( k$ P% C0 V3 `" m/ c

/ R3 U3 F. j- j3 q+ T; a4 O图1 示出全局时钟的实例。图1 定时波形示出触发器的数据输入D[1..3]应遵守建立时间和保持时间的约束条件。建立和保持时间的数值在PLD数据手册中给出,也可用软件的定时分析器计算出来。如果在应用中不能满足建立和保持时间的要求,则必须用时钟同步输入信号(参看下一章“异步输入”)。
. }3 _, O& I: a( {8 a; ]& L

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_1.jpg

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_2.jpg

. Q3 s0 I- ^( l/ z
图1 全局时钟

! v- D% d- L$ J0 @: K
(最好的方法是用全局时钟引脚去钟控PLD内的每一个寄存器,于是数据只要遵守相对时钟的建立时间tsu和保持时间th)
  b7 U% m% q/ d; I  H5 [, r, D, p 8 d# Y. d) M! X2 h; Y0 q& a6 I8 J' z
2.门控时钟7 @2 K% |' c: i2 m
! V& W% z  p# f+ E; f- C6 C+ _: u
在许多应用中,整个设计项目都采用外部的全局时钟是不可能或不实际的。PLD具有乘积项逻辑阵列时钟(即时钟是由逻辑产生的),允许任意函数单独地钟控各个触发器。然而,当你用阵列时钟时,应仔细地分析时钟函数,以避免毛刺。
2 {1 @3 E' B- V; M通常用阵列时钟构成门控时钟。门控时钟常常同微处理器接口有关,用地址线去控制写脉冲。然而,每当用组合函数钟控触发器时,通常都存在着门控时钟。如果符合下述条件,门控时钟可以象全局时钟一样可靠地工作:
- r: E0 o* O$ G  H. _8 ^7 Q+ E) y0 y7 \7 S
1.驱动时钟的逻辑必须只包含一个“与”门或一个“或”门。如果采用任何附加逻在某些工作状态下,会出现竞争产生的毛刺。
  U2 r: x3 ?% x: l/ w2.逻辑门的一个输入作为实际的时钟,而该逻辑门的所有其它输入必须当成地址或控制线,它们遵守相对于时钟的建立和保持时间的约束。
: ?/ w' _4 r$ q3 k! h2 v* v( a% U
* O& r- q! D" r4 a' A* s7 b
9 p' Y6 e6 a3 ]7 k) @; P. d* E9 {图 2和图3 是可靠的门控时钟的实例。在 图2 中,用一个“与”门产生门控时钟,在 图3 中,用一个“或”门产生门控时钟。在这两个实例中,引脚nWR和nWE考虑为时钟引脚,引脚ADD[o..3]是地址引脚,两个触发器的数据是信号 D[1..n]经随机逻辑产生的。
5 ]2 o7 c4 K& u2 N5 g5 N7 K7 A

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_3.jpg

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_4.jpg

图2 “与”门门控时钟


& p: X1 Z4 s  m# z+ k: {7 ~7 c 

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_5.jpg


) e) P# w0 J/ k1 O1 w- Z' n, i6 M 

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_6.jpg

图3 “或”门门控时钟


1 H8 H1 {% [$ p9 a6 W9 k8 d5 h% \0 e/ I3 y/ [
图2和图3 的波形图显示出有关的建立时间和保持时间的要求。这两个设计项目的地址线必须在时钟保持有效的整个期间内保持稳定(nWR和nWE是低电平有效)。如果地址线在规定的时间内未保持稳定,则在时钟上会出现毛刺,造成触发器发生错误的状态变化。另一方面,数据引脚D[1..n]只要求在nWR和nWE的有效边沿处满足标准的建立和保持时间的规定。7 D) H" H9 Y; X7 X' ^

# H+ N% k0 ~0 |3 a9 I我们往往可以将门控时钟转换成全局时钟以改善设计项目的可靠性。图4 示出如何用全局时钟重新设计 图2 的电路。地址线在控制D触发器的使能输入,许多PLD设计软件,如MAX+PLUSII软件都提供这种带使能端的D触发器。当ENA为高电平时,D输入端的值被钟控到触发器中:当ENA为低电平时,维持现在的状态。

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_7.jpg

: u5 A+ f9 A, \& Q% l2 e
http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_8.jpg

图4 “与”门门控时钟转化成全局时钟
  i  l6 _5 o  B/ s/ P

# r( Z+ `% [* W8 I( O$ t! h

% V, P% y9 J  |: r% |2 J6 I' o* k0 ^: W- t  B$ i+ [1 y

$ [$ F7 s" `: {* ~图4 中重新设计的电路的定时波形表明地址线不需要在nWR有效的整个期间内保持稳定;而只要求它们和数据引脚一样符合同样的建立和保持时间,这样对地址线的要求就少很多。
% S1 M+ D- p1 n1 k; I2 z6 M( L$ a0 B4 e! x1 I. @; M- n
图给出一个不可靠的门控时钟的例子。3位同步加法计数器的RCO输出用来钟控触发器。然而,计数器给出的多个输入起到时钟的作用,这违反了可靠门控时钟所需的条件之一。在产生RCO信号的触发器中,没有一个能考虑为实际的时钟线,这是因为所有触发器在几乎相同的时刻发生翻转。而我们并不能保证在 PLD/FPGA内部QA,QB,QC到D触发器的布线长短一致,因此,如 图5 的时间波形所示,在器从3计到4时,RCO线上会出现毛刺(假设QC到D触发器的路径较短,即QC的输出先翻转)。; L, v! Y# r; Y8 p+ l

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_9.jpg

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_10.jpg

# s% @2 D  X; n- w: c  B7 @3 W( r7 Q
 

, f; _% H$ X. |( f
图5 不可靠的门控时钟$ o7 |; y5 ^: ~4 C
& t) t4 x6 ~( o
(定时波形示出在计数器从3到4改变时,RCO信号如何出现毛刺的)


4 N5 x4 Z' c. N; f, Y3 m
' q  O7 a6 _" r3 h% V$ ]' t* G2 _3 t+ w: i0 Z% }& a# i
图6 给出一种可靠的全局钟控的电路,它是图5不可靠计数器电路的改进,RCO控制D触发器的使能输入。这个改进不需要增加PLD的逻辑单元。

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_11.jpg
' y9 \. f' c& Y+ X/ \, C- _0 l! A- `' }& e3 P. T7 V! l/ ^( M
图6 不可靠的门控时钟转换为全局时钟* ~8 A- d" i" d: ^; u' k9 i6 w
6 O4 d2 x. ^- C/ ^- G  R* n$ m' \
(这个电路等效于图5电路,但却可靠的多)

, |' D; R0 [! q0 u0 n! A( R

- s' n6 \8 w( ?" o' Y5 d8 o3.多级逻辑时钟
4 u* g1 H  N/ Y/ `) S, E: c8 [) p/ ]! d
当产生门控时钟的组合逻辑超过一级(即超过单个的“与”门或“或”门)时,证设计项目的可靠性变得很困难。即使样机或仿真结果没有显示出静态险象,但实际上仍然可能存在着危险。通常,我们不应该用多级组合逻辑去钟控PLD设计中的触发器。
/ L7 u- W3 e- U$ G0 V
' v/ `: d1 m; X4 s) Q7 m图 7 给出一个含有险象的多级时钟的例子。时钟是由SEL引脚控制的多路选择器输出的。多路选择器的输入是时钟(CLK)和该时钟的2分频(DIV2)。由图7 的定时波形图看出,在两个时钟均为逻辑1的情况下,当SEL线的状态改变时,存在静态险象。险象的程度取决于工作的条件。多级逻辑的险象是可以去除的。例如,你可以插入“冗余逻辑”到设计项目中。然而,PLD/FPGA编译器在逻辑综合时会去掉这些冗余逻辑,使得验证险象是否真正被去除变得困难了。为此,必须应寻求其它方法来实现电路的功能。
+ A1 j( D. Y9 v# Y9 G 

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_12.jpg


  X6 M" z" z! F图7 有静态险象的多级时钟

. \: A( w" @. m; R6 R" I0 h" Q
: |+ O3 c; \/ D
图8 给出 图7 电路的一种单级时钟的替代方案。图中SEL引脚和DIV2信号用于使能D触发器的使能输入端,而不是用于该触发器的时钟引脚。采用这个电路并不需要附加 PLD的逻辑单元,工作却可靠多了。 不同的系统需要采用不同的方法去除多级时钟,并没有固定的模式。
: W, K) h) `# j5 {' O$ e4 [ 

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_13.jpg

图7 无静态险象的多级时钟

(这个电路逻辑上等效于图7,但却可靠的多)

+ m0 T# e+ }5 s( O+ @* W6 E
 
( n8 D8 y2 Y3 Z" ]$ D4 [6 \4.行波时钟3 d, U3 X% E; x# k2 g' z1 o

( X. L- h7 }( P1 Y. f1 A另一种流行的时钟电路是采用行波时钟,即一个触发器的输出用作另一个触发器的时钟输入。如果仔细地设计,行波时钟可以象全局时钟一样地可靠工作。然而,行波时钟使得与电路有关的定时计算变得很复杂。行波时钟在行波链上各触发器的时钟之间产生较大的时间偏移,并且会超出最坏情况下的建立时间、保持时间和电路中时钟到输出的延时,使系统的实际速度下降。
, z  l' u! c+ D用计数翻转型触发器构成异步计数器时常采用行波时钟,一个触发器的输出钟控下一个触发器的输入,参看图9 同步计数器通常是代替异步计数器的更好方案,这是因为两者需要同样多的宏单元而同步计数器有较快的时钟到输出的时间。图10 给出具有全局时钟的同步计数器,它和 图9 功能相同,用了同样多的逻辑单元实现,却有较快的时钟到输出的时间。几乎所有PLD开发软件都提供多种多样的同步计数器。
' g; h3 ~8 \2 ~7 `! k7 N 

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_14.jpg

图9 行波时钟


- T9 B; S0 z  x 

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_15.jpg

图10 行波时钟转换成全局时钟- Q8 d' z" H2 [8 A
(这个3位计数器是图9异步计数器的替代电路,它用了同样的3个宏单元,但有更短的时钟到输出的延时)


# d6 d( `, f: N9 j. y5. 多时钟系统
. k" O5 q+ ?7 s( F% W0 o9 {4 q, V8 }
  L$ n0 x  V8 h) {( e& p! P

3 I; g9 n; j8 h* W8 [9 S/ I4 i9 R1 _( Y
- ], ]; l8 Q% v) `6 k
' M: c/ N" [4 {) k) T7 @: R& _# V! x4 C
5 a& r, C8 X7 y, O$ r7 Z0 f

" ~6 f8 u, K% _许多系统要求在同一个PLD内采用多时钟。最常见的例子是两个异步微处理器器之间的接口,或微处理器和异步通信通道的接口。由于两个时钟信号之间要求一定的建立和保持时间,所以,上述应用引进了附加的定时约束条件。它们也会要求将某些异步信号同步化。
0 j0 B+ h8 g( e2 o- p/ E4 M) Q' U1 x0 v8 i" q, y" p- _
图11 给出一个多时钟系统的实例。CLK_A用以钟控REG_A,CLK_B用于钟控REG_B,由于REG_A驱动着进入REG_B的组合逻辑,故CLK_A 的上升沿相对于CLK_B的上升沿有建立时间和保持时间的要求。由于REG_B不驱动馈到REG_A的逻辑,CLK_B的上升沿相对于CLK_A没有建立时间的要求。此外,由于时钟的下降沿不影响触发器的状态,所以CLK_A和CLK_B的下降沿之间没有时间上的要求。,如图4,2.II所示,电路中有两个独立的时钟,可是,在它们之间的建立时间和保持时间的要求是不能保证的。在这种情况下,必须将电路同步化。图12 给出REG_A的值(如何在使用前)同CLK_B同步化。新的触发器REG_C由GLK_B触控,保证REG_G的输出符合REG_B的建立时间。然而,这个方法使输出延时了一个时钟周期。
! v) T0 }; n- Z1 j
; {: _* `* I4 E  c8 a  E

. o: N6 T1 M& Z& y" x
4 w% J7 o3 L& s) P1 z
  X) x  @: N# e4 ]/ u/ h" K
2 [2 O# {* B( e4 s3 @8 G( @
7 T( i& i8 O/ [5 b1 e! Y/ R

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_16.jpg

图ll 多时钟系统
6 B- f5 c$ W8 u5 G(定时波形示出CLK_A的上升沿相对于CLK_B的上升沿有建立时间和保持时间的约束条件)

* Y" m! |; s8 U5 n; }* s4 Z
 

http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_17.jpg

图12 具有同步寄存器输出的多时钟系统  N1 Y! t. @- U1 p
(如果CLK_A和CLK_B是相互独立的,则REG—A的输出必须在它馈送到1REG_B之前,用REG_C同步化)

  K' [* j6 C2 h% x) m9 [6 A
 
1 n/ \1 ^/ ^- M! Q. h1 [  C在许多应用中只将异步信号同步化还是不够的,当系统中有两个或两个以上非同源时钟的时候,数据的建立和保持时间很难得到保证,我们将面临复杂的时间问题。最好的方法是将所有非同源时钟同步化。使用PLD内部的锁项环(PLL或DLL)是一个效果很好的方法,但不是所有PLD都带有PLL、DLL,而且带有 PLL功能的芯片大多价格昂贵,所以除非有特殊要求,一般场合可以不使用带PLL的PLD。 这时我们需要使用带使能端的D触发器,并引入一个高频时钟。

 http://image16.360doc.com/DownloadImg/2010/10/2417/6240652_18.jpg

图13 不同源时钟


5 ~; S& e0 ]( |( v7 b' P. W8 G如图13所示,系统有两个不同源时钟,一个为3MHz,一个为 5MHz,不同的触发器使用不同的时钟。为了系统稳定,我们引入一个20MHz时钟,将3M和5M时钟同步化,如图15所示。 20M的高频时钟将作为系统时钟,输入到所有触发器的的时钟端。3M_EN 和5M_EN将控制所有触发器的使能端。即原来接3M时钟的触发器,接20M时钟,同时3M_EN 将控制该触发器使能,原接5M时钟的触发器,也接20M时钟,同时5M_EN 将控制该触发器使能。 这样我们就可以将任何非同源时钟同步化。


$ |6 ]8 @' s9 d& x1 Nhttp://image16.360doc.com/DownloadImg/2010/10/2417/6240652_19.jpg

图13 同步化任意非同源时钟

(一个DFF和后面非门,与门构成时钟上升沿检测电路)


1 N& `, X! S" [* g: X

另外,异步信号输入总是无法满足数据的建立保持时间,容易使系统进入亚稳态,所以也建议设计者把所有异步输入都先经过双触发器进行同步化,详情可参阅这篇文章:Are Your PLD Metastable?

4 |7 t7 q2 o. X3 X4 L' b; B! v
 - M! N" F0 W3 `4 S  [# g8 {
小结:稳定可靠的时钟是系统稳定可靠的重要条件,我们不能够将任何可能含有毛刺的输出作为时钟信号,并且尽可能只使用一个全局时钟,对多时钟系统要注意同步异步信号和非同源时钟。

本版积分规则

QQ|一淘宝店|手机版|商店|电子DIY套件|一乐电子 ( 粤ICP备09076165号 ) 公安备案粤公网安备 44522102000183号

GMT+8, 2025-4-28 16:40 , Processed in 0.064211 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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