Today’s designs
have many functional as well as test modes. A number of clocks propagate to
different parts of design in different modes. And a number of control signals
are there which control these clocks. These signals are behind switching on and off the
design. Let us say, we have a simple design as shown in the figure below. Pin
‘SEL’ selects between two clocks. Also, ‘EN’ selects if clock will be
propagating to the sub-design or not. Similarly, there are signals that decide
what, when, where and how for propagation of clocks. Some of these controlling
signals may be static while some of these might be dynamic. Even with all this,
these signals should not play with waveform of the clock; i.e. these should not
cause any glitch in clock path. There are both architectural as well as timing
care-abouts that are to be taken care of while designing for signals toggling in
clock paths. This scenario is widely known as ‘clock gating’. The timing checks
that need to be modeled in timing constraints are known as ‘clock gating
checks’.
data:image/s3,"s3://crabby-images/28267/28267bb665cc3933b1d0b5b3fe9c98bea502fd6a" alt="A typical scenario showing how clocks are controlled in designs Two clocks are going to a sub-part of design and are controlled by two signals. SEL is used to select which clock will propagate. Further, there is a signal EN which decides if selected clock will propagate or not" |
Figure
1: A simplest clocking
structure
|
Definition of clock gating check: A clock gating check is a constraint, either applied or inferred automatically by tool, that ensures that the clock will propagate without any glitch through the gate.
Types of clock gating checks: Fundamentally,
all clock gating checks can be categorized into two types:
AND type clock gating check:
Let us say we have a 2-input AND gate in which one of the inputs has a clock
and the other input has a data which will toggle while the clock is still on.
data:image/s3,"s3://crabby-images/e4733/e47337f256fc36cd99104aa24a4b1c86dc2148af" alt="And type clock gating check EN signal controlling CLK_in signal" |
Figure 2: AND type clock gating check; EN signal controlling CLK_IN through AND gate |
Since, the clock
is free-running, we have to ensure that the change of state of enable signal
does not cause the output of the AND gate
to toggle. This is only possible if the enable input toggles when clock is at
‘0’ state. As is shown in figure 3 below, if ‘EN’ toggles when ‘CLK_IN’ is
high, the clock pulse gets clipped. In other words, we do not get full duty
cycle of the clock. Thus, this is a functional architectural miss causing
glitch in clock path. As is evident in figure 4, if ‘EN’ changes during
‘CLK_IN’ are low, there is no change in clock duty cycle. Hence, this is the
right way to gate a clock signal with an enable signal; i.e. make the enable
toggle only when clock is low.
data:image/s3,"s3://crabby-images/d4b00/d4b00aab7047ca854812b5e8ae7841bcca5609e2" alt="Clock clipping on AND gate If the enable signal toggles when clock is high, the output clock from an AND gate will be glitchy" |
Figure
3: Clock being clipped when
‘EN’ changes when ‘CLK_IN’ is high
|
data:image/s3,"s3://crabby-images/15be0/15be0eca88d3c1140f3eaf7c57cd266c665ade27" alt="Clock passing through AND gate If enable signal toggles when clock is low, clock will pass without any glitch" |
Figure
4: Clock waveform not being
altered when ‘EN’ changes when ‘CLK_IN’ is low
|
Theoretically,
‘EN’ can launch from either positive edge-triggered or negative edge-triggered
flops. In case ‘EN’ is launched by a positive edge-triggered flop, the setup
and hold checks will be as shown in figure 5. As shown, setup check in this
case is on the next positive edge and hold check is on next negative edge.
However, the ratio of maximum and minimum delays of cells in extreme operating
conditions may be as high as 3. So, architecturally, this situation is not
possible to guarantee the clock to pass under all conditions.
data:image/s3,"s3://crabby-images/f358e/f358e7186fd517540f91cacdea6e78952c0de05f" alt="setup check and hold check for and type clock gating When enable signal is launched from a positive edge-triggered register/latch, hold check is on next negative edge, which cannot be met." |
Figure
5: Clock gating setup and hold
checks on AND gate when 'EN' launches from a positive edge-triggered flip-flop
|
On the contrary,
if ‘EN’ launches from a negative edge-triggered flip-flop, setup check are
formed with respect to the next rising edge and hold check is on the same
falling edge (zero-cycle) as that of the launch edge. The same is shown in figure 6. Since,
in this case, hold check is 0 cycle, both the checks are possible to be met for
all operating conditions; hence, this solution will guarantee the clock to pass
under all operating condition provided the setup check is met for worst case
condition. The inactive clock state, as evident, in this case, is '0'.
data:image/s3,"s3://crabby-images/ea468/ea468bb329870fb8661a6788d44fdbae26e87839" alt="setup checks and hold checks for and-type clock gating when enable signals launches from negative edge When enable launches from negative-edge register/latch, hold check is zero cycle, which is possible to meet under all timing corners." |
Figure
6: Clock gating setup and hold
checks on AND gate when ‘EN’ launches from negative edge-triggered flip-flop
|
data:image/s3,"s3://crabby-images/e765f/e765ffae4866738a722094cd36767632a2c9e311" alt="An OR gate getting a clock and an enable OR gate forming a clock gating check" |
Figure 7: An OR gate controlling a
clock signal 'CLK_IN'
|
OR type clock gating check:
Similarly, since the off-state of OR gate is 1, the enable for an OR type clock
gating check can change only when the clock is at ‘1’ state. That is, we have
to ensure that the change of state of enable signal does not cause the output
of the OR gate to toggle. Figure 9 below shows if ‘EN’ toggles when ‘CLK_IN’
is high, there is no change in duty cycle. However, if ‘EN’ toggles when
‘CLK_IN’ is low (figure 8), the clock pulse gets clipped. Thus, ‘EN’ must be
allowed to toggle only when ‘CLK_IN’ is high.
data:image/s3,"s3://crabby-images/813bf/813bf99708db13cab67a87759049c1082a15d5f8" alt="Clock clipping on OR gate If the enable signal toggles when clock is low, the output clock from an OR gate will be glitchy" |
Figure
8: Clock being clipped when
'EN' changes when 'CLK_IN' is low
|
data:image/s3,"s3://crabby-images/68981/689811a300af94701b5b3a12e299069bb8771a46" alt="Clock passing through OR gate If enable signal toggles when clock is high, clock will pass without any glitch" |
Figure
9: Clock waveform not being
altered when 'EN' changes when 'CLK_IN' is low
|
As in case of
AND gate, here also, ‘EN’ can launch from either positive or negative edge
flops. In case ‘EN’ launches from negative edge-triggered flop, the setup and
hold checks will be as shown in the figure 10. The setup check is on the next
negative edge and hold check is on the next positive edge. As discussed earlier, it cannot guarantee
the glitch less propagation of clock.
data:image/s3,"s3://crabby-images/b8b48/b8b48539cbe66197c8d91201b5ff1429838d074e" alt="Setup and hold checks for OR type clock gating when enable launches from negative edge When enable signal is launched from a negative register/latch, hold check is on next positive edge, which cannot be met." |
Figure
10: Clock gating setup and hold
checks on OR gate when ‘EN’ launches from negative edge-triggered flip-flop
|
If ‘EN’ launches
from a positive edge-triggered flip-flop, setup check is with respect to next
falling edge and hold check is on the same rising edge as that of the launch
edge. The same is shown in figure 11. Since, the hold check is 0 cycle, both
setup and hold checks are guaranteed to be met under all operating conditions
provided the path has been optimized to meet setup check for worst case condition. The inactive clock state, evidently, in this case, is '1'.
data:image/s3,"s3://crabby-images/6891b/6891bc8569a33cf871eb3302d389b2070b89c06f" alt="Setup and hold checks for OR type clock gating when enable launches from positve edge When enable launches from positive-edge register/latch, hold check is zero cycle, which is possible to meet under all timing corners." |
Figure 11: Clock gating setup and hold checks on OR gate when 'EN' launches from a positive edge-triggered flip-flop
|
|
We have, thus
far, discussed two fundamental types of clock gating checks. There may be
complex combinational cells other than 2-input AND or OR gates. However, for
these cells, too, the checks we have to meet between the clock and enable pins
will be of the above two types only. If the enable can change during low phase
of the clock only, it is said to be AND type clock gating check and vice-versa.
SDC command for application of clock gating checks: In STA, clock gating checks can be applied with the help of SDC command set_clock_gating_check.
Also read: