Static Timing Analysis
Static Timing Analysis
Introduction
Static timing analysis is an important step in analyzing the performance of a design. Timer is Actel's static
timing analysis tool incorporated in Designer software. Timer allows both pre-layout and post-layout
static timing analysis and constraints setting.
Generally, static timing analysis is much faster than timing-driven gate-level simulation and does not
require stimulus vector generation. Therefore, unlike dynamic analysis, the quality of the static approach
is independent of the quality of stimulus vectors. However, proper functionality of the design cannot be
checked in static analysis.
An accurate and efficient static timing analysis has many benefits, such as providing quick and efficient
information to enhance the design performance and easing the design debugging procedure. This
application note presents the most important concepts and techniques of static timing analysis and
contains practical examples.
Background
Actel's Designer software includes the static timing analysis tool called Timer. The timing information is
accessible after compiling the design netlist in Actel’s Designer software. However, the final and accurate
timing information will be available after place-and-route. Detailed information on Timer is available in
the Timer User’s Guide. The Designer software release notes contain Timer updates and are located on
Actel's website. This section presents the main features of Timer and their functionality.
Figure 1 represents the main (or summary) window of Timer. In the Summary section, Timer reports
maximum clock frequency, input to register delay, register to output delay, and input to output port delay
for best, worst, and typical cases based on the user preference.
1. The contents are based on the Designer release R1-2002 Service pack 2.
January 2004 1
© 2004 Actel Corporation
Static Timing Analysis Using Designer's Timer
Figure 2 shows the Clock tab section of the Timer GUI. In this section, the user can apply constraints on the
clock or define paths that are not required to meet the timing constraint. For example, users can identify
their multi-cycle or false paths in this section.
One of the most useful sections of Timer is the Path tab (Figure 3). In this section, Timer reports the
detailed path delays for default or custom path sets. The default path sets are input-to-output, input-to-
register, register-to-register and register-to-output for the specified clock domain. Additionally, one can
define customized paths for a more focused and detailed analysis. Each path in a set can be expanded. In
the expanded path report, the delay components in each path (nets or gates) are listed along with a
schematic representation of the path.
Breaks is another interactive part of Timer (Figure 4 on page 3). Under this tab, the user can put breaks on
a different group of paths to be excluded from timing calculations or define paths to pass into the
calculations.
2
Static Timing Analysis Using Designer's Timer
INST_0 INST_1
Pad A INST_3
D Q Pad
B D
INST_2
CLK
3
Static Timing Analysis Using Designer's Timer
D1(max)
(1)
A
(2) B
D5(max)
D2(max) D3(max) D4(max)
4
Static Timing Analysis Using Designer's Timer
The user can apply constraints on the clock frequency using the summary tab. Based on the user's clock
period requirement, Timer calculates the maximum allowed register-to-register path delay based on the
following equation:
max reg-to-reg path delay = clock period requirement – setup time requirement + clock skew
In the path tab, the calculated max reg-to-reg delay will be shown in the "max delay" column. If the path
delay is more than the calculated max delay, the path will be marked as a constraints violation. The user
should note that this would happen if there is any constraint on the clock frequency. If there is no
constraint, the maximum allowed register-to-register delay will be calculated as the following equation
and no violation will be reported:
max reg-to-reg path delay = clock period requirement – setup time requirement
If needed, the verification of required hold time can be done manually as follows:
minimum path delay – maximum clock skew ≥ register hold time
5
Static Timing Analysis Using Designer's Timer
For example, in Figure 10 (data path delays are derived from the shortest path of the best case analysis), if
the maximum clock skew (tRd_2 – TRD_1), derived from the longest path in best case analysis, is larger than
2.1 ns (tCO[min] + tRD1[min] + tHD), then the hold time of the second register is violated. We will discuss the
clock skew and its derivation in more detail in the section “Clock Skew” on page 9. During the hold time
calculation/verification, the user needs to assume a safety margin, since the minimum delay values are not
guaranteed.
tCO = 2 ns tHD = 0 ns
tRD1 = 0.1 ns
Delay
tRD_1 tRD_2
tIN
For special registers or other special macros, such as TMR, CC, or any other macros that use more than one
cell to be implemented, larger delays are expected. For these macros, setup, hold, removal, and recovery
times become important and need to be checked carefully. Furthermore, the aforementioned timing
requirements need to be investigated more carefully in the presence of a noticeable clock skew.
For SX-A, RTSX-S, eX, Axcelerator, RTAX-S, ProASIC, ProASICPLUS, and any other new Actel devices, Timer
can generate a Setup and Hold Time Violation report for register-to-register paths in the same clock
domain. Users can generate the report by opening Timer from the Actel Designer software, then going to
File > Tool > Report Violation.
The Timing Violation report is only valid in the presence of a user-defined clock constraint. If the design
clocks are not constrained, the report context will be empty. The Timing Violation report is formed in four
sections, as follows:
• Header – contains the software version, design name, operating condition, device type, speed grade
and Timer preferences.
• Clock Constraint Violation – reports the critical paths that limit the clock frequency constraint.
• Max Delay Constraint Violation – reports the critical paths that limit any Max Delay constraint set in the
Timer Path tab window.
• Min Delay Constraint Violation – lists short data paths that are susceptible to hold time violation.
In the timing violation report, the clock network skew is taken into account when calculating the slack.
The report is sorted by slack for each section where a negative slack indicates a violation.
The timing violation report is created based on the operating condition set in the timer preferences.
Therefore, to examine the long data paths versus any clock or max delay constraint, the user should
export the report while the timer preferences are set to worst case/long paths. On the other hand, to
identify all possible hold time violations, the report should be created while the timer preferences are set
to best case/short paths. Users should note that after each change in the operating condition in the Timer
window, the Calculate Delays option should be selected before exporting the Timing Violation report.
The external setup and hold calculation and report will be discussed in more detail in the “Analysis of
Input and Output Delays” on page 11 and the “Timing Report Interpretation” on page 12.
6
Static Timing Analysis Using Designer's Timer
A. False Path
B. Multi_Cycle Path
CLK1
Large
Combinatorial Logic
Part B in Figure 11 shows multi-cycle paths. The upper path in part B in Figure 11 contains more than two
levels of registers, and therefore, it takes more than one clock cycle for the output to be valid. The lower
path in part B in Figure 11 shows another multi-cycle path, which contains only two levels of registers. The
large combinatorial logic delay on the data path requires more than one clock cycle to propagate the
valid data to the output. If users have these types of multi-cycle paths or false paths in their design, they
should be declared so that they will not be constrained by the place-and-route tool, or show up as
violations in your timing analysis. This will free routing resources to be used for other critical paths of the
design.
Figure 12 on page 8 shows an example of a long path that should be declared in Timer. For instance, in
this figure, the path from register SOURCE_A to SINK_A_1 is a multi-cycle path. By default, the Timer GUI
for this design will be similar to Figure 12 on page 8.
As shown in Figure 12 on page 8, the very first path in the register-to-register path set is a long path with
a 1.73 ns delay. Timer reports the minimum clock period as {1.73 + setup time of SINK_A_1}. Figure 12 on
page 8 also shows the Timer GUI if this path is expanded.
The reported minimum clock period for this design will be 2.43 ns (Figure 12 on page 8). To eliminate this
path from the report and obtain the clock period from the remaining single-cycle paths, one needs to put
a break in an appropriate location on the path. By asserting a break (using the break tab window of
Timer) on pins B or Y of the OR gate in the path, this long path will be broken and not reported in the
Timer. Figure 13 on page 8 shows the Timer GUI after inserting a break at the Y pin of the OR gate and
committing the change.
As indicated in Figure 13 on page 8, the minimum clock period is reported as 1.63 ns (0.93 ns + 0.7 ns).
7
Static Timing Analysis Using Designer's Timer
Timer GUI
for the Design
Expanded
Path
8
Static Timing Analysis Using Designer's Timer
If the paths are broken, they will not be reported in the path sets. If the user needs to have the false or
multi-cycle paths reported but not incorporated in the clock frequency calculations, he/she needs to
define them as clock exceptions. The clock exception definition is done under the "Clocks" tab. Any path
(identified by its source (driver) or sink (termination)), which is added to the “Exceptions" window, will be
excluded from the clock/constraint calculation.
Clock Skew
Clock skew is an important factor in design performance; however, clock skew problems may be
independent of operating clock frequency. Clock skew is a key factor in setup and hold time verification of
the registers. A large clock skew could lead to hold time violations or incorrect register states. The
following example shows how a large clock skew might affect the functionality of the design independent
of the running clock frequency. Consider the simple circuit shown in part A of Figure 14 on page 9.
If tSK is larger than tCQ + tDLY, then the application of the clock and data inputs may result in the wrong
register output as shown in Figure 14 on page 9. Note that reducing the clock frequency will not eliminate
the problem, indicated in Figure 14 on page 9. There are different solutions, such as adding a delay to the
data path or reducing the clock skew by using Actel's global networks to tackle similar problems.
However, the first step to approach the problem is estimating the clock skew.
A. B.
DIN Q1 Routing Q2
D Q D Q CLK
Delay t CQ
t DLY
CLK CLK
CLK_DLY CLK DLY
CLK Routing
Delay DIN
tSK
Q1
D2
Expected
Q2 Observed
To calculate the skew for a specific clock domain, the first step is to extract the delay from the clock input
(if the source is an external clock) to the clock input of all the registers in that clock domain. To do so, the
user needs to define and add an input-to-register path set from the clock input to the CLK port of all the
registers. If the clock is generated internally (such as PLL output), the user can define register-to-register
paths where the source register output is the generated clock. We will discuss the internal clock resources
under “Clock Drivers”. Timer keywords can be used to create the appropriate sets. For more information
9
Static Timing Analysis Using Designer's Timer
on the Timer keywords, please refer to the Timer User's Guide. The difference between the maximum and
minimum delay of the set is the clock delay of that clock domain. Note that the clock skew is not
necessarily equal to the maximum clock delay. The difference between the arrival time of the clock to two
registers can be taken as the skew, only if there is a valid data path between those registers.
The following is an example of a simple design with a clock input (CLK) driving two registers. In this
example, the clock skew and the shortest data paths between the registers will be extracted to point out
the critical paths of the design. The goal is to determine the clock skew between two registers which
forms the shortest data path delay (to check for hold time violation). Setting the Timer preferences to
show the shortest path in the best case, and using the following keywords in the "Advanced" window of
the "Add path set" GUI, will result in the Timer GUI shown in Figure 15 on page 11.
From: To:
$clocks( )[CLK]$registers(CLK):clockpins( )
(This will create a set from CLK input to clock input of all registers driven by CLK)
$registers(CLK):clockpins( ) $registers(CLK):$dp( )
The maximum clock skew can be obtained by comparing the shortest path delay from CLK input to the
source registers and the longest path delay from CLK input to the sink registers of the path set number six
in Figure 15 on page 11.
Clock Drivers
In many cases, the clocks are gated for different purposes. For example, users might need to select
between different clocks to drive a portion of the design through a MUX architecture. Moreover, the
output of the registers might be used as clocks in order to divide the source clock frequency. Regardless of
the purpose of gated or internally generated clocks, these clock resources should be identified in Timer for
accurate static timing analysis.
Generally, any signal that drives the clock input of registers is considered by Timer as a potential clock
signal. Therefore, the name of the clock signals might be different from the user-selected names because
Timer may pick a different net (carrying the same logic) than the clock resource. The following example
helps users to identify their clock resources for constraint application and analysis. Figure 16 on page 11
shows an example design with multiple clock signals.
If the netlist for the design in Figure 16 on page 11 is compiled in the Designer software, the following
ports will be indicated as clocks in Timer:
DIVIDER_CLK: This is a regular I/O driving a regular INBUF and then the CLK port of the register FF1.
CLK_SEL: This input is the selection input of the MUX architecture, which drives the clock input of the FF4
and FF6 registers.
SEC_CLK_MUX: This input is also connected to the clock input of the FF4 and FF6. The user should note
that the timing characteristics of this clock are similar to the CLK_SEL input.
FF1:Q: This is the output of the FF1 register. Any signal driving CLKINT (or QCLKINT) buffers will be
considered as a clock by Timer. In this particular example, the output of the FF1 register drives the routed
clock network (CLKINT buffer) and is connected to the clock input of the FF3, FF4, FF5, and FF6 registers
(FF4 and FF6 clock inputs are driven through the MUX).
PLL Outputs
Actel provides embedded PLL macros in some of the device families. In the designs targeting those
families, if the PLL macro is used, the output of the PLL is considered as the potential clock signal in the
design. The users can apply timing constraints to the output of the PLL as a clock and run timing-driven
place-and-route to meet the constraints. However, for ProASICPLUS devices, Timer does not take the PLL
configuration information (such as output frequency and multiplication factors) as a pre-defined
constraint. If necessary, the user needs to apply timing constraints on the output of the PLL to be able to
achieve better timing performance on the PLL outputs.
10
Static Timing Analysis Using Designer's Timer
11
Static Timing Analysis Using Designer's Timer
Delay I
Delay II
(+) (-)
(-) (+)
STABLE DATA STABLE
DATA
CLK CLK
Similarly, the external input hold time is calculated as the following equation:
External Hold Time = Delay II – Delay I + Internal Register Hold Time
Again, it is possible to have negative or positive external hold time and meet the timing requirements.
The most convenient approach to obtain the external setup and hold timer requirement of the design is
to export the timing report. This will be discussed in more detail in the "Timing Report Interpretation"
section.
Register-to-out path delays are used to derive the clock-to-out timing performance of the FPGA. Clock-to-
out timing characteristics of a design are vital in order to examine the external setup and hold time
requirement of the device derived by the FPGA outputs. In order to obtain the maximum clock-to-out of a
specific output, the user can define (add) a path set, sourcing from all registers and sinking into that
particular output. Please refer to the Timer User's Guide for instruction on how to add path sets.
12
Static Timing Analysis Using Designer's Timer
respect to the design clock signals. For example, in the report attached in “Appendix A” on page 14, the
user can find the following lines in the external setup and hold section:
Setup Hold Pins
1.09 0.35 From: INPUT_1
To: CLK_1
-0.03 0.42 From: INPUT_3
To: INPUT_1
These report lines mean that INPUT_1 must arrive to the FPGA at least 1.09 ns before the active edge of
CLK_1 and stay valid until at least 0.35 ns after the edge of CLK_1 to meet the setup and hold
requirements of the internal registers. Furthermore, INPUT_3 can even arrive up to 0.03 ns after the active
edge of INPUT_1 and still meet the setup time requirement of an internal register driven by the INPUT_1
(INPUT_1 is driving the clock port of this register). Figure 18 on page 13 represents the calculated values
for this example.
INPUT_1 INPUT_3
STABLE STABLE
CLK INPUT_1
Figure 18 • Graphical Interpretation of External Setup and Hold Time of the Report in Appendix A
Conclusion
Static timing analysis is the most accurate approach to analyze the timing performance of a design before
performing dynamic timing analysis through extensive testbenches. Timer, the static timing analysis tool
located in the Designer software, is user-interactive and allows users to apply timing constraints on their
design. Most of the required timing characteristics of a design are provided in Timer. However, the user
needs to combine his/her timing analysis skills with the knowledge of the tool to extract different timing
information, such as path delays, clock performance, external setup and hold time, and clock-to-out
timing of the design. Different features have been embedded in the Timer tool to help users access the
required information faster and more easily. Users needs to refer to the Designer software release notes
for the latest updates on the Timer tool. In sum, this document, combined with the Timer User’s Guide,
provides reference material for Actel static timing analysis.
List of Changes
Previous Version Changes in Current Version (51900002-1/01.04*) Page
51900002-0/10.02 The "Setup/Hold Time Calculation and Verification" section was updated. 5
* The part number is located on the last page of the document.
13
Static Timing Analysis Using Designer's Timer
Appendix A
Timer Version 01.01.01
Actel Corporation - Designer software Development System Release R2-2002 Development, ©1989-2002
Date: Wed Jun 12 18:07:06 2002
Design: F_M
Family: 54SXA
Die: A54SX32A
Package: 208 PQFP
Radiation Exposure: 0 KRad
Temperature: COM
Voltage: COM
Speed Grade: -3
Design State: Post-Layout
Timing: Worst Case
Path Tracing: Longest Paths
Break at Clk/G pins: True
Break at Preset/Clr pins: True
Break at Data pins of Latchs: True
Section Clock Frequency
Actual Required ClockName
323.52MHz N/A CLK_1
721.50MHz N/A CLK_2
End Section
Section $Inputs() to $Outputs()
Delay(ns) Slack(ns) Pins
3.65 N/A From: INPUT_1
To: OUTPUT_1
End Section
Section $Inputs() to $Registers(CLK_2):$DataPins()
Delay(ns) Slack(ns) Pins
0.80 N/A From: INPUT_2
To: REG1:D
End Section
Section $Inputs() to $Registers(CLK_2):$ClockPins()
Delay(ns) Slack(ns) Pins
2.39 N/A From: CLK_SEL
To: REG2:CLK
End Section
Section $Inputs() to $Registers(CLK_2):$AsyncPins()
--- No Paths found ---
End Section
Section $Registers(CLK_2):$InputPins() to $Outputs()
Delay(ns) Slack(ns) Pins
2.56 N/A From: REG2:CLK
To: OUTPUT2
14
Static Timing Analysis Using Designer's Timer
End Section
Section $Registers(CLK_2):$ClockPins() to
$Registers(CLK_2):$InputPins(TmacEX_ASYNCPINS)
Delay(ns) Slack(ns) Pins
0.69 N/A From: REG1:CLK
To: REG2:D
First Path Expansion from REG1:CLK to REG2:D
Total Delay Load Type Name
1.39 0.70 0 Setup
0.69 0.15 0 Net $1N98
REG2:D(R)
0.53 0.53 2 Cell ADLIB:DF1
REG1:Q(R)
0.00 0.00 0 Net $1N90
REG1:CLK(R)
End Section
Section $Registers(CLK_2):$ClockPins() to $Registers(CLK_2):$AsyncPins()
--- No Paths found ---
End Section
Section $Registers(CLK_2):$AsyncPins() to $Registers(CLK_2):$InputPins()
--- No Paths found ---
End Section
The following section is NOT breaking on Clk/G pins of registers
Section CLK_2 to $Outputs()
Delay(ns) Slack(ns) Pins
4.09 N/A From: CLK_2
To: OUTPUT2
First Path Expansion from CLK_2 to OUTPUT2
Total Delay Load Type Name
4.09 0.00 0 Net
OUTPUT2(F)
4.09 1.96 1 Cell ADLIB:OUTBUF
$1I93:PAD(F)
2.13 0.07 0 Net $1N100
$1I93:D(F)
2.06 0.53 1 Cell ADLIB:DF1
REG2:Q(F)
1.53 0.15 0 Net $1N90
REG2:CLK(R)
1.37 0.69 2 Cell ADLIB:MX2
$1I74:Y(R)
0.69 0.23 0 Net $1N77
$1I74:B(R)
0.46 0.46 1 Cell ADLIB:INBUF
$1I75:Y(R)
0.00 0.00 0 Net CLK_2
15
Static Timing Analysis Using Designer's Timer
$1I75:PAD(R)
0.00 0.00 0 Net
CLK_2(R)
End Section
Section $Inputs() to $Registers(CLK_1):$DataPins()
Delay(ns) Slack(ns) Pins
2.67 N/A From: INPUT_1
To: REG3:D
1.85 N/A From: INPUT_3
To: $1I2:D
End Section
Section $Inputs() to $Registers(CLK_1):$ClockPins()
Delay(ns) Slack(ns) Pins
2.42 N/A From: CLK_1
To: $1I1:CLK
End Section
Section $Inputs() to $Registers(CLK_1):$AsyncPins()
Delay(ns) Slack(ns) Pins
0.87 N/A From: RESET
To: $1I1:CLR
End Section
Section $Registers(CLK_1):$InputPins() to $Outputs()
Delay(ns) Slack(ns) Pins
3.34 N/A From: REG3:CLK
To: OUTPUT_1
End Section
Section $Registers(CLK_1):$ClockPins() to
$Registers(CLK_1):$InputPins(TmacEX_ASYNCPINS)
Delay(ns) Slack(ns) Pins
2.39 N/A From: $1I1:CLK
To: REG3:D
First Path Expansion from $1I1:CLK to REG3:D
Total Delay Load Type Name
3.09 0.70 0 Setup
2.39 0.00 0 Net $1N118
REG3:D(R)
2.39 0.69 1 Cell ADLIB:OR2
$1I119:Y(R)
1.70 0.38 0 Net $1N6
$1I119:B(R)
1.32 0.69 2 Cell ADLIB:XO1
$1I3:Y(R)
0.64 0.08 0 Net $1N4
$1I3:C(R)
0.56 0.56 1 Cell ADLIB:DFC1B
$1I1:Q(R)
16
Static Timing Analysis Using Designer's Timer
17
Static Timing Analysis Using Designer's Timer
To: CLK_1
-0.03 0.42 From: INPUT_3
To: INPUT_1
0.96 0.31 From: INPUT_3
To: CLK_1
-0.03 0.46 From: INPUT_2
To: CLK_2
End Section
18
Actel and the Actel logo are registered trademarks of Actel Corporation.
All other trademarks are the property of their owners.
http://www.actel.com
Actel Corporation Actel Europe Ltd. Actel Japan Actel Hong Kong
2061 Stierlin Court Dunlop House, Riverside Way EXOS Ebisu Bldg. 4F 39th Floor, One Pacific Place
Mountain View, CA Camberley, Surrey GU15 3YL 1-24-14 Ebisu Shibuya-ku 88 Queensway, Admiralty
94043-4655 USA United Kingdom Tokyo 150 Japan Hong Kong
Phone 650.318.4200 Phone +44 (0)1276.401450 Phone +81.03.3445.7671 Phone 852.227.35712
Fax 650.318.4600 Fax +44 (0)1276.401490 Fax +81.03.3445.7668 Fax 852.227.35999
51900002-1/01.04