

# **TUTORIAL 2—IMPLEMENTING CIRCUITS IN ALTERA DEVICES**

In this tutorial we describe how to use the physical design tools in Quartus II. In addition to the modules used in Tutorial 1, the following Quartus II modules are introduced: Fitter, Floorplan Editor, and Timing Analyzer. To illustrate the procedures involved, we will first implement the *example\_verilog* project created in Tutorial 1 in a Cyclone II FPGA.

# **C.1** IMPLEMENTING A CIRCUIT IN A CYCLONE II FPGA

Select File > Open Project and browse to the directory *designstyle2*, which contains the Verilog design example used in Tutorial 1. As depicted in Figure C.1, select the *example\_verilog* project (Quartus II project files have the filename extension .*qpf*) and click Open.

### C.1.1 SELECTING A CHIP

In Tutorial 1 we used the Compiler to perform the synthesis operations, which generated the information needed for functional simulation. Now, we will implement the design in an FPGA and then use timing simulation.

To specify which chip to use, select Assignments > Device to open the window shown in Figure C.2. Click on the pull-down menu in the box labeled Family and select Cyclone II. Note that in some cases Quartus II will display the message "Device family selection has changed. Do you want to remove all pin assignments?" Click Yes to close this pop-up box.

In the Target device box you can specify that Quartus II should automatically select a device during compilation. The ability to have a chip chosen automatically is sometimes convenient for the designer. However, in this case we wish to select a specific chip, so click on Specific device selected in 'Available devices' list.

The various chips in the Cyclone II family are displayed in the box labeled Available devices. One available chip is the EP2C35F672C6 (if this device is not listed, change the Speed Grade item in the Filter box to Any). The meaning of the chip name is as follows: The EP2C means that the chip is a member of the Cyclone II family, and the 35 gives

#### **APPENDIX C** • TUTORIAL 2–IMPLEMENTING CIRCUITS IN ALTERA DEVICES

| Open Project                      |                    |                      |                      |            | ×      |
|-----------------------------------|--------------------|----------------------|----------------------|------------|--------|
| Look in                           | : 🗀 designstyle2   | !                    | •                    | + 1 +      |        |
| My Recent<br>Documents<br>Desktop | db<br>example_veri | log.qpf              |                      |            |        |
| My Documents                      |                    |                      |                      |            |        |
| My Computer                       |                    |                      |                      |            |        |
| My Network                        | File name:         | example_verilog.qp   | ıf                   | •          | Open   |
| Places                            | Files of type:     | Quartus II Project F | file (*.qpf;*.quartu | s;*.qar) 💌 | Cancel |

Figure C.1 Opening the *example\_verilog* project.

an indication of the number of logic elements in the chip. The designator F672 indicates a Fineline 672-pin ball grid array package; we describe package types in section 3.6.3. The C6 gives the *speed grade*. We discuss speed grades in Appendix E. As indicated in Figure C.2, choose the EP2C35F672C6 device, and then click OK to close the Settings window. We have chosen this chip because it is provided on an Altera development board that is discussed in Appendix D.

### **C.1.2 COMPILING THE PROJECT**

In Appendix B we ran just the synthesis tools in Quartus II, by using the command Processing > Start > Start Analysis & Synthesis. Now, we wish to run in sequence the four modules in the Quartus II software that we showed in Figure B.16: Synthesis, Fitter, Assembler, and Timing Analyzer. Before invoking these tools, open the menu under Tools > Options and then in the category General > Processing click to select Automatically generate equation files during compilation. This setting causes the Quartus II Compiler to record in its Report File the logic expressions generated during the compilation process.

To invoke the tools, select Processing > Start Compilation, or use the toolbar icon that looks like a solid purple triangle. As we saw in Tutorial 1, the compilation progress through each Quartus II module is displayed in the Status window on the left side of the Quartus II display. After the Analysis & Synthesis module converts the Verilog code into a circuit that comprises Cyclone II logic elements, the Fitter module chooses locations on the

### **C.1** IMPLEMENTING A CIRCUIT IN A CYCLONE II FPGA

857

| Files                                                                                                                                                                                         |                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |              |          |                                             |              |                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------|---------------------------------------------|--------------|-----------------|
| - User Libraries (Current Project)<br>- Device<br>- Timing Analysis Settings<br>- EDA Tool Settings<br>- Compilation Process Settings<br>- Analysis & Synthesis Settings<br>- Fitter Settings | Select the family and device<br>Family: Cyclone II<br>Device & Pin Options                                                                                                  | -Show in 'Avail<br>Package:<br>Pin count:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Any<br>Any   | s' list  |                                             |              |                 |
| – Assembler<br>– Design Assistant<br>– SignalT ap II Logic Analyzer<br>– Logic Analyzer Interface<br>– SignalProbe Settings<br>– Simulator Settings                                           | C Auto device selected t<br>Specific device select<br>C Other: n/a<br>Available devices:                                                                                    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ble devices' | list     | Speed grade:<br>Core voltage:<br>I Show adv | 1.2V         | <b>▼</b><br>ces |
| - PowerPlay Power Analyzer Settings                                                                                                                                                           | Name                                                                                                                                                                        | LEs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Memor        | Embed    | PLL                                         |              |                 |
| n owen ay rower Anayzer Setungs                                                                                                                                                               | EP2C35F484C6<br>EP2C35F484C7<br>EP2C35F484C8<br>EP2C35F4848<br>EP2C35F672C6<br>EP2C35F672C7<br>EP2C35F672C8<br>EP2C35F672C8<br>EP2C35F67218<br>EP2C35U484C6<br>EP2C35U484C7 | EP2C35F484C7         33216         483840         70           EP2C35F484C8         33216         483840         70           EP2C35F4848         33216         483840         70           EP2C35F672C6         38216         433840         70           EP2C35F672C7         33216         483840         70           EP2C35F672C8         33216         483840         70           EP2C35F672C8         33216         483840         70           EP2C35F672C8         33216         483840         70           EP2C35F672B         33216         483840         70           EP2C35F672B         33216         483840         70           EP2C35F672B         33216         483840         70           EP2C35F672B         33216         483840         70           EP2C35U484C6         33216         483840         70 |              |          |                                             |              |                 |
|                                                                                                                                                                                               | Migration compatibility                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | - Companion  | device—  |                                             |              |                 |
|                                                                                                                                                                                               | Migration Devices                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | HardCopy I   | 1:       |                                             |              | 7               |
|                                                                                                                                                                                               | 0 migration devices selec                                                                                                                                                   | ted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 🔽 Limit D    | SP & RAM | to HardCopy II o                            | levice resou | irces           |

Figure C.2 Selecting a Cyclone II device.

FPGA chip for these logic elements. A detailed discussion of the CAD modules is provided in Chapter 12.

When compilation is finished, the compilation report displayed in Figure C.3 is produced. Click on the small + symbol to expand the Fitter section of the report, and then click on the Equations section to reach the display in Figure C.4. Scroll through this part of the report to see the logic expressions implemented by our circuit. At the bottom of the report the output f is given as

### f = OUTPUT(A1L2);

This means that *f* appears on an output pin, and that output is defined by the logic expression called A1L2, which is realized as indicated near the top of the Fitter Equations section in Figure C.4. This expression properly implements our logic function  $f = x_1x_2 + \overline{x}_2x_3$ . Note that the # symbol is used by Quartus II to denote the OR operator.

#### **APPENDIX C** • TUTORIAL 2–IMPLEMENTING CIRCUITS IN ALTERA DEVICES

| Compilation Report - Flow Sumr                                                                                                                                                                                                                 | nary                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Compilation Report                                                                                                                                                                                                                             | Flow Summary                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                    |
| Completed Report     Completed Report     Completed Report     Flow Summary     Flow Settings     Flow Elapsed Time     Flow Lapsed Time     Flow Lapsed Time     Flow Lapsed Time     Flow Lapsed Time     Assembler     Flow Timing Analyzer | 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 logic elements<br>Total registers<br>Total pins<br>Total pins<br>Total memory bits<br>Embedded Multiplier 9-bit elements<br>Total PLLs | Successful - Tue Nov 07 20:54:48 2006<br>6.0 Build 202 06/20/2006 SP 1 SJ Web Edition<br>example_verilog<br>Cyclone II<br>EP2C35F672C6<br>Final<br>Yes<br>1 / 33,216 (< 1 % )<br>0<br>4 / 475 (< 1 % )<br>0<br>0 / 483,840 (0 % )<br>0 / 70 (0 % )<br>0 / 4 (0 % ) |
|                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                    |

Figure C.3 The compilation summary.



