# Timing Considerations with VHDL-Based Designs

This tutorial describes how Altera's Quartus<sup>(R)</sup> II software deals with the timing issues in designs based on the VHDL hardware description language. It discusses the various timing parameters and explains how specific timing constraints may be set by the user.

#### **Contents:**

Example Circuit Timing Analyzer Report Specifying the Timing Constraints Timing Simulation Quartus II software includes a Timing Analyzer module which performs a detailed analysis of all timing delays for a circuit that is compiled for implementation in an FPGA chip. This tutorial discusses the types of analyses performed and shows how particular timing requirements may be specified by the user. The discussion assumes that the reader is familiar with the basic operation of Quartus II software, as may be learned from an introductory tutorial.

Doing this tutorial, the reader will learn about:

- · Parameters evaluated by the Timing Analyzer
- · Specifying the desired values of timing parameters
- Using timing simulation

The timing results shown in the examples in this tutorial were obtained using Quartus II version 9.0, but other versions of the software can also be used.

#### **1** Example Circuit

Timing issues are most important in circuits that involve long paths through combinational logic elements with registers at inputs and outputs of these paths. As an example, we will use the adder/subtractor circuit shown in Figure 1. It can add, subtract, and accumulate *n*-bit numbers using the 2's complement number representation. The two primary inputs are numbers  $A = a_{n-1}a_{n-2}\cdots a_0$  and  $B = b_{n-1}b_{n-2}\cdots b_0$ , and the primary output is  $Z = z_{n-1}z_{n-2}\cdots z_0$ . Another input is the AddSub control signal which causes Z = A + B to be performed when AddSub = 0 and Z = A - B when AddSub = 1. A second control input, Sel, is used to select the accumulator mode of operation. If Sel = 0, the operation  $Z = A \pm B$  is performed, but if Sel = 1, then B is added to or subtracted from the current value of Z. If the addition or subtraction operations result in arithmetic overflow, an output signal, Overflow, is asserted.

To make it easier to deal with asynchronous input signals, they are loaded into flip-flops on a positive edge of the clock. Thus, inputs A and B will be loaded into registers *Areg* and *Breg*, while *Sel* and *AddSub* will be loaded into flip-flops *SelR* and *AddSubR*, respectively. The adder/subtractor circuit places the result into register *Zreg*.



Figure 1. The adder/subtractor circuit.

The required circuit is described by the VHDL code in Figure 2. For our example, we use a 16-bit circuit as specified by n = 16. Implement this circuit as follows:

- Create a project *addersubtractor*.
- Include a file *addersubtractor.vhd*, which corresponds to Figure 2, in the project. For convenience, this file is provided in the directory *DE1\_tutorials\design\_files*, which is included on the CD-ROM that accompanies the DE1 board and can also be found on Altera's DE1 web pages.
- Choose the Cyclone II EP2C20F484C7 device, which is the FPGA chip on Altera's DE1 board.
- Compile the design.

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;
-- Top-level module
ENTITY addersubtractor IS
   GENERIC (n : INTEGER := 16);
                                 : IN STD_LOGIC_VECTOR(n-1 DOWNTO 0);
   PORT (A, B
          Clock, Reset, Sel, AddSub : IN STD_LOGIC ;
          Ζ
                                : BUFFER STD_LOGIC_VECTOR(n-1 DOWNTO 0);
          Overflow
                                 : OUT STD_LOGIC);
END addersubtractor;
ARCHITECTURE Behavior OF addersubtractor IS
   SIGNAL G, H, M, Areg, Breg, Zreg, AddSubR n : STD LOGIC VECTOR(n-1 DOWNTO 0);
   SIGNAL SelR, AddSubR, carryout, over flow : STD LOGIC ;
   COMPONENT mux2to1
       GENERIC (k : INTEGER := 8);
       PORT (V, W : IN STD_LOGIC_VECTOR(k-1 DOWNTO 0);
              Selm : IN STD_LOGIC;
              F
                    : OUT STD_LOGIC_VECTOR(k-1 DOWNTO 0));
   END COMPONENT;
   COMPONENT adderk
       GENERIC (k : INTEGER := 8);
       PORT (carryin : IN STD_LOGIC;
              X, Y
                     : IN STD_LOGIC_VECTOR(k-1 DOWNTO 0);
              S
                     : OUT STD LOGIC VECTOR(k-1 DOWNTO 0);
              carryout : OUT STD_LOGIC);
   END COMPONENT;