Figure C.4 The Fitter Equations section.

### **C.1.3 Performing Timing Simulation**

Timing simulation is done by using the same procedure that we described in Tutorial 1 for functional simulation. Select Assignments > Settings and click on the Simulator item, as shown in Figure B.24. Open the drop-down list next to Simulation mode and change this setting from Functional to Timing. Use the Edit > End Time command to set the duration of the simulation to 640 ns. Then, turn on grid lines at 40-ns intervals by selecting Edit > Grid Size and setting the Time period to 40 ns.

Use similar input waveforms for  $x_1$ ,  $x_2$ , and  $x_3$  that were drawn with the Waveform Editor in Tutorial 1 as inputs for the timing simulation. Select Processing > Start Simulation to run the simulation. When it is completed, the simulation report is displayed. Part of this

### C.1 IMPLEMENTING A CIRCUIT IN A CYCLONE II FPGA

859



Figure C.5 The Timing Simulation Report.

report is shown in Figure C.5. Select View > Fit in Window to see the complete time range of the waveforms. Compare these waveforms to those shown in Figure B.25. The timing simulation produces the same results as the functional simulation in Tutorial 1 except that the changes in the waveform for f are now determined by the timing characteristics of the Cyclone II 2C35 chip. There are two changes in the waveform for f shown in Figure C.5 that we should mention. At the 320 ns point in the simulation, the inputs  $x_1x_2x_3$  change from 011 to 100. Since f = 0 for both of these input combinations, we would expect to see no change in the output value produced by the simulation. The waveform in Figure C.5 shows that f does have the correct value (0) after the inputs change to 100, but there is a short period of time when a wrong value of f = 1 is produced. This temporary change in the output value, which is usually called a *glitch*, is due to the delay properties of the lookup table based logic element in the Cyclone II FPGA. We discuss lookup table based logic cells in section 3.6.5. A similar glitch occurs at the 480 ns point in the simulation shown in Figure C.5. In practice, glitches like these do not cause a problem, because they only exist for a short time before the output stabilizes at the correct value. We discuss this topic in more detail in Chapter 9.

We can use the vertical reference line in the Simulation Report window to determine the exact time when f changes value. To do this select View > Snap to Transition, so that your mouse pointer will align perfectly with an edge on any waveform. Click and drag the vertical reference line to the point where f first changes to 1, as shown in the figure (you can also move the reference line by using the keyboard arrow keys). The box labeled Master Time Bar now displays 85.396 ns, meaning that it takes about 5.4 ns for the change in x3, which occurs at 80 ns, to cause a change in f. This result is a reflection of the timing characteristics of the Cyclone II FPGA.

## **C.1.4** Using the Chip Planner

In addition to examining the equations in the compilation report, another way to view the implementation results is to use the Chip Planner. Select Tools > Chip Planner to open the



#### **APPENDIX C** • TUTORIAL 2–IMPLEMENTING CIRCUITS IN ALTERA DEVICES

Figure C.6 The Chip Planner display.

window shown in Figure C.6. To make the window look like the one in the figure, it may be necessary to turn off the feature that displays equations in the bottom part of the Chip Planner window. Select View > Equations to toggle off this feature.

Figure C.6 shows some of the logic elements in the Cyclone II 2C35 chip. As shown in Appendix E, each logic element comprises a four-input lookup table. The logic elements are organized into logic array blocks (LABs), where each LAB contains 16 logic elements. Selecting View > Fit in Window in the Chip Planner will display the entire chip. The Chip Planner uses different colors to indicate logic elements and pins that are used in a circuit and those that are unused. For our small example four pins are used for the three inputs and one output, and one logic element (of more than 33,000 in the chip!) is used to implement the function f. To see larger or smaller views of the chip, click on the Zoom Tool button in the Chip Planner toolbar, which looks like a small magnifying glass. Left-click to zoom in and right-click to zoom out. To display different sections of the chip, use the window scroll bars.

Adjust the display so that the logic cell that produces the output f is visible, as depicted in Figure C.7 (your compilation results may use a different logic element and pins from the ones shown in the figure). Make sure the **Selection Tool**, which looks like an arrowhead, in the Chip Planner is active, and then click on the logic element for f to select it. The Chip Planner can draw lines that indicate which other resources the selected logic element



### C.1 IMPLEMENTING A CIRCUIT IN A CYCLONE II FPGA

Figure C.7 Viewing node fan-in and equations.

is connected to by choosing View > Generate Fan-In Connections and View > Generate Fan-Out Connections. It is also possible to see what logic function is implemented in the selected node by selecting View > Equations. As seen in the figure, this choice displays the logic expressions from the compilation report in the bottom part of the Chip Planner window.

Instead of displaying the whole chip, it is also possible to see more details for individual resources. Right-click on the logic element for f and select Locate > Locate in Resource Property Editor to open the Resource Property Editor tool shown in Figure C.8. Another way to open this tool is to double-click the mouse on the logic element. To make the display look as shown in the figure it may be necessary to select View > View Port Connections to toggle off this feature.

A lot of useful information is available in the Resource Property Editor. It shows that the lookup table inputs called *B*, *C*, and *D* are used for our logic function. Hover the mouse cursor over each of the inputs in turn to see that *B* is connected to  $x_3$ , *C* to  $x_2$ , and *D* to  $x_1$ . The window shows the logic function implemented in the lookup table under the name *Sum Equation*; this terminology is used because it is possible to configure a lookup table such that it implements separate outputs for the sum and carry functions needed in a full-adder (since our logic function is not a full-adder, the expression for Carry Equation is shown as N/A). We should note that the logic expression shown for *f* in the figure is specified as 861

### APPENDIX C • TUTORIAL 2-IMPLEMENTING CIRCUITS IN ALTERA DEVICES

 $f = x_3(x_1 + \overline{x}_2) + \overline{x}_3 x_2 x_1$ . This is not the simplest expression that one may expect, namely  $f = x_1 x_2 + \overline{x}_2 x_3$ . But both expressions represent the same function and the CAD tools do not always display the simplest form of an equation.

The bottom right corner of the Resource Property Editor window shows the propagation delays through the logic element. Click on the value 150 ps associated with input D, which is connected to  $x_1$ . As indicated in Figure C.8 the corresponding path through the logic element is highlighted. The path starting at input C has a delay of 271 ps, and the path through B has the delay 420 ps. The differing delays associated with each input to the lookup table is the reason that we observed glitches in the simulation waveforms for f in Figure C.5; changes in the input  $x_1$  affect the value of the output f more quickly than changes in inputs  $x_2$  and  $x_3$ . In larger designs where it is important to optimize the performance of the implemented circuit, the CAD tools make use of the faster inputs through lookup tables for the parts of a circuit that are the most timing critical.

It is possible to explore different parts of the implemented circuit using the Resource Property Editor. To experiment with this feature, right-click on the DATAD input to the lookup table and select **Go to source node**, as indicated in Figure C.9. This action causes the Resource Property Editor to display the pin used for the input  $x_1$ . The **Bock to previous resource** icon in the Resource Property Editor toolbar, which looks like an arrow pointing to the left, can then be used to return the display to the logic element previously viewed. In a similar way, you can right-click on the output of the lookup table and examine the pin used for the output f.



Figure C.8 The Resource Property Editor display.

### C.2 IMPLEMENTING AN ADDER USING QUARTUS II 863



Figure C.9 Using the Resource Property Editor.

We have now completed the implementation of the *example\_verilog* project in a Cyclone II FPGA. Close the project.

# C.2 IMPLEMENTING AN ADDER USING QUARTUS II

In section 5.5 we show how an *n*-bit ripple-carry adder can be specified in Verilog code. In this section we show how the ripple-carry adder can be implemented using the Quartus II system. Create a new project, *adder16*, in a directory *tutorial2\addern*. We will implement the adder circuit in a Cyclone II FPGA. Thus, in the New Project Wizard window shown in Figure B.6, select the Cyclone II family and choose the specific device called the EP2C35F672C6 (if this device is not listed, change the Speed Grade item in the Filter box to Any). We are using this device because it is available in the DE2 Development and Education board provided by Altera (see altera.com), which we discuss in Appendix D.

### **C.2.1** THE RIPPLE-CARRY ADDER CODE

Verilog code for the *n*-bit adder is given in Figure C.10. It takes as inputs the carry-in signal, *carryin*, plus two *n*-bit numbers, X and Y, and produces the *n*-bit output sum, S, and carry-out signal, *carryout*. The code uses the parameter *n*, so that the adder can be parameterized to work for any number of bits. In this example, *n* is set to 16. In the code the vector *C* is used to represent the intermediate carries between the stages in the adder. A for loop is used to create *n* full-adders that comprise the ripple-carry adder.

**APPENDIX C** • TUTORIAL 2—IMPLEMENTING CIRCUITS IN ALTERA DEVICES

```
module adder16 (carryin, X, Y, S, carryout);
   parameter n = 16;
  input carryin;
  input [n-1:0] X, Y;
   output reg [n-1:0] S;
   output reg carryout;
  reg [n:0] C;
  integer k;
   always @(X or Y or carryin)
  begin
     C[0] = carryin;
     for (k = 0; k \le n-1; k = k+1)
     begin
        S[k] = X[k] \land Y[k] \land C[k];
        C[k+1] = (X[k] \ \& \ Y[k]) \ | \ (C[k] \ \& \ X[k]) \ | \ (C[k] \ \& \ Y[k]);
     end
     carryout = C[n];
   end
```

endmodule

Figure C.10 Verilog code for a ripple-carry adder.

Type the code in Figure C.10 into the Text Editor, as explained in Section B.4.2, and save the file in the *tutorial2\addern* directory using the name *adder16.v*. Compile the circuit. The compilation report is shown in Figure C.11.

### **C.2.2** SIMULATING THE CIRCUIT

To test the correctness of the circuit, we will perform timing simulation. For brevity only a few test vectors will be used, but in a real design situation more extensive testing would be required.

Create a new Vector Waveform file. Use Edit > End Time to set the desired simulation to run from 0 to 250 ns. Choose the grid lines to be placed at 25-ns intervals. This is done by selecting Edit > Grid Size, which leads to the window in Figure C.12 and setting the Time period to 25 ns. Select View > Fit in Window to display the entire simulation range in the window.

Select Edit > Insert > Insert Node or Bus, and then open the Node Finder utility to reach the window in Figure C.13. Set the filter to Pins: all and click List, which displays the input and output nodes as depicted in the figure. Scroll down the list of displayed nodes until you reach *carryin*. Select this node by clicking on it and then clicking the > sign. Next select the X input. Note that this input can be selected either as nodes that correspond

#### C.2 IMPLEMENTING AN ADDER USING QUARTUS II

| Compilation Report - Flow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Summary                                                                                                                                                                   | _ 🗆 ×                                                                                                                                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Compilation Report - Flow     Compilation Report     Compilation Report     Compilation Report     Flow Summary     Flow Summary     Flow Settings     Flow Settings     Flow Elapsed Time     Flow Elapsed Time     Flow Log     Flow Log     Flow Log                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Summary<br>Flow Summary<br>Flow Status<br>Quartus II Version<br>Revision Name<br>Top-level Entity Name<br>Family<br>Device                                                | Successful - Mon Nov 13 16:16:38 2006<br>(Beta) 6.1 Internal Build 185d 10/31/2006 SJ Full Version<br>adder16<br>Cyclone II<br>EP2C35F672C6 |
| Image: Second | Device<br>Timing Models<br>Met timing requirements<br>Total logic elements<br>Total combinational functions<br>Dedicated logic registers<br>Total registers<br>Total pins | EP2C35F672C6<br>Final<br>Yes<br>40 / 33,216 ( < 1 % )<br>40 / 33,216 ( < 1 % )<br>0 / 33,216 ( 0 % )<br>0<br>50 / 475 (11 % )               |
| <u>∢</u> ►                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Total virtual pins<br>Total memory bits<br>Embedded Multiplier 9-bit elements<br>Total PLLs                                                                               | 0<br>0/483,840(0%)<br>0/70(0%)<br>0/4(0%)                                                                                                   |

Figure C.11 The compilation report summary.

| Grid Size                        | × |
|----------------------------------|---|
| Base grid on                     | 1 |
| Clock settings:                  |   |
| <b>v</b>                         |   |
| <ul> <li>Time period:</li> </ul> |   |
| Period: 25 ns 💌                  |   |
| OK Cancel                        |   |

Figure C.12 Setting the spacing of grid lines.

to the individual bits (denoted by bracketed subscripts) or as a 16-bit vector, which is a more convenient form. Then, select the input Y and outputs S and *carryout*. This produces the image in the figure. Click OK.

The Waveform Editor window now looks like the image in Figure C.14. Vectors X, Y, and S are initially treated as binary numbers. They can also be treated as either octal, hexadecimal, signed decimal, or unsigned decimal numbers. For our purpose it is convenient to treat them as hexadecimal numbers, so right-click on X in the Name column and select Properties in the pop-up box to get to the window displayed in Figure C.15. Choose hexadecimal as the radix, make sure that the bus width is 16 bits, and click OK. (Quartus II uses the term *bus* to refer to multibit nodes.) In the same manner, declare that Y

APPENDIX C • TUTORIAL 2-IMPLEMENTING CIRCUITS IN ALTERA DEVICES

| lamed: 📔       | 10          | Filter: F   | iris. ali |    |                     | omize       |             | ОК     |
|----------------|-------------|-------------|-----------|----|---------------------|-------------|-------------|--------|
| ook in:  ladde | пы          |             |           |    |                     | subentities | Stop        | Cancel |
| lodes Found:   |             |             |           |    | Selected Nodes:     |             |             |        |
| Name           | Assignments | Туре        | C 🔺       |    | Name                | Assignments | Туре        |        |
| PΥ             | Unassigned  | Input Group | U         |    | 🗩  adder16 carryin  | Unassigned  | Input       |        |
| 🕪 Y[0]         | Unassigned  | Input       | U         |    | 💕  adder16 X        | Unassigned  | Input Group |        |
| ₽¥[1]          | Unassigned  | Input       | U         |    | iadder16 Y          | Unassigned  | Input Group |        |
| ₽¥[2]          | Unassigned  | Input       | U         |    | 🐵   adder 16   S    | Unassigned  | Output Grou |        |
| 🕪 Y[3]         | Unassigned  | Input       | U         |    | 🐵  adder16 carryout | Unassigned  | Output      |        |
| 🕩 Y[4]         | Unassigned  | Input       | U         |    |                     |             |             |        |
| 🗩 Y[5]         | Unassigned  | Input       | U         | >  |                     |             |             |        |
| 🕪 Y[6]         | Unassigned  | Input       | U         |    |                     |             |             |        |
| 🕪 Y[7]         | Unassigned  | Input       | U         | >> |                     |             |             |        |
| 🗩 Y[8]         | Unassigned  | Input       | U         |    |                     |             |             |        |
| 🕪 Y[9]         | Unassigned  | Input       | U         | <  |                     |             |             |        |
| 🕪 Y[10]        | Unassigned  | Input       | U         | << |                     |             |             |        |
| ₽¥[11]         | Unassigned  | Input       | U         |    |                     |             |             |        |
| ₽¥[12]         | Unassigned  | Input       | U         |    |                     |             |             |        |
| 🕪 Y[13]        | Unassigned  | Input       | U         |    |                     |             |             |        |
| 🕪 Y[14]        | Unassigned  | Input       | U         |    |                     |             |             |        |
| 🕩 Y[15]        | Unassigned  | Input       | U         |    |                     |             |             |        |
| 🗈 carryin      | Unassigned  | Input       | U         |    |                     |             |             |        |
| 💿 carryout     | Unassigned  | Output      | υŢ        |    |                     |             |             |        |

Figure C.13 The Node Finder window.

| 🗗 Waveform                                                                                                                                      | 1.vwf*       |            |                  |                 |                |                       |                       |                       | <u>_   ×</u> |
|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------|------------------|-----------------|----------------|-----------------------|-----------------------|-----------------------|--------------|
|                                                                                                                                                 | Master T     | ime Bar: 0 | ps 🔸 Po          | ointer:         | 0 ps Interval: | 0 ps St               | art:                  | End:                  |              |
| ₿А発<br>⊕                                                                                                                                        |              | Name       | Value at<br>0 ps | Ops<br>Ops<br>J | 50.0 ns        | 100 <sub>,</sub> 0 ns | 150 <sub>,</sub> 0 ns | 200 <sub>,</sub> 0 ns | 250.0 ns     |
| <b>纳</b> 公。                                                                                                                                     | ∎>0          | carryin    | BO               |                 |                |                       |                       |                       |              |
|                                                                                                                                                 | <b>₽</b> 1   | ΞX         | B 000000         |                 |                | 0000000               | 00000000              |                       |              |
| ें ≫ू छे                                                                                                                                        | <b>1</b> 8   | ΞY         | B 000000         |                 |                | 0000000               | 00000000              |                       |              |
| 노르ळ                                                                                                                                             | <b>@</b> 35  | 🗉 S        | в 🗴 🐼            |                 |                |                       | ******                |                       |              |
| Ar Ar Ar                                                                                                                                        | <b>@</b> >52 | carryout   | В×               |                 | *****          | ********              | ********              | *******               | *****        |
| 11 × 10                                                                                                                                         |              |            |                  |                 |                |                       |                       |                       |              |
| $\underline{2} \underline{2} = \underline{2} \underline{2} \underline{2} \underline{2} \underline{2} \underline{2} \underline{2} \underline{2}$ |              |            |                  |                 |                |                       |                       |                       |              |
| <u>⊓ः</u> ≹↓                                                                                                                                    | 4            |            | Þ                |                 |                |                       |                       |                       |              |