BEGIN
   PROCESS (Reset, Clock)
   BEGIN
       IF Reset = '1' THEN
           Areg <= (OTHERS => '0'); Breg <= (OTHERS => '0');
           Zreg \le (OTHERS => '0'); SelR \le '0'; AddSubR \le '0'; Overflow \le '0';
       ELSIF Clock'EVENT AND Clock = '1' THEN
           Areg \leq = A; Breg \leq = B; Zreg \leq = M;
           SelR <= Sel; AddSubR <= AddSub; Overflow <= over_flow;
       END IF;
   END PROCESS :
   nbit_adder: adderk
       GENERIC MAP (k => n)
       PORT MAP (AddSubR, G, H, M, carryout);
   multiplexer: mux2to1
       GENERIC MAP (k => n)
       PORT MAP (Areg, Z, SelR, G);
   AddSubR_n \le (OTHERS \Longrightarrow AddSubR);
   H <= Breg XOR AddSubR_n;
   over_flow \leq carryout XOR G(n-1) XOR H(n-1) XOR M(n-1);
   Z \leq Zreg;
END Behavior:
\dots continued in Part b
```

```
Figure 2. VHDL code for the circuit in Figure 1 (Part a).
```

```
-- k-bit 2-to-1 multiplexer
LIBRARY ieee;
USE ieee.std_logic_1164.all;
ENTITY mux2to1 IS
    GENERIC ( k : INTEGER := 8 );
    PORT ( V, W : IN STD_LOGIC_VECTOR(k-1 DOWNTO 0);
           Selm : IN STD_LOGIC ;
           F
                : OUT STD_LOGIC_VECTOR(k-1 DOWNTO 0));
END mux2to1;
ARCHITECTURE Behavior OF mux2to1 IS
BEGIN
    PROCESS (V, W, Selm)
    BEGIN
       IF Selm = '0' THEN
           F \leq V;
       ELSE
           F \leq W:
       END IF;
    END PROCESS;
END Behavior;
-- k-bit adder
LIBRARY ieee ;
USE ieee.std logic 1164.all;
USE ieee.std_logic_signed.all;
ENTITY adderk IS
    GENERIC ( k : INTEGER := 8 );
    PORT ( carryin : IN STD_LOGIC ;
           X, Y
                 : IN STD_LOGIC_VECTOR(k-1 DOWNTO 0);
                  : OUT STD_LOGIC_VECTOR(k-1 DOWNTO 0);
           S
           carryout : OUT STD_LOGIC);
END adderk;
ARCHITECTURE Behavior OF adderk IS
    SIGNAL Sum : STD_LOGIC_VECTOR(k DOWNTO 0);
BEGIN
    Sum \leq ('0' \& X) + ('0' \& Y) + carryin;
    S \le Sum(k-1 DOWNTO 0);
   carryout <= Sum(k);