Figure C.14 Selected input and output nodes.

#### Node Properties × General X Name Type: INPUT • 9-Level Value type Hexadecimal • Radix 16 \* Bus width:

ΟК

Cancel

### C.2 IMPLEMENTING AN ADDER USING QUARTUS II 867

| Figure C.15 Del | ining the c | haracteristics o | f a nod | le. |
|-----------------|-------------|------------------|---------|-----|
|-----------------|-------------|------------------|---------|-----|

🗖 Display gray code count as binary count

| <b>D</b> Waveform                         | 1.vwf*       |              |                  |              |           |            |          |      |                       | _ 🗆 ×    |
|-------------------------------------------|--------------|--------------|------------------|--------------|-----------|------------|----------|------|-----------------------|----------|
|                                           | Master T     | ime Bar: 0 p | IS IP            | ointer:      | 0 ps Inte | rval: 0 ps | Start: ( | Dips | End: 250.0 r          | ns       |
| ₽<br>₽                                    |              | Name         | Value at<br>0 ps | O ps<br>O ps | 50.0 ns   | 100,0 ns   | 150,     | 0 ns | 200 <sub>,</sub> 0 ns | 250.0 ns |
| <b>纳</b> 3.6                              | ∎>0          | carryin      | ВO               |              |           |            |          |      |                       |          |
|                                           | <b>₽</b> 1   | Ξ×           | H 0000           |              |           |            | 0000     |      |                       |          |
| \v                                        | <b>1</b> 8   | ΞY           | H 0000           |              |           |            | 0000     |      |                       |          |
| 치고 📈                                      | <b>@</b> 35  | ⊞ S          | н≫∞              |              |           |            | XXXX     |      |                       |          |
| XI XH XE                                  | <b>@</b> >52 | carryout     | В×               |              | ******    | ******     | *****    | **** | *******               | *****    |
| xx /c /@                                  |              |              |                  |              |           |            |          |      |                       |          |
| $\chi_{\overline{2}} \chi_{\overline{B}}$ |              |              |                  |              |           |            |          |      |                       |          |
| 野 え↓                                      | ∢            |              | Þ                |              |           |            |          |      |                       |          |

Figure C.16 Using the hexadecimal representation for multibit signals.

and S should be treated as hexadecimal numbers. The resulting waveform display is shown in Figure C.16.

We will now set the test values of X and Y. The default value of these inputs is 0. To assign specific values in various intervals proceed as follows. Select (highlight) the interval from 100 to 175 ns of input X. Press the Arbitrary Value icon in the toolbar (it is labeled by a question mark), to bring up the pop-up window in Figure C.17. Enter the value 3FFF and click OK. Then, set X to the value 7FFF in the interval from 175 to 250 ns. Set Y to 0001 in the interval from 50 to 250 ns. Thus, the input waveforms should be as depicted in Figure C.18. If this were a real design project we would enter additional test values into

**APPENDIX C** • TUTORIAL 2—IMPLEMENTING CIRCUITS IN ALTERA DEVICES

| Arbitrary Value         |             |   | ×      |
|-------------------------|-------------|---|--------|
| Node/group name(s):     |             |   | ОК     |
| ×                       |             |   | Cancel |
| Radix:                  | Hexadecimal | • | ]      |
| Numeric or named value: | 3FFF        |   | •      |

Figure C.17 Assigning the value of a multibit signal.

| Simulation Report - Sim | ulation \   | Wavef                   | orms     |          |                           |            |          |  |  |  |  |
|-------------------------|-------------|-------------------------|----------|----------|---------------------------|------------|----------|--|--|--|--|
| 🞒 🗟 Simulation Report   | Simulat     | mulation Waveforms      |          |          |                           |            |          |  |  |  |  |
| - 🗃 🖹 Legal Notice      | Simulati    | Simulation mode: Timing |          |          |                           |            |          |  |  |  |  |
| Flow Summary            |             |                         |          |          |                           |            |          |  |  |  |  |
| Flow Settings           | K Ma        | aster Ti                | ime Ops  | · · Poir | iter 0 ps Interval        | 0 ps Start | End      |  |  |  |  |
| 🖻 🚑 🔄 Simulator         |             |                         |          |          |                           |            |          |  |  |  |  |
| Summary                 |             |                         |          | Value at | Ops 1                     | 00,0 ns    | 200,0 ns |  |  |  |  |
| Settings                | ₩.          |                         | Name     | Ops      | O ps                      |            |          |  |  |  |  |
|                         |             |                         |          |          | <u> </u>                  |            |          |  |  |  |  |
| INI Usage               | <u> _`Ľ</u> | ▶0                      | carryin  | BO       |                           |            |          |  |  |  |  |
| A Messages              | B 🖬         | ≩1                      | Ξ×       | H 0000   | 0000                      | X 3FFF     | X 7FFF   |  |  |  |  |
|                         | M 🖻         | <b>≩</b> 18             | ΞY       | H 0000   | ( 0000 X (                | 0001       |          |  |  |  |  |
|                         | 1 R.        | 35                      | . E S    | H 0000   | ( 0000 X 000 <sup>.</sup> | 1 )        | X 8000   |  |  |  |  |
|                         | ∾,   _      | € 52                    | carryout | во       |                           | r          |          |  |  |  |  |
|                         | ∣→ ⊨        |                         |          |          |                           |            |          |  |  |  |  |
|                         |             |                         |          |          |                           |            |          |  |  |  |  |

Figure C.18 The result of timing simulation.

the waveforms, but for purposes of this tutorial a few test vectors will suffice. Save the file as *adder16.vwf*.

### **C.2.3 TIMING SIMULATION**

To examine the functionality of the circuit, and determine its speed of operation in the chosen device, we will perform a timing simulation. Select Assignments > Settings > Simulator to reach the window in Figure B.25 and choose Timing as the simulation mode. Run the simulator. The result is given in Figure C.18. It shows considerable delays in producing the correct value S = 4000 because the carries are rippling through the adder stages.

Point to the small square handle at the top of the reference line and drag it to the point where the S value becomes 4000. A more accurate view can be obtained if the waveform image is enlarged using the Zoom Tool. Enlarge the image to look like the display in

### C.2 IMPLEMENTING AN ADDER USING QUARTUS II

| Simulation Report - | Simul      | ation W                                                                       | aveforms |          |              |      |           |         | _ 🗆 🗵    |  |  |  |
|---------------------|------------|-------------------------------------------------------------------------------|----------|----------|--------------|------|-----------|---------|----------|--|--|--|
| Simulation Report   | Simu       | nulation Waveforms                                                            |          |          |              |      |           |         |          |  |  |  |
| - 🚑 🖹 Legal Notice  | Simu       | nulation mode: Timing                                                         |          |          |              |      |           |         |          |  |  |  |
| Flow Summary        |            | <u>M</u>                                                                      |          |          |              |      |           |         |          |  |  |  |
| Flow Settings       |            | Master Time Bar: 121.87 ns 💶 Pointer: 96.87 ns Interval: -25.0 ns Start: End: |          |          |              |      |           |         |          |  |  |  |
| 🖻 🚑 🔄 Simulator     |            |                                                                               |          |          |              |      | ·····     |         | 1        |  |  |  |
| Summary             | A          |                                                                               |          | Value at | 96.87 ns     | 3    | 110.25 ns | 1       | 23.62 ns |  |  |  |
| Settings            | ₩          |                                                                               | Name     | 121.87   |              |      |           | 121.8   | 17 ns    |  |  |  |
| The Simulation      | £          |                                                                               |          |          | <u> </u>     |      |           |         | 1        |  |  |  |
| INI Usage           | P          | •0                                                                            | carryin  | BO       |              |      |           |         |          |  |  |  |
| A Messages          | Þ          | <b>1</b>                                                                      | ∃×       | H 3FFF   | <u>0000X</u> |      | 3FFF      |         |          |  |  |  |
| Erer Hossages       | #          | <b>1</b> 8                                                                    | ΞY       | H 0001   |              |      | 0001      |         |          |  |  |  |
|                     |            | <b>@</b> 35                                                                   | ⊡s       | H 4000   |              | 0001 |           | 9XX00X) | 4000     |  |  |  |
|                     | M.,        |                                                                               | carryout | во       |              |      |           |         |          |  |  |  |
|                     | <b> </b> → |                                                                               | 1        |          |              |      |           |         |          |  |  |  |
|                     | 00,        | •                                                                             | 1        |          | •            |      |           | I       | F        |  |  |  |

Figure C.19 Detailed results of timing simulation.

Figure C.19. Click on the Selection Tool icon, and drag the reference line as closely as possible to the point where the value 4000 becomes valid.

The change in *S* from 0001 to 4000 is caused by the *X* input changing from 0000 to 3FFF, which occurs at 100 ns. As seen in Figure C.19, the output *S* changes to 4000 at approximately 121.9 ns. Therefore, the propagation delay through the adder, for these particular values of inputs, is estimated to be 21.9 ns. Note that, in this case, the adder performs the operation 3FFF + 1 = 4000 which involves a carry rippling through most of the stages of the adder circuit. For other values of inputs, the propagation delay may be much smaller. In Figure C.18, we see that the operation 0000 + 0001 = 0001 is completed in about 5.76 ns.

When we compile our circuit using Processing > Start Compilation one of the modules executed is the Timing Analyzer. As explained in Chapter 12, this module automatically produces an estimate of the speed of the circuit. Open the compilation report by selecting Processing > Compilation Report or by clicking on its icon. The report includes the derived timing analysis. Click on the small + symbol next to Timing Analyzer to expand this section of the report. Then, click on Summary to get the display in Figure C.20. The summary indicates that the estimated worst case propagation delay from an input to output pin,  $t_{pd}$ , is 21.9 ns. This longest path starts at the X[1] input and ends at S[14]. More detailed information about the propagation delays along various paths through the circuit can be seen by clicking on the left side of Figure C.20, which displays the information in Figure C.21. Here, we see that there are several paths along which the propagation delay is close to the maximum, including the one given in the summary in Figure C.20. These longest-delay paths are referred to as *critical paths*.

The Timing Analyzer performs several types of timing analysis. The results displayed in Figure C.21 give the delays through a combinational circuit, from input pins to output pins. The other types of analysis are applicable only to circuits that contain storage elements, namely flip-flops. This type of analysis is discussed in section C.4.

### APPENDIX C • TUTORIAL 2-IMPLEMENTING CIRCUITS IN ALTERA DEVICES

| 🚭 Compilation Report - Timir | ng i | Analyzer Summary             |       |                  |                |      |       |               | _           |                 |
|------------------------------|------|------------------------------|-------|------------------|----------------|------|-------|---------------|-------------|-----------------|
| Compilation Report           | Ti   | ming Analyzer Summary        |       |                  |                |      |       |               |             |                 |
| - 🔄 🖹 Legal Notice           |      | Туре                         | Slack | Required<br>Time | Actual<br>Time | Fr   | To    | From<br>Clock | To<br>Clock | Failed<br>Paths |
| Flow Settings                | 1    | Worst-case tpd               | N/A   | None             | 21.870 ns      | ×[1] | S[14] |               |             | 0               |
| Flow Non-Default Glot        | 2    | Total number of failed paths |       |                  |                |      |       |               |             | 0               |
| Flow Elapsed Time            |      |                              |       |                  |                |      |       |               |             |                 |
| Flow Log                     |      |                              |       |                  |                |      |       |               |             |                 |
| 🗄 🚭 📄 Analysis & Synthesis   |      |                              |       |                  |                |      |       |               |             |                 |
| 🗄 🚭 🛄 Partition Merge        |      |                              |       |                  |                |      |       |               |             |                 |
| 🕀 🕘 📄 Fitter                 |      |                              |       |                  |                |      |       |               |             |                 |
| 🗄 🚭 🧰 Assembler              |      |                              |       |                  |                |      |       |               |             |                 |
| 🖹 🗃 🗃 Timing Analyzer        |      |                              |       |                  |                |      |       |               |             |                 |
| - 🗃 🐯 Summary                |      |                              |       |                  |                |      |       |               |             |                 |
| 🛛 🎒 🛄 Settings               |      |                              |       |                  |                |      |       |               |             |                 |
| 🚽 🗃 🔜 tpd                    |      |                              |       |                  |                |      |       |               |             |                 |
| - 🚭 🔅 Messages               |      |                              |       |                  |                |      |       |               |             |                 |
|                              | •    |                              |       |                  |                |      |       |               |             | Þ               |

Figure C.20 The worst-case propagation delay.

| Description Report - tpd                 |     |       |                      |                    |      |          |          |
|------------------------------------------|-----|-------|----------------------|--------------------|------|----------|----------|
| Compilation Report                       | tpd |       |                      |                    |      |          |          |
| - 🚑 🖹 Legal Notice<br>- 🎒 📑 Flow Summary |     | Slack | Required<br>P2P Time | Actual P2P<br>Time | From | To       | <u> </u> |
| Flow Settings                            | 1   | N/A   | None                 | 21.870 ns          | X[1] | S[14]    |          |
|                                          | 2   | N/A   | None                 | 21.772 ns          | X[0] | S[14]    |          |
| Flow Elapsed Time                        | 3   | N/A   | None                 | 21.627 ns          | Y[1] | S[14]    |          |
| Flow Log                                 | 4   | N/A   | None                 | 20.950 ns          | Y[2] | S[14]    |          |
| 🗄 🎒 🛄 Analysis & Synthesis               | 5   | N/A   | None                 | 20.937 ns          | X[1] | S[12]    |          |
| ⊕- <b>4</b> Dertition Merge              | 6   | N/A   | None                 | 20.839 ns          | X[0] | S[12]    |          |
|                                          | 7   | N/A   | None                 | 20.813 ns          | X[2] | S[14]    |          |
|                                          | 8   | N/A   | None                 | 20.694 ns          | Y[1] | S[12]    |          |
| 🖉 🚑 🔣 Summary                            | 9   | N/A   | None                 | 20.017 ns          | Y[2] | S[12]    |          |
| - 🗃 🎹 Settings                           | 10  | N/A   | None                 | 19.880 ns          | X[2] | S[12]    |          |
| - 🚑 🐯 tpd                                | 11  | N/A   | None                 | 19.814 ns          | X[1] | carryout |          |
| - 🗃 🔅 Messages                           | 12  | N/A   | None                 | 19.716 ns          | X[0] | carryout |          |
|                                          | 13  | N/A   | None                 | 19.571 ns          | Y[1] | carrvout | <b>•</b> |

Figure C.21 The critical paths.

We have finished working on the addern circuit, so close the project.

# C.3 USING AN LPM MODULE

In section 5.5.1 we discuss how an adder circuit can be implemented by using the *lpm\_add\_sub* module in the library of parameterized modules (LPM). In this section we compare the adder circuit produced by the *lpm\_add\_sub* module to the ripple-carry adder

#### **C.3** USING AN LPM MODULE

implemented in the previous section. Create a new project, *adder16\_lpm*, in a directory *tutorial2\adderlpm*. Choose the same FPGA chip as in section C.2.

The easiest way to instantiate an LPM module is by means of a wizard. Select Tools > MegaWizard Plug-in Manager to activate the wizard. A number of pop-up boxes will appear in which we can specify the features of the desired module. In the screen shown in Figure C.22 choose to create a new variation of a megafunction, and click Next. In the screen in Figure C.23 select the LPM\_ADD\_SUB module. Make sure that the Cyclone II family is indicated at the top right, and also select the entry Verilog HDL as the type of file to create. Let the output file be named *megadd.v*. (The filename extension, *v*, will be added automatically.) Click Next. In Figure C.24, specify that a 16-bit adder circuit is required. Click Next to reach the subsequent screen and accept the default setting that indicates that both inputs can vary. Click Next again to reach the window in Figure C.25 and specify that both carry input and output signals are needed. Observe that the wizard displays a symbol for the adder which includes the specified inputs and outputs. Advance past the next screen, which presents a pipelining option that we will not use. The last screen is given in Figure C.26, which indicates the files generated by the wizard. Click Finish. We are interested only in the *megadd.v* file, so make sure that this is the only file selected by a check mark.

The *megadd* module is shown in Figure C.27. (We have removed the comments to make the figure smaller.) The top-level Verilog code that instantiates this module is given in Figure C.28. Enter this code into a file called *adder16\_lpm.v*.

Compile the design. A summary of the timing analysis is shown in Figure C.29. In this design, the worst-case propagation delay is about 13.28 ns. Clearly, the adder implementation by means of an appropriate LPM is superior to our generic specification in Figure C.10. The reason that this adder is much faster than our previously created ripple-carry adder is that the LPM makes use of special circuitry in the FPGA for performing addition. We discuss such circuitry, often called a *carry-chain*, in Sections 5.4 and 12.1. We may conclude that a designer should normally use an LPM if a suitable module exists in the library.

| MegaWizaro    | l Plug-In Manager [page 1]                                                                                                 |
|---------------|----------------------------------------------------------------------------------------------------------------------------|
| $\propto$     | The MegaWizard Plug-In Manager helps you create or modify design<br>files that contain custom variations of megafunctions. |
| $\rightarrow$ | Which action do you want to perform?                                                                                       |
| Á             | <ul> <li>Create a new custom megafunction variation</li> </ul>                                                             |
|               | C Edit an existing custom megafunction variation                                                                           |
|               | C Copy an existing custom megafunction variation                                                                           |
|               | Copyright © 1991-2003 Altera Corporation                                                                                   |
|               | Cancel < Back Next> Finish                                                                                                 |



#### APPENDIX C • TUTORIAL 2-IMPLEMENTING CIRCUITS IN ALTERA DEVICES

| MegaWizard Plug-In Manager [page 2a]                                                                                                                                                                                                                                                                                                                   | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Which megafunction would you like to customize?<br>Select a megafunction from the list below                                                                                                                                                                                                                                                           | Which device family will you be Cyclone II                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Installed Plug-Ins Altera SOPC Builder Altera SOPC Builder Aithmetic ALTFP_ADD_SUB ALTFP_DIV ALTFP_DIV ALTFP_MULT ALTFP_MULT ALTFP_MULT ALTFR_MULT ALTFR_MULT ALTFR_MULT ALTRORT LPM_ADD_SUB LPM_COUNTER LPM_COUNTER LPM_COUNTER LPM_DIVIDE LPM_MULT PARALLEL_ADD Gates 1/0 Memory Compiler Parallel Flash Loader SignalT ap II Logic Analyzer Storage | <ul> <li>Which type of output file do you want to create?</li> <li>AHDL</li> <li>VHDL</li> <li>Verilog HDL</li> </ul> What name do you want for the output file? Browse D:\tutorial2\adderlpm\megadd <ul> <li>Generate clear box netlist file instead of a default wrapper file (for use with supported EDA synthesis tools only)</li> <li>Return to this page for another create operation</li> </ul> Note: To compile a project successfully in the Quartus II software, your design files must be in the project directory, in the global user libraries specified in the User Libraries page of the Settings dialog box (Assignments menu). Your current user library directories are: |
|                                                                                                                                                                                                                                                                                                                                                        | Cancel < Back Next > Finish                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Figure C.23 Select the LPM and its Verilog specification.

To examine the circuit produced by using the LPM adder, open the Chip Planner tool as discussed in section C.1.4. Locate in the Chip Planner the part of the circuit that implements the adder, as indicated in Figure C.30. The logic elements that comprise the adder are connected together vertically by the carry chain wires. As indicated in the figure, select one of the logic elements in the adder and double-click on it to examine its contents in the Resource Property Editor tool. As illustrated in Figure C.31, the logic element is configured into a mode that produces both a sum output as well as a separate carry output that is fed to the next stage of the adder.

The *adder16\_lpm* project can now be closed.

# C.4 DESIGN OF A FINITE STATE MACHINE

This example shows how to implement a sequential circuit using Quartus II. The presentation assumes that the reader is familiar with the material in Chapter 8. In section 8.1 we show a simple Moore-type finite state machine (FSM) that has one input, w, and one output, z.

#### C.4 DESIGN OF A FINITE STATE MACHINE

873

| MegaWizard Plug-In Manage                                                   | er - LPM_ADD_SL   | JB [page 3 of 8]                                       |                   |                               | X        |
|-----------------------------------------------------------------------------|-------------------|--------------------------------------------------------|-------------------|-------------------------------|----------|
| Version 6                                                                   | _ADD_SU           | В                                                      | About             | : <u>D</u> ocumentation       |          |
| Parameter     Z Simulation     Settings     General     General     General |                   | >                                                      |                   |                               |          |
| megadd                                                                      |                   | Currently selected devic                               | e family:         | yclone II                     | <b>~</b> |
| dataa[15.0] A+B result[15                                                   |                   | vide should the 'dataa' an<br>th operating mode do you | ·                 |                               | \$       |
|                                                                             | ⊙ <b>µ</b><br>○ 9 | addition only                                          |                   |                               |          |
|                                                                             |                   | Treate an 'add_sub' input<br>1 adds; 0 subtracts)      | port to allow me  | to do both                    |          |
|                                                                             |                   |                                                        |                   |                               |          |
| Resource Usage                                                              |                   |                                                        |                   |                               |          |
| 16 lut                                                                      |                   | Cano                                                   | el < <u>B</u> ack | <u>N</u> ext > <u>F</u> inish |          |

**Figure C.24** Choose the adder option and the number of bits.

Whenever *w* is 1 for two successive clock cycles, *z* is set to 1. The state diagram for the FSM is given in Figure 8.3; it is reproduced in Figure C.32. Verilog code that describes the machine appears in Figure 8.33; it is reproduced in Figure C.33. Create a new project, *simple*, in the directory *tutorial2*/*fsm*. Create a new Text Editor file and enter the code shown in Figure C.33. Save the file with the name *simple.v*.

Select the same Cyclone II device as in previous sections of this tutorial. Before compiling the code we need to make one change in the settings used by the synthesis module in Quartus II. Select Assignments > Settings to open the Settings window, and under Category click on the item Analysis and Synthesis Settings. Then, click on the button More Settings to open the window shown in Figure C.34. In the box called Existing options settings scroll down to the bottom of the list and click on the item State Machine Processing. Change the value of this option from its default (Auto) to the setting User-Encoded. This setting instructs the Synthesis module to use the state assignment specified in the Verilog code in Figure C.33, rather than to choose state codes automatically. Compile the circuit.

Open the Waveform Editor and import the nodes *Resetn*, *Clock*, *w*, and *z*. These nodes are found by setting the Node Finder filter to Pins: all. We also want to see the behavior of the state variables, which are implemented by means of flip-flops. To find these nodes, set the Node Finder filter to Registers: post-fitting and click List. The Node Finder displays two

#### **APPENDIX C** • TUTORIAL 2—IMPLEMENTING CIRCUITS IN ALTERA DEVICES



Figure C.25 Include carry input and output connections.

nodes, as shown in Figure C.35. Import both of these nodes into the Waveform Editor. Set the total simulation time to 650 ns and set the grid size to 25 ns. Set *Resetn* = 0 during the first 50 ns, and then set *Resetn* = 1. To enter the waveform for the clock signal, click on the name of the *Clock* waveform in the Waveform Editor display. With the signal highlighted, click on the *Overwrite Clock* icon in the toolbar (the icon depicts a clock). This causes the pop-up window in Figure C.36 to appear. Set the clock period to be 50 ns, make sure that the offset is 0 and the duty cycle is 50 percent, and click OK. The defined clock signal is now displayed in the Waveform Editor window, as depicted in Figure C.37. Next, draw the waveform for *w* as indicated in the figure. To make the changes in *w* occur shortly after the positive clock edge, we temporarily changed the grid size in the Waveform Editor to 5 ns. Specifying the waveform for *w* in this manner is a reasonable choice, because most signals in a real system are generated by flip-flops that use the same clock signal. Save the file, under the name *simple.vwf*. Run the Timing Simulator to get the result shown in Figure C.38.

The FSM behaves correctly, setting z = 1 in each clock cycle for which w = 1 in the preceding two clock cycles. Examine the timing delays in the circuit, using the reference line in the Waveform Editor. Observe that changes in the FSM's state occur about 2.95 ns after an active clock edge and that 6.37 ns are needed to change the value of z at its output pin.

874

#### C.4 Design of a Finite State Machine

875

| MegaWizard Plug-In Manager                                            | · - LPM_ADD_SUB [page 8 (                                                                                                      | of 8] Summary 🛛 🗙                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPM_A     Version 6                                                   | ADD_SUB                                                                                                                        | <u>A</u> bout <u>D</u> ocumentation                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1 Parameter 2 Simulation<br>Settings Library                          | 3 Summary                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| megadd<br>cin<br>dataa[150]<br>A+B result[15.<br>datab[150]<br>A-B co | automatically generat<br>Finish to generate the<br>subsequent MegaWize<br>0]<br>The MegaWizard Plug<br>directory: D:\tutorial2 | wish to generate. A gray checkmark indicates a file that is<br>ted, and a red checkmark indicates an optional file. Click<br>e selected files. The state of each checkbox is maintained in<br>zard Plug-In Manager sessions.<br>g-In Manager creates the selected files in the following<br>2\adderlpm\<br>Description<br>Variation file<br>AHDL Include file<br>VHDL component declaration file<br>Quartus II symbol file<br>Instantiation template file<br>Veniog HDL black-box file |
| Resource Usage<br>16 lut                                              |                                                                                                                                | Cancel < <u>B</u> ack <u>N</u> ext > <u>F</u> inish                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Figure C.26 Files generated by the wizard.

Open the Timing Analyzer summary in the compilation report, which is displayed in Figure C.39. Row 4 in the table indicates that the maximum frequency, which is often called  $F_{max}$ , at which the synthesized circuit can operate is 420.17 MHz. This is a useful indicator of performance. The  $F_{max}$  is determined by the longest propagation delay between two registers (flip-flops). The figure also shows the values of some other timing parameters. The worst-case flip-flop setup time,  $t_{su}$ , and hold time,  $t_h$ , are given. Line 1 in Figure C.39 specifies that the *w* input can change until up to 0.609 ns *after* the active clock edge occurs (at the clock pin), and still meet the flip-flop setup requirement. Line 3 shows that the worst-case hold time at the *w* input pin is 0.839 ns after the active clock edge. We explain in section 10.3.2 how flip-flop timing parameters are determined in a target chip. The parameter  $t_{co}$  indicates the time elapsed from an active edge of the clock signal at the clock pin until an output signal is produced at an output pin. This delay is 6.37 ns for the *z* output, which is what we also observed in the waveforms in Figure C.38.

Note that the states of this FSM are implemented using two state variables. The Verilog code in Figure C.33 specified the present state variables as y[2] and y[1]. However, Quartus II gave the names  $y \sim 15$  and  $y \sim 14$  to these variables, as we discovered when using the Node

876 APPENDIX C • TUTORIAL 2–Implementing Circuits in Altera Devices

module megadd (dataa, datab, cin, result, cout);
input [15:0] dataa;
input [15:0] datab;
input cin;
output [15:0] result;
output cout;
wire sub wire0;
wire [15:0] sub wire1;
wire cout = sub wire0;
wire [15:0] result = sub wire1[15:0];

### defparam

lpm\_add\_sub\_component.lpm width = 16, lpm\_add\_sub\_component.lpm direction = "ADD", lpm\_add\_sub\_component.lpm type = "LPM\_ADD\_SUB", lpm\_add\_sub\_component.lpm hint = "ONE\_INPUT\_IS\_CONSTANT=NO";

### endmodule

Figure C.27 Verilog code for the *megadd* module.

Figure C.28 Verilog code that instantiates the LPM adder module.

### C.4 DESIGN OF A FINITE STATE MACHINE 877

| Compilation Report - T | 🗳 Compilation Report - Timing Analyzer Summary |    |                              |       |                  |                |      |       |               |             |                 | × |
|------------------------|------------------------------------------------|----|------------------------------|-------|------------------|----------------|------|-------|---------------|-------------|-----------------|---|
| 🖻 🞒 Timing Analyzer    |                                                | Ti | ming Analyzer Summary        |       |                  |                |      |       |               |             |                 |   |
| Summary<br>Settings    |                                                |    | Туре                         | Slack | Required<br>Time | Actual<br>Time | From | To    | From<br>Clock | To<br>Clock | Failed<br>Paths |   |
| 👍 🐻 tpd                | T                                              | 1  | Worst-case tpd               | N/A   | None             | 13.283 ns      | Y[1] | S[13] |               |             | 0               |   |
|                        |                                                | 2  | Total number of failed paths |       |                  |                |      |       |               |             | 0               |   |

Figure C.29 The worst-case delay for the *adder16\_lpm* circuit.



Figure C.30 Examining the 16-bit adder in the Chip Planner.

Finder. Quartus II uses the names of all inputs and outputs as given in the Verilog code, but it may generate different names for internal connections.

Two or more binary signals displayed in the Waveform Editor can be combined into a "group" (corresponding to a vector in Verilog terminology) of signals that can be referred to by a single name. Open the *simple.vwf* file and select the  $y\sim15$  and  $y\sim14$  simultaneously, so that their waveforms are highlighted (make sure that  $y\sim15$  is listed *above*  $y\sim14$ , as shown in Figure C.37). Select Edit > Grouping > Group to reach the pop-up box in Figure C.40. Type y as the group name, choose binary as the radix, and click OK. This causes y to be used, instead of  $y\sim15$  and  $y\sim14$ , in the file *simple.vwf*. Perform timing simulation to get the result in Figure C.40. Now, the FSM states are represented by the values of the vector y that correspond to our Verilog code.











C.5 CONCLUDING REMARKS 879

```
module simple (Clock, Resetn, w, z);
  input Clock, Resetn, w;
  output z;
  reg [2:1] y, Y;
  parameter [2:1] A = 2 b00, B = 2 b01, C = 2 b10;
  // Define the next state combinational circuit
  always @(w or y)
     case(y)
       A: if (w) Y = B;
                 Y = A;
          else
       B: if (w) Y = C;
          else
                 Y = A;
       C: if (w) Y = C;
                 Y = A;
          else
       default: Y = 2 bxx;
     endcase