END Behavior;
```

Figure 2. VHDL code for the circuit in Figure 1 (Part b).

### 2 Timing Analyzer Report

Successful compilation of our circuit generates the Compilation Report in Figure 3. This report provides a lot of useful information. It shows the number of logic elements, flip-flops (called registers), and pins needed to implement the circuit. It gives detailed information produced by the Synthesis and Fitter modules. It also indicates the speed of the implemented circuit. A good measure of the speed is the maximum frequency at which the circuit

can be clocked, referred to as *fmax*. This measure depends on the longest delay along any path, called the *critical path*, between two registers clocked by the same clock. Quartus II software performs a timing analysis to determine the expected performance of the circuit. It evaluates several parameters, which are listed in the Timing Analyzer section of the Compilation Report. Click on the small + symbol next to Timing Analyzer to expand this section of the report, and then click on the Timing Analyzer item Summary which displays the table in Figure 4. The last entry in the table shows that the maximum frequency for our circuit implemented on the specified chip is 216.59 MHz. You may get a different value of *fmax*, dependent on the specific version of Quartus II software that you are using. To see the paths in the circuit that limit the *fmax*, click on the Timing Analyzer item Clock Setup: 'Clock' in Figure 4 to obtain the display in Figure 5. This table shows that the critical path begins at the flip-flop *SelR* and ends at the flip-flop *Overflow*.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Flow Summary                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Legal Notice</li> <li>Flow Summary</li> <li>Flow Subscript</li> <li>Flow Non-Default</li> <li>Flow Flow Edges</li> <li>Flow Cog</li> <li>Flow Cog<!--</td--><td>Flow Status<br/>Quartus II Version<br/>Revision Name<br/>Top-level Entity Name<br/>Family<br/>Device<br/>Timing Models<br/>Met timing requirements<br/>Total logic elements<br/>Total combinational functions<br/>Dedicated logic registers<br/>Total combinational functions<br/>Dedicated logic registers<br/>Total registers<br/>Total registers<br/>Total memory bits<br/>Embedded Multiplier 9-bit elements<br/>Total PLLs</td><td>Successful - Thu Apr 30 13:50:08 2009<br/>9.0 Build 132 02/25/2009 SJ Full Version<br/>addersubtractor<br/>ddersubtractor<br/>Cyclone II<br/>EP2C20F484C7<br/>Final<br/>Yes<br/>52 / 18,752 (&lt; 1 % )<br/>51 / 18,752 (&lt; 1 % )<br/>51 / 18,752 (&lt; 1 % )<br/>51 / 18,752 (&lt; 1 % )<br/>51<br/>53 / 315 (17 % )<br/>0<br/>0 / 239,616 (0 % )<br/>0 / 52 (0 % )<br/>0 / 4 (0 % )</td></li></ul> | Flow Status<br>Quartus II Version<br>Revision Name<br>Top-level Entity Name<br>Family<br>Device<br>Timing Models<br>Met timing requirements<br>Total logic elements<br>Total combinational functions<br>Dedicated logic registers<br>Total combinational functions<br>Dedicated logic registers<br>Total registers<br>Total registers<br>Total memory bits<br>Embedded Multiplier 9-bit elements<br>Total PLLs | Successful - Thu Apr 30 13:50:08 2009<br>9.0 Build 132 02/25/2009 SJ Full Version<br>addersubtractor<br>ddersubtractor<br>Cyclone II<br>EP2C20F484C7<br>Final<br>Yes<br>52 / 18,752 (< 1 % )<br>51 / 18,752 (< 1 % )<br>51 / 18,752 (< 1 % )<br>51 / 18,752 (< 1 % )<br>51<br>53 / 315 (17 % )<br>0<br>0 / 239,616 (0 % )<br>0 / 52 (0 % )<br>0 / 4 (0 % ) |
| <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                            |

Figure 3. The Compilation Report.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Ti | ming Analyzer Summary        |       |                  |                                 |         |               |               |             |                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------------------------------|-------|------------------|---------------------------------|---------|---------------|---------------|-------------|-----------------|
| - 🚑 🖹 Legal Notice<br>- 🎒 📑 Flow Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    | Туре                         | Slack | Required<br>Time | Actual<br>Time                  | From    | To            | From<br>Clock | To<br>Clock | Failed<br>Paths |
| - 🚑 🎹 Flow Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1  | Worst-case tsu               | N/A   | None             | 4.565 ns                        | A[5]    | Areg[5]       |               | Clock       | 0               |
| - 🚑 🎹 Flow Non-Default                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 2  | Worst-case tco               | N/A   | None             | 8.251 ns                        | Zreg[1] | Z[1]          | Clock         |             | 0               |
| Flow Elapsed Tim                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 3  | Worst-case th                | N/A   | None             | -2.987 ns                       | B[7]    | Breg[7]       |               | Clock       | 0               |
| Flow OS Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 4  | Clock Setup: 'Clock'         | N/A   | None             | 216.59 MHz (period = 4.617 ns ) | SelR    | Overflow~reg0 | Clock         | Clock       | 0               |
| 🖅 🚑 🖹 Flow Log<br>🖅 🚑 🦳 Analysis & Synthe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 5  | Total number of failed paths |       |                  |                                 |         |               |               |             | 0               |
| Get Setting:     G |    |                              |       |                  |                                 |         |               |               |             |                 |
| <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <  |                              |       |                  | iiii                            |         |               |               |             | ))              |

Figure 4. The Timing Analyzer Summary.

|                                              | Cloc | k Setup: 'Clock' |                                 |          |               |               |             |                                |                              |              |
|----------------------------------------------|------|------------------|---------------------------------|----------|---------------|---------------|-------------|--------------------------------|------------------------------|--------------|
| - 🚑 🖹 Legal Notice<br>- 🎒 📰 Flow Summary     |      | Slack            | Actual fmax<br>(period)         | From     | To            | From<br>Clock | To<br>Clock | Required Setup<br>Relationship | Required Longest<br>P2P Time | Acl ^<br>P2l |
| - 🗃 🎹 Flow Settings                          | 1    | N/A              | 216.59 MHz (period = 4.617 ns ) | SelR     | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.3          |
| - 🚰 🎹 Flow Non-Default Global Se             | 2    | N/A              | 219.59 MHz (period = 4.554 ns ) | AddSubR  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.3          |
| Flow Elapsed Time                            | 3    | N/A              | 220.85 MHz (period = 4.528 ns ) | Zreg[5]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.2          |
| Flow OS Summary                              | 4    | N/A              | 225.94 MHz (period = 4.426 ns ) | Zreg[6]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.1          |
| - 🗃 🖹 Flow Log<br>- 🚔 🦳 Analysis & Synthesis | 5    | N/A              | 227.74 MHz (period = 4.391 ns ) | Zreg[13] | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.1          |
| Analysis & Synthesis     Fitter              | 6    | N/A              | 229.62 MHz (period = 4.355 ns ) | Zreg[14] | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.1          |
| Assembler                                    | 7    | N/A              | 230.36 MHz (period = 4.341 ns ) | Zreg[0]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.1          |
|                                              | 8    | N/A              | 231.86 MHz (period = 4.313 ns ) | Zreg[7]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.0          |
| Summary                                      | 9    | N/A              | 235.24 MHz (period = 4.251 ns ) | Zreg[4]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.0          |
| Settings                                     | 10   | N/A              | 236.41 MHz (period = 4.230 ns ) | Zreg[2]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 4.0          |
| Clock Settings Summar                        | 11   | N/A              | 238.27 MHz (period = 4.197 ns ) | Breg[0]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 3.9          |
| Parallel Compilation                         | 12   | N/A              | 239.29 MHz (period = 4.179 ns ) | Zreg[12] | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 3.9          |
| Clock Setup: 'Clock'                         | 13   | N/A              | 244.20 MHz (period = 4.095 ns ) | Zreg[1]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 3.8          |
|                                              | 14   | N/A              | 250.00 MHz (period = 4.000 ns ) | Breg[2]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 3.7          |
| - 🚔 🖪 th                                     | 15   | N/A              | 254.39 MHz (period = 3.931 ns ) | Zreg[3]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 3.7          |
| A Messages                                   | 16   | N/A              | 254.58 MHz (period = 3.928 ns ) | Areg[0]  | Overflow~reg0 | Clock         | Clock       | None                           | None                         | 3.6          |
| <b>G</b> (2) (1) (2)                         | 17   | N/A              | 255.10 MHz (period = 3.920 ns ) | Breg[3]  | Overflow~reg0 |               | Clock       | None                           | None                         | 3.6          |
|                                              | 18   | N/A              | 256.54 MHz (period = 3.898 ns ) | Areg[1]  | Overflow~reg0 |               | Clock       | None                           | None                         | 3.6 🗸        |
|                                              | <    |                  |                                 |          |               |               |             |                                |                              | >            |
| or Help, press F1                            |      |                  |                                 |          |               |               |             |                                | NUM                          |              |

Figure 5. Critical paths.

The table in Figure 4 also shows other timing results. While *fmax* is a function of the longest propagation delay between two registers in the circuit, it does not indicate the delays with which output signals appear at the pins of the chip. The time elapsed from an active edge of the clock signal at the clock source until a corresponding output signal is produced (from a flip-flop) at an output pin is denoted as the *tco* delay at that pin. In the worst case, the *tco* in our circuit is 8.251 ns. Click on tco in the Timing Analyzer section to view the table given in Figure 6. The first entry in the table shows that it takes 8.251 ns from when an active clock edge occurs until a signal propagates from bit 1 in register *Zreg* to the output pin  $z_1$ . The other two parameters given in Figure 4 are setup time, *tsu*, and hold time, *th*.

| Compilation Report                           | tco |       |              |               |               |          |               |
|----------------------------------------------|-----|-------|--------------|---------------|---------------|----------|---------------|
| - 🚰 🖹 Legal Notice<br>- 🎒 🛅 Flow Summary     |     | Slack | Required tco | Actual<br>tco | From          | To       | From<br>Clock |
| Flow Settings                                | 1   | N/A   | None         | 8.251 ns      | Zreg[1]       | Z[1]     | Clock         |
| - 🚑 🎹 Flow Non-Default Global Se             | 2   | N/A   | None         | 8.136 ns      | Zreg[7]       | Z[7]     | Clock         |
| Flow Elapsed Time                            | 3   | N/A   | None         | 7.732 ns      | Zreg[10]      | Z[10]    | Clock         |
| Flow OS Summary                              | 4   | N/A   | None         | 7.555 ns      | Zreg[6]       | Z[6]     | Clock         |
| - 🚑 🖹 Flow Log<br>🗉 🚑 🧰 Analysis & Synthesis | 5   | N/A   | None         | 7.445 ns      | Zreg[3]       | Z[3]     | Clock         |
| + A Fitter                                   | 6   | N/A   | None         | 7.285 ns      | Zreg[13]      | Z[13]    | Clock         |
| + Assembler                                  | 7   | N/A   | None         | 7.273 ns      | Zreg[11]      | Z[11]    | Clock         |
| 🗉 🚑 🔄 Timing Analyzer                        | 8   | N/A   | None         | 7.166 ns      | Zreg[15]      | Z[15]    | Clock         |
| Summary                                      | 9   | N/A   | None         | 7.163 ns      | Zreg[14]      | Z[14]    | Clock         |
| - 🚑 🎹 Settings                               | 10  | N/A   | None         | 7.148 ns      | Zreg[0]       | Z[0]     | Clock         |
| Clock Settings Summar                        | 11  | N/A   | None         | 7.134 ns      | Zreg[9]       | Z[9]     | Clock         |
| Parallel Compilation                         | 12  | N/A   | None         | 7.134 ns      | Zreg[2]       | Z[2]     | Clock         |
| - 👍 🔣 Clock Setup: 'Clock'<br>- 🚑 🐯 tsu      | 13  | N/A   | None         | 7.130 ns      | Zreg[5]       | Z[5]     | Clock         |
|                                              | 14  | N/A   | None         | 7.127 ns      | Zreg[12]      | Z[12]    | Clock         |
| and th                                       | 15  | N/A   | None         | 7.117 ns      | Zreg[8]       | Z[8]     | Clock         |
| () Messages                                  | 16  | N/A   | None         | 6.802 ns      | Zreg[4]       | Z[4]     | Clock         |
|                                              | 17  | N/A   | None         | 6.791 ns      | Overflow~reg0 | Overflow | Clock         |

Figure 6. The tco delays.

## **3** Specifying Timing Constraints

So far we have compiled our VHDL code without indicating to the Quartus II software the required speed performance of the circuit. It is possible to specify certain timing constraints that should be met. For example, suppose that we want our example circuit to operate at a clock frequency of at least 220 MHz. To see if this can be achieved we can set the *fmax* constraint as follows:

1. Select Assignments > Timing Analysis Settings > Classic Timing Analyzer Settings to reach the

window in Figure 7. In this window it is possible to specify the requirements for a number of different parameters.

- 2. In the box Clock Settings specify that the required value of *fmax* is 220 MHz. Click OK.
- 3. Recompile the circuit.
- 4. Open the Timing Analyzer Summary to see that the new *fmax* is 220.60 MHz, as indicated in Figure 8. You may get a slightly different result depending on the version of the Quartus II software used.

| Settings - addersubtractor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <ul> <li>Files</li> <li>Libraries</li> <li>Device</li> <li>Compilation Process Settings</li> <li>EDA Tool Settings</li> <li>Filter Settings</li> <li>Timing Analysis &amp; Synthesis Settings</li> <li>Filter Settings</li> <li>Timing Analysis Settings</li> <li>Classic Timing Analyzer Settings</li> <li>Classic Timing Analyzer Repor</li> <li>Assembler</li> <li>Design Assistant</li> <li>SignalT ap II Logic Analyzer</li> <li>Logic Analyzer Interface</li> <li>Simulator Settings</li> <li>PowerRay Power Analyzer Settings</li> <li>SSN Analyzer</li> </ul> | sesic Timing Analyzer Settings         pecify settings for the Classic Timing Analyzer. Use the Assignment Editor for individual timing signments. Note: These settings affect the Classic Timing Analyzer only. To specify TimeQuest ming Analyzer settings, use the TimeQuest Timing Analyzer (Timing Analyzer Settings menu).         Delay requirements         tgg       ns         tgg       ns         tgg       ns         tgg       ns         tgg       ns         Use the quirements       Minimum delay requirements         tgg       ns         Use the quire dimax       220         More Settings         More Settings         escription:         ippedies the minimum acceptable clock frequency, that is, the maximum clock frequency that analysed without violating internal setup and hold time requirements. |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | OK Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Figure 7. Specify the timing constraints in the Settings window.

|                                                                                                         | Tir | ming Analyzer Summary        |          |                                 |                                  |         |          |               |             |        |
|---------------------------------------------------------------------------------------------------------|-----|------------------------------|----------|---------------------------------|----------------------------------|---------|----------|---------------|-------------|--------|
| Legal Notice                                                                                            | Π   | Туре                         | Slack    | Required<br>Time                | Actual<br>Time                   | From    | То       | From<br>Clock | To<br>Clock | Failed |
| Flow Settings                                                                                           | 1   | Worst-case tsu               | N/A      | None                            | 4.793 ns                         | B[4]    | Breg[4]  |               |             | 0      |
| Flow Non-Default Globa                                                                                  | 2   | Worst-case tco               | N/A      | None                            | 7.401 ns                         | Zreg[2] | Z[2]     | Clock         |             | 0      |
| - Flow Elapsed Time                                                                                     | 3   | Worst-case th                | N/A      | None                            | -3.006 ns                        | A[2]    | Areg[2]  |               | Clock       | 0      |
| Flow OS Summary                                                                                         | 4   | Clock Setup: 'Clock'         | 0.012 ns | 220.02 MHz (period = 4.545 ns ) | 220.60 MHz ( period = 4.533 ns ) |         |          | Clock         | Clock       | 0      |
| 🚽 🖹 Flow Log                                                                                            | 5   | Clock Hold: 'Clock'          |          | 220.02 MHz (period = 4.545 ns ) |                                  |         | Zreg[10] | Clock         | Clock       | 0      |
| Generation Analysis & Synthesis     Generation Analysis & Synthesis     Generation Analysis & Synthesis | 6   | Total number of failed paths |          | ,                               |                                  |         |          |               |             | 0      |
| • Assembler                                                                                             | П   |                              |          |                                 |                                  |         |          |               |             |        |
| 🗄 🚟 🔄 Timing Analyzer                                                                                   |     |                              |          |                                 |                                  |         |          |               |             |        |
| Summary                                                                                                 |     |                              |          |                                 |                                  |         |          |               |             |        |
| Gettings                                                                                                |     |                              |          |                                 |                                  |         |          |               |             |        |
| - 🖓 🎹 Clock Settings Sum                                                                                |     |                              |          |                                 |                                  |         |          |               |             |        |
| Parallel Compilation                                                                                    |     |                              |          |                                 |                                  |         |          |               |             |        |
| - 🚑 🔣 Clock Setup: 'Clock'                                                                              |     |                              |          |                                 |                                  |         |          |               |             |        |
| – 🚑 📆 Clock Hold: 'Clock' 😒                                                                             |     |                              |          |                                 |                                  |         |          |               |             |        |
| < >                                                                                                     | <   |                              |          |                                 |                                  |         |          |               |             | >      |

Figure 8. New timing results.

If the specified constraint is too high, the Quartus II compiler will not be able to satisfy it. For example, set the *fmax* constraint to 300 MHz and recompile the circuit. Now, the Timing Analyzer Summary will show that this

constraint cannot be met, as seen in Figure 9.

| 🗃 🖹 Legal Notice 👘                           |   | Туре                         | Slack     | Required                         | Actual                           | From     | To            | From  | To    | Failed |
|----------------------------------------------|---|------------------------------|-----------|----------------------------------|----------------------------------|----------|---------------|-------|-------|--------|
| - 🚭 🛅 Flow Summary                           | Ц | Туре                         | SIGCK     | Time                             | Time                             | FIUII    | 10            | Clock | Clock | Paths  |
| Flow Settings                                | 1 | Worst-case tsu               | N/A       | None                             | 4.793 ns                         | B[4]     | Breg[4]       |       | Clock | 0      |
| 🗃 📰 Flow Non-Default Globa                   | 2 | Worst-case tco               | N/A       | None                             | 7.401 ns                         | Zreg[2]  | Z[2]          | Clock |       | 0      |
| Flow Elapsed Time                            | 3 | Worst-case th                | N/A       | None                             | -3.006 ns                        | A[2]     | Areg[2]       |       | Clock | 0      |
| Flow OS Summary                              | 4 | Clock Setup: 'Clock'         | -1.200 ns | 300.03 MHz ( period = 3.333 ns ) | 220.60 MHz ( period = 4.533 ns ) | Zreg[0]  | Overflow~reg0 | Clock | Clock | 67     |
| - 🚑 🖹 Flow Log<br>- 🎒 📄 Analysis & Synthesis | 5 | Clock Hold: 'Clock'          | 1.257 ns  | 300.03 MHz ( period = 3.333 ns ) | N/A                              | Breg[10] | Zreg[10]      | Clock | Clock | 0      |
| Fitter                                       | 6 | Total number of failed paths |           |                                  |                                  |          |               |       |       | 67     |
| Assembler                                    |   |                              |           |                                  |                                  |          |               |       |       |        |
| - 🚑 🔁 Timing Analyzer                        |   |                              |           |                                  |                                  |          |               |       |       |        |
| Summary                                      |   |                              |           |                                  |                                  |          |               |       |       |        |
|                                              |   |                              |           |                                  |                                  |          |               |       |       |        |
| - 🚑 🎹 Clock Settings Sumi                    |   |                              |           |                                  |                                  |          |               |       |       |        |
| Parallel Compilation                         |   |                              |           |                                  |                                  |          |               |       |       |        |
| - A Clock Setup: 'Clock'                     |   |                              |           |                                  |                                  |          |               |       |       |        |
| - 🚑 🖪 Clock Hold: 'Clock' 🔽                  |   |                              |           |                                  |                                  |          |               |       |       |        |
|                                              |   |                              |           |                                  |                                  |          |               |       |       |        |

Figure 9. The timing constraint cannot be met.

The specified *fmax* of 300 MHz cannot be achieved because one or more paths in the circuit have long propagation delays. To locate the most critical path highlight the Clock Setup entry in the table by clicking on it. Then, right-click to get the pop-up menu shown in Figure 10. Select Locate > Locate in RTL Viewer which will cause the RTL Viewer to display the critical path as presented in Figure 11. Note that this path begins at bit 0 in register *Zreg* and ends at the *Overflow* flip-flop.

| Galaction Report                 | Ti | ming Analyze   | r Summary    |           |               |              |       |                                     |            |            |       |       |
|----------------------------------|----|----------------|--------------|-----------|---------------|--------------|-------|-------------------------------------|------------|------------|-------|-------|
| 🚑 🖹 Legal Notice                 | Γ  | Туре           |              | Slack     | Required      |              |       | Actual                              | From       | To         | From  | To    |
| - 🚑 🔲 Flow Summary               |    | 100.00         |              |           | Time          |              | Time  |                                     |            |            | Clock | Clock |
| - Flow Settings                  | 1  | Worst-case ts  | u            | N/A       | None          |              |       | 4.793 ns                            | B[4]       | Breg[4]    |       | Clock |
| Flow Non-Default Global Settings | 2  | Worst-case to  | 0            | N/A       | None          |              |       | 7.401 ns                            | Zreg[2]    | Z[2]       | Clock |       |
| - 🗃 🎹 Flow Elapsed Time          | 3  | Worst-case th  |              | N/A       | None          |              |       | -3.006 ns                           | A[2]       | Areg[2]    |       | Clock |
| - 🚰 🎹 Flow OS Summary            | 4  | Clock Setup: 1 | Clock'       | -1 200 m  | 300.03 MHz (  | neriod = 3.3 | 33 ns | ) 220.60 MHz ( period = 4.533 ns )  |            |            | Clock | Clock |
| - 😂 🖹 Flow Log                   | 5  | Clock Hold: 'C |              |           |               |              |       | ) N/A                               |            | Zreg[10]   | Clock | Clock |
| 🗄 🎒 Analysis & Synthesis         |    |                | Select All   |           |               | Ctrl+A       | 5115  | JIWA                                | bieg[10]   | j zieg[10] | CIUCK | CIUCK |
| 🛨 🎒 🧰 Fitter                     | 6  | Total number   |              |           |               | carrie       | ⊢     |                                     |            |            |       |       |
| 🗈 🎒 🚞 Assembler                  |    |                | 🖌 Align Left |           |               |              | I     |                                     |            |            |       |       |
| 🖻 🎒 Timing Analyzer              |    |                | Align Righ   | t         |               |              | I     |                                     |            |            |       |       |
| Summary                          |    |                |              |           |               |              | I     |                                     |            |            |       |       |
| - 🚑 🎹 Settings                   |    |                | List Paths   |           |               |              | I     |                                     |            |            |       |       |
| - 🗃 🛄 Clock Settings Summary     |    |                | Advanced     | List Path | s             |              |       |                                     |            |            |       |       |
| Parallel Compilation             |    |                | Locate •     |           |               |              | Lo    | cate in Assignment Editor           |            |            |       |       |
| Clock Setup: 'Clock'             |    |                |              |           |               |              | Lo    | cate in Pin Planner                 |            |            |       |       |
| Clock Hold: 'Clock'              |    |                | Timing Set   | ttings    |               |              | Lo    | cate in Timing Closure Floorplan    |            |            |       |       |
| tsu                              |    |                | Save Curr    | ent Reno  | rt Section As |              | Lo    | cate in Chip Planner (Floorplan & O | hip Editor | 0          |       |       |
| - 🚑 🔣 tco                        |    |                | Saro can     | onenopo   |               |              |       | cate in Resource Property Editor    |            | ~          |       |       |
| - 🚑 🐯 th<br>- 🚑 🌒 Messages       |    |                |              |           |               |              |       | cate in Technology Map Viewer       |            |            |       |       |
| Messages                         |    |                |              |           |               |              |       | cate in RTL Viewer                  |            |            |       |       |
|                                  |    |                |              |           |               | 1            | Lo    | cate in Design File                 |            |            |       |       |
|                                  |    |                |              |           |               | L            | _     |                                     |            |            |       |       |
|                                  |    |                |              |           |               |              |       |                                     |            |            |       |       |
|                                  |    |                |              |           |               |              |       |                                     |            |            |       |       |
|                                  |    |                |              |           |               |              |       |                                     |            |            |       |       |
|                                  | <  |                |              |           |               |              |       |                                     |            |            |       | >     |

Figure 10. Locate the critical path.



Figure 11. Path for which the timing constraint cannot be met.

It is likely that there are other paths that make it impossible to meet the specified constraint. To identify these paths choose Clock Setup: 'Clock' on the left side of the Compilation Report in Figure 9. As seen in Figure 12, there are 67 paths with propagation delays that are too long. Observe a column labeled Slack. The term *slack* is used to indicate the margin by which a timing requirement is met or not met. In the top row in Figure 12 we see that the timing delay along the path from bit 0 in register *Zreg* flip-flop to the *Overflow* flip-flop is 1.200 ns longer than the maximum of 3.33 ns that is the period of the 300-MHz clock specified as the *fmax* constraint.

| <u>File Edit View Tools Window</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                   |                                                                      |           |               |               |             |                                |             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------------|----------------------------------------------------------------------|-----------|---------------|---------------|-------------|--------------------------------|-------------|
| 🗃 🔄 Compilation Report                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Cloc | k Setup: 'C       | lock'                                                                |           |               |               |             |                                |             |
| - 😂 🖹 Legal Notice<br>- 😂 📑 Flow Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      | Slack             | Actual fmax<br>(period)                                              | From      | То            | From<br>Clock | To<br>Clock | Required Setup<br>Relationship | Re ^<br>P2I |
| - Flow Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1    | -1.200 ns         | 220.60 MHz ( period = 4.533 ns )                                     | Zreg[0]   | Overflow~reg0 | Clock         | Clock       | 3.333 ns                       | 3.0         |
| Flow Non-Default Global Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2    | -1.129 ns         | 224.11 MHz ( period = 4.462 ns )                                     | AddSubR   | Overflow~reg0 | Clock         | Clock       | 3.333 ns                       | 3.0         |
| Flow Elapsed Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3    | -1.116 ns         | 224.77 MHz (period = 4.449 ns)                                       | Zreg[1]   | Overflow~reg0 | Clock         | Clock       | 3.333 ns                       | 3.0         |
| Flow OS Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 4    | -1.112 ns         | 224.97 MHz (period = 4.445 ns )                                      | SelR      | Overflow~reg0 | Clock         | Clock       | 3.333 ns                       | 3.0         |
| B Flow Log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5    | -1.078 ns         | 226.71 MHz (period = 4.411 ns )                                      | Zreg[2]   | Overflow~reg0 | Clock         | Clock       | 3.333 ns                       | 3.0         |
| 🗄 🚭 🧰 Analysis & Synthesis<br>🗄 🚭 🧰 Fitter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 6    | -1.048 ns         | 228.26 MHz ( period = 4.381 ns )                                     | Zreg[7]   | Overflow~reg0 | Clock         | Clock       | 3.333 ns                       | 3.0         |
| Assembler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 7    | -0.907 ns         |                                                                      | Zreg[3]   | Overflow~reg0 | Clock         | Clock       | 3.333 ns                       | 3.0         |
| Analyzer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 8    |                   | 237.42 MHz (period = 4.212 ns )                                      | Zreg[4]   | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
| Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 9    | -0.818 ns         | 240.91 MHz (period = 4.151 ns )                                      | Zreg[6]   | Overflow~reg0 | Clock         | Clock       | 3.333 ns                       | 3.0         |
| - Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 10   |                   | 245.28 MHz (period = 4.077 ns )                                      | Zreg[5]   | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
| - 🗃 🎹 Clock Settings Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 11   |                   | 247.04 MHz (period = 4.048 ns )                                      | Breg[1]   | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
| Parallel Compilation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 12   |                   | 248.32 MHz (period = 4.027 ns )                                      | Breg[2]   | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
| Clock Setup: 'Clock'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 13   | -0.662 ns         |                                                                      | Breg[0]   | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
| Clock Hold: 'Clock'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 14   | 17.18 ACC 10.17.1 | 250.82 MHz (period = 3.987 ns )                                      | Breg[3]   | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
| - 🚑 🖪 tsu<br>- 🚑 🖪 tco                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 15   |                   | 252.84 MHz (period = 3.955 ns )                                      | Areg[0]   | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
| and the second s | 16   |                   | 253.87 MHz (period = 3.939 ns )                                      | Zreg[12]  | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
| A Messages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 17   |                   | 255.49 MHz (period = 3.914 ns )                                      | Areg[1]   | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
| E C Mossages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 18   |                   | 256.08 MHz (period = 3.905 ns )                                      | Breg[4]   | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 19   |                   |                                                                      | Zreg[13]  | Overflow~reg0 |               | Clock       | 3.333 ns                       | 3.0         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 20   |                   |                                                                      | Area[2]   | Overflow regu |               | Clock       | 3.333 ns                       | 3.0         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 20   |                   | 260.62 MHz ( period = 3.634 hs )<br>261.30 MHz ( period = 3.827 pc ) |           | Overflow~reg0 |               | Clock       | 3.333 no                       | 3.0         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <    | a ar and the      |                                                                      | in radiat | Troaman Tani  | in more       | in mer      |                                | >           |

Figure 12. The longest delay paths.

We have shown how to set the *fmax* constraint. The other constraints depicted in the window in Figure 7 can be set in the same way.

### 4 Timing Simulation

Timing simulation provides a graphical indication of the delays in the implemented circuit, as can be observed from the displayed waveforms. For a discussion of simulation see the tutorial *Quartus II Simulation with VHDL Designs*, which uses the same *addersubtractor* circuit as an example.

Copyright ©2009 Altera Corporation. All rights reserved. Altera, The Programmable Solutions Company, the stylized Altera logo, specific device designations, and all other words and logos that are identified as trademarks and/or service marks are, unless noted otherwise, the trademarks and service marks of Altera Corporation in the U.S. and other countries. All other product or service names are the property of their respective holders. Altera products are protected under numerous U.S. and foreign patents and pending applications, mask work rights, and copyrights. Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera Corporation. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

This document is being provided on an "as-is" basis and as an accommodation and therefore all warranties, representations or guarantees of any kind (whether express, implied or statutory) including, without limitation, warranties of merchantability, non-infringement, or fitness for a particular purpose, are specifically disclaimed.