```

```
// Define the sequential block
always @(negedge Resetn or posedge Clock)
    if (Resetn == 0) y <= A;
    else y <= Y;
// Define output</pre>
```

assign z = (y == C);

endmodule

Figure C.33 Verilog code for the FSM in Figure C.32.

# **C.5 CONCLUDING REMARKS**

Having completed this and the preceding tutorial, the reader is familiar with many of the most important features of Quartus II. In the next tutorial we will show how the user can manipulate which pins on the target chip are used for a circuit, and how FPGA programming is done with Quartus II.

### APPENDIX C • TUTORIAL 2-IMPLEMENTING CIRCUITS IN ALTERA DEVICES

| Option                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                  |           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------|
| Name: State Machine Process                                                                                                                                                                                                                                                                                                                                                                                                               | ng                                                                                               | Reset     |
| Setting: User-Encoded                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                  | Reset All |
| Description:                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                  |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                  |           |
| xisting option settings:                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                  |           |
| xisting option settings:<br>Name:                                                                                                                                                                                                                                                                                                                                                                                                         | Setting:                                                                                         |           |
| Name:<br>Number of Removed Registers Repor.                                                                                                                                                                                                                                                                                                                                                                                               | . 100                                                                                            |           |
| Name:<br>Number of Removed Registers Repor.<br>Optimization Technique Cyclone II                                                                                                                                                                                                                                                                                                                                                          | . 100<br>Balanced                                                                                | -         |
| Name:<br>Number of Removed Registers Repor.<br>Optimization Technique Cyclone II<br>PowerPlay Power Optimization                                                                                                                                                                                                                                                                                                                          | . 100<br>Balanced<br>Normal compilation                                                          |           |
| Name:<br>Number of Removed Registers Repor.<br>Optimization Technique Cyclone II<br>PowerPlay Power Optimization<br>Power-Up Don't Care                                                                                                                                                                                                                                                                                                   | . 100<br>Balanced<br>Normal compilation<br>On                                                    |           |
| Name:<br>Number of Removed Registers Repor.<br>Optimization Technique Cyclone II<br>PowerPlay Power Optimization<br>Power-Up Don't Care<br>Remove Duplicate Registers                                                                                                                                                                                                                                                                     | . 100<br>Balanced<br>Normal compilation<br>On<br>On                                              |           |
| Name:<br>Number of Removed Registers Repor.<br>Optimization Technique Cyclone II<br>Powerl/Jay Power Optimization<br>Power-Up Don't Care<br>Remove Duplicate Registers<br>Remove Redundant Logic Cells                                                                                                                                                                                                                                    | . 100<br>Balanced<br>Normal compilation<br>On<br>On<br>Off                                       |           |
| Name:<br>Number of Removed Registers Repor.<br>Optimization Technique Cyclone II<br>PowerPlay Power Optimization<br>Power-Up Don't Care<br>Remove Duplicate Registers<br>Remove Redundant Logic Cells<br>Restructure Multiplexers                                                                                                                                                                                                         | . 100<br>Balanced<br>Normal compilation<br>On<br>On<br>Off<br>Auto                               |           |
| Name:<br>Number of Removed Registers Repor.<br>Optimization Technique Cyclone II<br>PowerPlay Power Optimization<br>Power-Up Don't Care<br>Remove Duplicate Registers<br>Remove Redundant Logic Cells<br>Restructure Multiplexers<br>Restructure Multiplexers<br>Retiming Meta-Stability Register Sequ.                                                                                                                                   | . 100<br>Balanced<br>Normal compilation<br>On<br>On<br>Off<br>Auto                               |           |
| Name:<br>Number of Removed Registers Repor.<br>Optimization Technique Cyclone II<br>Powerl/lay Power Optimization<br>Power-Up Don't Care<br>Remove Duplicate Registers<br>Remove Duplicate Registers<br>Restructure Multiplexers<br>Retiming Meta-Stability Register Sequ.<br>Safe State Machine                                                                                                                                          | . 100<br>Balanced<br>Normal compilation<br>On<br>Off<br>Auto<br>. 2<br>Off                       |           |
| Existing option settings:<br>Name:<br>Number of Removed Registers Repor.<br>Optimization Technique Cyclone II<br>PowerPlay Power Optimization<br>Power-Up Don't Care<br>Remove Duplicate Registers<br>Remove Redundant Logic Cells<br>Restructure Multiplexers<br>Retiming Meta-Stability Register Sequ.<br>Safe State Machine<br>Show Parameter Settings Tables in S<br>State Machine Processing<br>Suppress Register Optimization Relat | . 100<br>Balanced<br>Normal compilation<br>On<br>Off<br>Auto<br>. 2<br>Off<br>On<br>User-Encoded |           |

Figure C.34 Setting the state machine processing to User-Encoded.

| Node Finder              |             |                  |               |                 |             |            | x      |
|--------------------------|-------------|------------------|---------------|-----------------|-------------|------------|--------|
| Named:                   | ▼ F         | Filter: Register | s: post-fitti | ng 💌 Custo      | mize        | List       | ОК     |
| Look in: Isimple         |             |                  |               | 💌 🔽 Include     | subentities | Stop 🌂     | Cancel |
| Nodes Found:             |             |                  |               | Selected Nodes: |             |            |        |
| Name                     | Assignments | Туре             | >             | Name            | Assignments | Туре       |        |
| 🐨 y~14                   | Unassigned  | Registered       | $\rightarrow$ | Isimplely~14    | Unassigned  | Registered |        |
| <ul><li>𝔹 y~15</li></ul> | Unassigned  | Registered       | <             | Isimplely~15    | Unassigned  | Registered |        |
| •                        |             | Þ                | <<            | •               |             | Þ          |        |

Figure C.35 Nodes that represent the state variables.

### C.5 CONCLUDING REMARKS 881

| Clock       |              | ×        |
|-------------|--------------|----------|
| Time range  |              |          |
| Start time: | 0            | ps 💌     |
| End time:   | 650.0        | ns 💌     |
| Base wave   | form on      |          |
| C Clock s   | ettings:     |          |
|             |              | <b>~</b> |
| Time p      | eriod:       |          |
| Period:     | 50.0         | ns 🔻     |
| Offset:     | 0.0          | ns 💌     |
| Duty c      | ycle (%): 50 | 3        |
|             | ОК           | Cancel   |

Figure C.36 Creating the *Clock* waveform.

| <b>G</b> i sin | nple.vwf* |                 |                                                                |                       |
|----------------|-----------|-----------------|----------------------------------------------------------------|-----------------------|
| Master         | Time Bar: | 0 ps 💽          | Pointer: 0 ps Interval: 0 ps Start: End:                       |                       |
|                | Name      | Value at<br>Ops | 0 ps 100,0 ns 200,0 ns 300,0 ns 400,0 ns 500,0 ns<br>0 ps<br>1 | 600 <sub>,</sub> 0 ns |
| ∎>0            | Resetn    | AO              |                                                                |                       |
|                | Clock     | AO              |                                                                |                       |
| ₽2             | w         | AO              |                                                                |                       |
| <b>@</b> 3     | z         | AX              |                                                                | ******                |
| <b>1</b>       | y~15      | AU              |                                                                |                       |
| € 🕞            | y~14      | AU              |                                                                |                       |
| <u> </u>       |           | Þ               |                                                                |                       |

Figure C.37 Input test vectors.

### **APPENDIX C** • TUTORIAL 2–IMPLEMENTING CIRCUITS IN ALTERA DEVICES



Figure C.38 Timing simulation waveforms.

| Compilation Report - | Tir | ning Analyzer Summary        |       |                  |                                               | _    |      |
|----------------------|-----|------------------------------|-------|------------------|-----------------------------------------------|------|------|
| 🛋 Assembler 🛛 🔺      | Tir | ming Analyzer Summary        |       |                  |                                               |      |      |
| Timing Analyzer      |     | Туре                         | Slack | Required<br>Time | Actual<br>Time                                | From | To   |
| Settings             | 1   | Worst-case tsu               | N/A   | None             | -0.609 ns                                     | W    | y~14 |
| 🚽 🖬 Clock Settings : | 2   | Worst-case tco               | N/A   | None             | 6.370 ns                                      | y~15 | z    |
| 🕘 🐻 Clock Setup: 'C  | 3   | Worst-case th                | N/A   | None             | 0.839 ns                                      | W    | y~14 |
| 🚽 🔄 tsu              | 4   | Clock Setup: 'Clock'         | N/A   | None             | Restricted to 420.17 MHz (period = 2.380 ns ) | y~15 | y~14 |
| - 🚑 🖪 tco            | 5   | Total number of failed paths |       |                  |                                               |      |      |
| 률 Messages 💽         |     |                              |       |                  |                                               |      |      |
|                      | •   |                              |       |                  |                                               |      | •    |

Figure C.39 Summary of the timing analysis for the FSM circuit.

| Group                                   |        | ×        |  |  |  |  |  |  |  |
|-----------------------------------------|--------|----------|--|--|--|--|--|--|--|
| Group name:                             | у      |          |  |  |  |  |  |  |  |
| Radix:                                  | Binary | <b>_</b> |  |  |  |  |  |  |  |
| Display gray code count as binary count |        |          |  |  |  |  |  |  |  |
|                                         | OK     | Cancel   |  |  |  |  |  |  |  |

**Figure C.40** Grouping of signals.

### **C.5** CONCLUDING REMARKS

| 🗳 Simulation Report - Simulation Waveforms |                      |                         |        |          |            |                       |                       |                       |  |  |
|--------------------------------------------|----------------------|-------------------------|--------|----------|------------|-----------------------|-----------------------|-----------------------|--|--|
| Simulation Report                          | Simulation Waveforms |                         |        |          |            |                       |                       |                       |  |  |
| 🛛 🗁 🖹 Legal Notice                         | Simu                 | Simulation mode: Timing |        |          |            |                       |                       |                       |  |  |
| Flow Summary                               |                      |                         |        |          |            |                       |                       |                       |  |  |
| Flow Settings                              |                      | Master                  | Time 0 | ps · · I | Pointer: 0 | 0 ps Interval: 0 ps   | Start:                | End:                  |  |  |
| E Simulator                                | A                    |                         |        |          |            |                       |                       |                       |  |  |
| Summary                                    |                      |                         | Name   | Value at | 0 ps       | 200 <sub>,</sub> 0 ns | 400 <sub>,</sub> 0 ns | 600 <sub>,</sub> 0 ns |  |  |
| Simulation W                               | €€                   |                         | Name   | 0 ps     | Ops        |                       |                       |                       |  |  |
| E - A Simulation C                         | Ð,                   | ⊡>0                     | Resetn | НО       | i          |                       |                       |                       |  |  |
| INI Usage                                  | - Ba                 | 1 1                     |        |          |            |                       |                       |                       |  |  |
| A Messages                                 | 日白                   |                         | Clock  | НO       | [] 년 년_    | <u> 너 너 너</u> 너       | 4 <u> LI LI LI</u>    | 니니니                   |  |  |
|                                            | 14                   | ■>2                     | W      | но       |            |                       | _                     |                       |  |  |
|                                            |                      | <b>@</b> 3              | z      | но       |            |                       |                       |                       |  |  |
|                                            | <u>₩</u> ,           | <b>@</b> 4              | Шy     | B 00     | 00         |                       | <u> </u>              | 1 X 00                |  |  |
|                                            | →                    | 4                       |        | Þ        |            |                       |                       |                       |  |  |

Figure C.41 Waveform displayed as a vector y.