Exercise Manual for Introduction to VHDL Using Quartus II



# Introduction to VHDL Lab Overview

## Objective: Build a sequential 8 X 8 multiplier

The objective of the following exercises is to build an 8 X 8 multiplier. The input to the multiplier consists of two 8-bit multiplicands (a[7..0], b[7..0]) and the output from the multiplier is a 16-bit result (result[15..0]). Additional outputs are a done bit (DONE\_FLAG) and seven signals to drive a seven segment display, (A, B, C, D, E, F, G).

There are several methods of implementing a multiplier; the method chosen for the VHDL labs is the sequential multiplier method. This 8 X 8 multiplier requires four clock cycles to perform the full multiplication. During each cycle, a pair of 4-bit portion of the multiplicands is multiplied in a 4 X 4 multiplier. The multiplication result of these 4 bit slices is then accumulated. At the end of the four cycles, the fully composed 16-bit result can be read at the output.

The following equations illustrate the mathematical principles supporting this implementation:

result[15..0] = a[7..0] \* b[7..0]

 $= ((a[7..4] * 2^{4}) + a[3..0] * 2^{0})$  $* ((b[7..4] * 2^{4}) + b[3..0] * 2^{0})$  $= ((a[7..4] * b[7..4]) * 2^{8})$  $+ ((a[7..4] * b[3..0]) * 2^{4})$  $+ ((a[3..0] * b[7..4]) * 2^{4})$  $+ ((a[3..0] * b[3..0]) * 2^{0})$ 

Figure 1 in the following page illustrates the top-level block diagram of the 8 X 8 multiplier.

The labs are structured as a bottom-up design approach. In each of the first five exercises, you will use targeted features of the VHDL language to build the individual components of the 8 X 8 multiplier. Then, in exercise 6 you will put everything together in a top-level design. You will then compile and simulate to verify the completeness of your design.

Good luck and have fun going through the exercises!





Figure 1 - 8 X 8 multiplier top level design block diagram





*Objective: The 16-bit adder can be constructed using the + operator.* 

|     | AD    | DER      |
|-----|-------|----------|
| - A | [150] | SUM[150] |
| в   | [150] |          |
| ı   |       |          |
|     | Figu  | re 1-1.  |

## Step 1 (Ask the instructor for the <pathname>)

- 1. **<pathname>** is\_\_\_\_\_
- 2. Use this **<pathname>** pathname for this Lab

## Step 2 (Create new project and open VHDL text editor file)

Create a project by using the New Project Wizard. To create a project using the New Project Wizard, please follow these steps:

- 1. Select **New Project Wizard** from the File menu. The first time you open the New Project Wizard, it shows the introduction page; you can **click Next** to proceed to the first page of the wizard.
- 3. Type a name for the project in the project name box. For this lab, **type adder**.
- 4. **Type adder** as the name of the top-level design entity of the project in the top-level design entry box.
- 5. Click Next. The second page of the New Project Wizard appears.
- 6. At this point, there is no file to add because we will create the adder source file later.
- 7. **Click Next**. The EDA Tools Settings page appears. These exercises will use only Quartus II so the Tool Name should be <NONE> for all the Tool Types.
- 8. **Click Next**. The Device Family page appears. Select Stratix II as the Device Family and select No, I want to allow the Compiler to choose a device.
- 9. Click Next 2 times. The summary page appears. The summary page gives information about your project.



- 10. **Click Finish**. You have just finished the project creation. You should see the top-level entity (adder) in the Compilation Hierarchies tab of the Project Navigator window.
- 11. From the File menu select new or click on  $\Box$ . The New file dialog box will appear; select VHDL

file. Click on OK

| New                                                | ×  |
|----------------------------------------------------|----|
| Device Design Files   Software Files   Other Files |    |
| AHDL File<br>Block Diagram/Schematic File          |    |
| EDIF File<br>Verilog HDL File<br>WHOL File         |    |
|                                                    |    |
|                                                    |    |
|                                                    |    |
|                                                    |    |
|                                                    |    |
|                                                    |    |
| OK Canc                                            | el |

Figure 1-2.

- 12. VHDL text editor will appear.
- 13. Before the beginning of your code (before the ENTITY), type the following:

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

USE ieee.std\_logic\_unsigned.all;

14. Write your source code.

Remember to use the same input and output port names as shown in Figure 1-1.

15. Go to File menu and Choose Save As.

Save new VHDL text file to <path>\altera\_trn\vhdl\lab1\adder.vhd.

#### Step 3 (Synthesize the design)

- 1. From the Processing menu choose Start-> Start Analysis and Synthesis
- 2. This will save and check for syntax and semantic errors for the file adder.vhd. It will then synthesize

the design. When you see the message "Analysis and synthesis was successful", click OK.



7

## **Step 4 (Do a functional simulation)**

- 1. The stimulus file has been created for you to verify the functionality of your design. If you are interested in learning how to create your own stimulus file, please go to the Appendix of this manual.
- 2. Go to the Assignments menu and choose Simulator. In the Simulator mode section select Functional.

| Category:                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General<br>Files<br>User Libraries<br>Device<br>Timing Requirements & Options<br>EDA Tool Settings<br>Compilation Process<br>Analysis & Synthesis Settings<br>Filter Settings<br>Timing Analyzer<br>Design Assistant<br>SignalT ap II Logic Analyzer<br>SignalProbe Settings<br>Simulator<br>B Software Build Settings<br>Stratix GX Registration<br>HardCopy Settings | Simulator         Select options for simulations.         Simulation mode:         Functional         Simulation input:         Simulation period         Image: Run simulation until all vector stimuli are used         End simulation at:         Image: Run simulation options         Automatically add pins to simulation output waveforms         Check outputs         Setup and hold time violation detection         If tich detection:         Image: Image: Run simulation input file with simulation results         uPCore Transaction Model File Name:         Power Estimation |
| 1                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

- 3. Choose **OK**.
- 4. From the Processing menu select the Generate Functional Simulation Netlist, Click OK when done.
- 5. From the Processing menu select Start Simulation or click on . When you see the message, "Simulation was successful", click OK.
- 6. Check to see if you get the same results shown in Figure 1-6.



| Simu     | lation Wavef | orms   |                                     |          |           |          |         | <u> 12</u> | 10      |
|----------|--------------|--------|-------------------------------------|----------|-----------|----------|---------|------------|---------|
| Mast     | er Time Bar: | 5.0 ns | <ul> <li>Image: Pointer:</li> </ul> | 44.19 ns | Interval: | 39.19 ns | Start:  | End:       |         |
|          |              | Valu   | 0 ps                                | 10.0 ns  | 20.0      | ns       | 30.0 ns | 40.0 ns    | 50.0 ns |
|          | Name         | 5.0 ns | 5.0 ns                              |          |           |          |         |            |         |
| <b>1</b> | ⊞ a          | U 8    |                                     | 8        | X         | Ó        | ×       | 10         |         |
| 3        | њь           | U 5    |                                     | 5        | X         | 1        | X       | 5          |         |
| 0        | 🛨 sum        | U 13   |                                     | 13       | X         | 1        | X       | 15         |         |
|          |              |        |                                     |          |           |          |         |            |         |
|          |              |        |                                     |          |           |          |         |            |         |
|          |              |        |                                     |          |           |          |         |            |         |
|          |              |        |                                     |          |           |          |         |            |         |
|          |              |        |                                     |          |           |          |         |            |         |
|          |              |        |                                     |          |           |          |         |            |         |
|          |              |        |                                     |          |           |          |         |            |         |
|          |              |        |                                     | 1        | 15 53     |          |         | 18 13      | er.     |
|          |              |        |                                     |          | Figure 1- | 6.       |         |            |         |

## Step 6 (Check operator overloading)

- In adder.vhd, comment (--) out the LIBRARY and USE clauses in the beginning of the file.
   -- LIBRARY ieee;
  - -- USE ieee.std\_logic\_1164.all;
  - -- USE ieee.std\_logic\_unsigned.all;
- 2.
- Save and check adder.vhd.
- 3. You should get the following error messages as shown in Figure 1-7.

🗉 🔅 Info: Running Quartus II Analysis & Synthesis

- Info: Command: quartus\_map --import\_settings\_files=on --export\_settings\_files=off adder -c adder --analyze\_project
- 😢 Error: VHDL error at adder.vhd(6): object std\_logic\_vector is used but not declared
- 😮 Error: VHDL error at adder.vhd(7): object std\_logic\_vector is used but not declared
- 😢 Error: Ignored construct adder at adder.vhd(9) because of previous errors
- 😣 Error: VHDL error at adder.vhd(11): entity adder is used but not declared
- 8 Error: VHDL error at adder.vhd(14): object sum is used but not declared
- Error: VHDL error at adder.vhd(11): entity adder must be in current project's work library
- Info: Found 0 design units and 0 entities in source file c:\documents and settings\mmendoza\desktop\vhdl\introduction\_to\_vhdl\_quartusii\_ver7\solutions\lab1\adder.vhd
- 🗄 🔀 Error: Quartus II Analysis & Synthesis was unsuccessful. 6 errors, 4 warnings
  - Info: Writing report file adder.map.rpt

Figure 1-7.

This is due to operator overloading. The VHDL compiler does not understand the arithmetic operation for std\_logic\_vector data types. The std\_logic\_unsigned package contains the function that describes this arithmetic operation. Therefore, the library that contains this package and the package itself needs to be referenced in the design file.



9

5. Change adder.vhd to re-include the declarations then save.

## **Step 7 (Close the project)**

1. From the File menu select Close project option.

# **END OF EXERCISE 1**



## Objective: Build a four input 2:1 multiplexer using IF-THEN statement.

The input to the multiplexer consists of two 4-bit data buses (a[3..0] and b[3..0]). The output (y[3..0]) is a[3..0] if the select control (sel) is low (0). The output is b[3..0] if sel is high (1).

The four input 2:1 multiplexer will be used in the top level design for selecting the 4-bit slices a[7..4], a[3..0], b[7..4], and b[3..0] as inputs to the 4 X 4 multiplier.



The inputs **a** and **b**, and the output **y** are declared as **STD\_LOGIC\_VECTOR(3 DOWNTO 0)**. The input **sel** is declared as a **STD\_LOGIC**.

## Step 1 (Ask the instructor for the <pathname>)

- 1. **<pathname>** is\_\_\_\_\_
- 2. Use this **<pathname>** pathname for this Lab

## Step 2 (Create new project and open VHDL text editor file)

Create a project by using the New Project Wizard. To create a project using the New Project Wizard, please follow the following steps:

- 1. Select **New Project Wizard** from the File menu. The first time you open the New Project Wizard, it shows the introduction page; you can **click Next** to proceed to the first page of the wizard.
- 3. Type a name for the project in the project name box. For this lab, type mux4.
- 4. **Type mux4** as the name of the top-level design entity of the project in the top-level design entry box.
- 5. Click Next. The second page of the New Project Wizard appears.
- 6. At this point, there is no file to add because we will create the mux4 source file later.
- 7. Click Next. The EDA Tools Settings page appears. These exercises will use only Quartus II so the Tool Name should be <NONE> for all the Tool Types.



- 8. **Click Next**. The Device Family page appears. Select Stratix II as the Device Family and select No, I want to allow the Compiler to choose a device.
- 9. Click Next 2 times. The summary page appears. The summary page gives information about your project.
- 10. **Click Finish**. You have just finished the project creation. You should see the top-level entity (mux4) in the Compilation Hierarchies tab of the Project Navigator window.
- 11. From the File menu select new or click on D. New file dialog box will appear and select VHDL

file. Click OK.

| ew                       |             |               |             |         |
|--------------------------|-------------|---------------|-------------|---------|
| Design Files             | Other Files | Project Files | Other Docum | ients   |
| AHDL File<br>Block Diagr | am/Schemati | c File        |             |         |
| Verilog HDL              | . File      |               |             |         |
| VHUL File                |             |               |             |         |
|                          |             |               |             |         |
|                          |             |               |             |         |
|                          |             |               |             |         |
|                          |             |               |             |         |
|                          |             |               |             |         |
| 1                        |             |               |             |         |
|                          |             |               | οκ Ι        | Cancel  |
|                          |             | L             |             | Caricer |

Figure 2-2.

- 1. VHDL text editor will appear.
- 2. Before the beginning of your code (before the ENTITY), type the following:

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

USE ieee.std\_logic\_unsigned.all;

3. Write your source code.

Remember to use the same input and output port names as shown in Figure 2-1.

4. Go to File menu and Choose Save As.

Save new VHDL text file to <path>\altera\_trn\vhdl\lab2\mux4.vhd.



#### Step 3 (Synthesize the design)

- 1. From the Processing menu choose Start-> Start Analysis and Synthesis
- 2. This will save and check for syntax and semantic errors for the file mux4.vhd. It will then synthesize the design. When you see the message "Analysis and synthesis was successful", click OK.

### **Step 4 (Do a functional simulation)**

- 1. The stimulus file has been created for you to verify the functionality of your design. If you are interested in learning how to create your own stimulus file, please go to the Appendix of this manual.
- 2. Go to the Assignments menu and choose **Simulator**. In the Simulator mode section select

#### Functional.

| Settings - reg                                                                                                                                                                                                                                                                                                                                              | X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category:                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| General<br>General<br>User Libraries<br>Device<br>Timing Requirements & Options<br>EDA Tool Settings<br>Compilation Process<br>Analysis & Synthesis Settings<br>Fitter Settings<br>Timing Analyzer<br>Design Assistant<br>SignalT ap II Logic Analyzer<br>SignalTop II Logic Analyzer<br>SignalTop Settings<br>Stratix GX Registration<br>HardCopy Settings | Simulator         Select options for simulations.         Simulation mode:         Functional         Simulation input         Image: Simulation option         End simulation at         Simulation options         Automatically add pins to simulation output waveforms         Check outputs         Setup and hold time violation detection         Glitch detection:         Simulation coverage reporting         Overwrite simulation input file with simulation results         uPCore Transaction Model File Name:         Power Estimation |
|                                                                                                                                                                                                                                                                                                                                                             | OK Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

- 3. Choose OK.
- 4. From the Processing menu select the Generate Functional Simulation Netlist.
- 5. Choose OK.



- 6. From the Processing menu select Start Simulation or click on . When you see the message, "Simulation was successful", click OK.
- 7. Check to see if you get the same results shown in Figure 2.6.

| 51m   | ulation Wavel | orms         |                          | 344       |          | _    |      | _     | _                  |    |      |      |    |    |      |      | _   | _   |     |    |     |      |    |   |     | -    | _     | _  |     |    |     |     |    | _  | _    |      |   |                   |      |     |                  | -    |
|-------|---------------|--------------|--------------------------|-----------|----------|------|------|-------|--------------------|----|------|------|----|----|------|------|-----|-----|-----|----|-----|------|----|---|-----|------|-------|----|-----|----|-----|-----|----|----|------|------|---|-------------------|------|-----|------------------|------|
| Mas   | ter Time Bar: | 25.0 ns      |                          |           | •        | Po   | inte | er: [ |                    | 1  | 17.7 | 74 r | ns |    | Ir   | nter | val | : [ |     | 9  | 2.7 | '4 r | ns |   |     | Sta  | rt: [ |    |     |    |     |     |    |    | En   | ±: [ |   |                   |      |     |                  |      |
| 01 V. | Name          | Valu<br>25.0 | <mark>0 р</mark><br>25.0 | s<br>Dins | 80.<br>s | 0 n: | s    | 160   | ) <sub>1</sub> 0 r | ns | 240  | 0,0  | ns | 32 | 20,0 | ) ns | 4   | 00  | 0 r | ns | 48  | 0,0  | ns | 5 | 60, | 0 n: | s E   | 40 | 0 r | IS | 720 | 0,0 | ns | 80 | )0,0 | ) ns | 8 | 80 <sub>1</sub> 1 | 0 ns | : 9 | 960 <sub>1</sub> | 0 ns |
|       | sel           | BO           |                          |           | ſ        |      | T    | 1     |                    |    | 1    | Ir   |    | ٦  | 1    | J    |     |     |     |    | ſТ  |      | 1  |   | Г   |      | 1     |    | ſ   | 1  | 1   | T   | J  | 1  | 1    | T    | Г | Ħ                 | ī    | T   | Г                |      |
| 3     | ± a           | U 9          | C                        |           | T        |      |      |       |                    |    |      | 1    |    |    |      |      |     |     |     |    | T   | 1    | 9  |   |     | T    | 1     |    |     |    |     |     |    |    |      |      |   |                   |      | 1   |                  |      |
| 3     | 🛨 b           | U 7          |                          | 1         |          |      |      |       |                    |    |      |      |    |    |      |      |     |     |     |    |     | 1    | 7  |   |     |      |       |    |     |    |     | 1   |    |    |      |      |   |                   |      |     |                  |      |
| 6     | <b></b> ∎ y   | U 9          | C                        |           | Ċ        |      | 9    | X     | 7                  | X  | 9    | X    | 7  | X  | 9    | X    | 7   |     |     | 1  | ¢   | 7    | X  | 9 | χ   | 7    | X     | 9  | X   | 7  | X   | 9   | Х  | 7  | X    | 9    | Χ | 7                 | X    | 9   | Х                | 7    |
|       |               |              |                          |           |          |      |      |       |                    |    |      |      |    |    |      |      |     |     |     |    |     |      |    |   |     |      |       |    |     |    |     |     |    |    |      |      |   |                   |      |     |                  |      |

Figure 2-6.

## **Step 5 (Close the project)**

1. From the File menu select Close project option to close the project.

# **END OF EXERCISE 2**







17

# Objective: Build a 7-segment display using CASE statement.

The 7-segment display shall display 0, 1, 2, 3, and E.

| Ι   | NPUT | S   |   |   | οι | JTPU | TS |   |   |         |
|-----|------|-----|---|---|----|------|----|---|---|---------|
| IN2 | IN1  | IN0 | А | b | с  | d    | Е  | F | g | DISPLAY |
| 0   | 0    | 0   | 1 | 1 | 1  | 1    | 1  | 1 | Ō | 0       |
| 0   | 0    | 1   | 0 | 1 | 1  | 0    | 0  | 0 | 0 | 1       |
| 0   | 1    | 0   | 1 | 1 | 0  | 1    | 1  | 0 | 1 | 2       |
| 0   | 1    | 1   | 1 | 1 | 1  | 1    | 0  | 0 | 1 | 3       |
| 1   | Х    | Х   | 1 | 0 | 0  | 1    | 1  | 1 | 1 | Е       |



The input is declared as **STD\_LOGIC\_VECTOR(2 DOWNTO 0)**. The outputs **a**, **b**, **c**, **d**, **e**, **f**, **g** are declared as **STD\_LOGIC**.

## Step 1 (Ask the instructor for the <pathname>)

- 1. **<pathname>** is\_\_\_\_\_
- 2. Use this **<pathname>** pathname for this Lab

## Step 2 (Create new project and open VHDL text editor file)

Create a project by using the New Project Wizard. To create a project using the New Project Wizard, please follow the following steps:



- 1. Select **New Project Wizard** from the File menu. The first time you open the New Project Wizard, it shows the introduction page; you can **click Next** to proceed to the first page of the wizard.
- 3. Type a name for the project in the project name box. For this lab, **type seven**.
- 4. Type seven as the name of the top-level design entity of the project in the top-level design entry box.
- 5. Click Next. The second page of the New Project Wizard appears.
- 6. At this point, there is no file to add because we will create the seven source file later.
- 7. **Click Next**. The EDA Tools Settings page appears. These exercises will use only Quartus II so the Tool Name should be <NONE> for all the Tool Types.
- 8. **Click Next**. The Device Family page appears. Select Stratix II as the Device Family and select No, I want to allow the Compiler to choose a device.
- 9. Click Next 2 times. The summary page appears. The summary page gives information about your project.
- 10. **Click Finish**. You have just finished the project creation. You should see the top-level entity (mux4) in the Compilation Hierarchies tab of the Project Navigator window.
- 11. From the File menu select new or click on New file dialog box will appear and select VHDL file. Click OK.

| New                                                                        | × |
|----------------------------------------------------------------------------|---|
| Design Files Other Files Project Files Other Documents                     |   |
| AHDL File<br>Block Diagram/Schematic File<br>EDIF File<br>Verilog HDL File |   |
| VHDL File                                                                  |   |
|                                                                            |   |
|                                                                            |   |
|                                                                            |   |
| OK Cancel                                                                  |   |
|                                                                            |   |

Figure 3-2.

12. VHDL text editor will appear.



13. Before the beginning of your code (before the ENTITY), type the following:

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

USE ieee.std\_logic\_unsigned.all;

14. Write your source code.

Remember to use the same input and output port names as shown in Figure 3-1.

15. Go to File menu and Choose Save As.

Save new VHDL text file to <path>\altera\_trn\vhdl\lab3\seven.vhd.

### Step 3 (Synthesize the design)

- 1. From the Processing menu choose Start-> Start Analysis and Synthesis
- 2. This will save and check for syntax and semantic errors for the file seven.vhd. It will then synthesize

the design. When you see the message "Analysis and synthesis was successful", click OK.

## Step 4 (Do a functional simulation)

1. The stimulus file has been created for you to verify the functionality of your design. If you are interested in learning how to create your own stimulus file, please go to the Appendix of this manual.

2. Go to the Assignments menu and choose . In the Simulator mode section select

#### Functional.

| L'ategory:                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Category:<br>General<br>Files<br>User Libraries<br>Device<br>Timing Requirements & Options<br>EDA Tool Settings<br>Compilation Process<br>Analysis & Synthesis Settings<br>Fitter Settings<br>Timing Analyzer<br>Design Assistant<br>SignalTap II Logic Analyzer<br>SignalProbe Settings<br>Simulator<br>Simulator<br>Software Build Settings<br>Stratix GX Registration<br>HardCopy Settings | Simulator         Select options for simulations.         Simulation mode:         Functional         Simulation input:         Simulation period         Run simulation until all vector stimuli are used         End simulation at:         Image: I |  |

#### 3. Choose OK.

- 4. From the Processing menu select the Generate Functional Simulation Netlist, Click OK when done.
- 5. From the Processing menu select Start Simulation or click on . When you see the message, "Simulation was successful", click OK.
- 6. Check to see if you get the same results shown in Figure 3-6.



| Mast | er Time Bar: | 50.0 n:             | s    | Pointe  | r: 16.         | 71 ns           | Interval: | -33.29 n              | s Star   | t        |                       | End:     |                       |
|------|--------------|---------------------|------|---------|----------------|-----------------|-----------|-----------------------|----------|----------|-----------------------|----------|-----------------------|
|      | Name         | Value at<br>50.0 ns | 0 ps | 20.0 ns | 40.0 ns<br>50. | 60.0 ns<br>0 ns | 80.0 ns   | 100 <sub>,</sub> 0 ns | 120,0 ns | 140,0 ns | 160 <sub>,</sub> 0 ns | 180,0 ns | 200 <sub>,</sub> 0 ns |
| 2    | 🗉 input      | U 1                 |      | Ó       |                |                 |           |                       | 2        |          | CHE                   | 3        | X 4                   |
| ٢    | а            | B 0                 |      |         |                |                 |           |                       |          |          |                       |          |                       |
| ٥)   | Ь            | B 1                 |      |         |                |                 |           |                       |          |          |                       |          |                       |
| o)   | с            | B 1                 |      |         |                |                 |           |                       |          |          |                       |          |                       |
|      | d            | B 0                 |      |         |                |                 |           |                       |          |          |                       |          |                       |
| o)   | е            | BO                  |      |         |                |                 |           |                       |          |          |                       |          |                       |
| o)   | f            | BO                  |      |         |                |                 |           |                       |          |          |                       |          |                       |
| œ    | g            | B 0                 |      |         |                |                 |           |                       |          |          |                       |          |                       |
|      |              |                     | •    |         |                |                 |           |                       |          |          |                       |          |                       |



## **Step 5 (Close the project)**

1. From the File menu select Close project option to close the project.

# **END OF EXERCISE 3**





## Objective: Build an 8-bit to 16-bit shifter using a FOR LOOP statement

In this exercise, you will build an 8-bit to 16-bit shifter. This shifter will be capable of perform three types of shifter operations: no shift, left shift by 4 bit positions, and left shift by 8 bit positions.

The input to the shifter consists of a single 8-bit data bus (in[7..0]). The shift operation is controlled by the control signal cnt[1..0].

When cnt = "00", the no shift operation will be selected. The output (result[15..0]) shall be: result[15..8] = 0 and result [7..0] = in[7..0].

When cnt = "01", the left shift by 4 operation will be selected. The output (result[15..0]) shall be: result[15..12] = 0, result [11..4] = in[7..0], and result[3..0] = 0.

When cnt = "10", the left shift by 8 operation will be selected. The output (result[15..0]) shall be: result[15..8] = in[7..0], and result[7..0] = 0.

When cnt = "11", the no shift operation will be selected. The output (result[15..0]) shall be: result[15..8] = 0 and result [7..0] = in[7..0].

This 8-bit to 16-bit shifter will be used to perform the  $*2 \land 0$  (no shift),  $*2 \land 4$  (left shift by 4 bit positions), and  $*2 \land 8$  (left shift by 8 bit positions) operations of the following equation:

|   | SHI       | FTER        |
|---|-----------|-------------|
| - | INPUT[70] | RESULT[150] |
| - | CNT[10]   |             |

Figure 4-1.

## Step 1 (Ask the instructor for the <pathname>)

- 1. **<pathname>** is\_\_\_\_\_
- 2. Use this **<pathname>** pathname for this Lab



## Step 2 (Create new project and open VHDL text editor file)

Create a project by using the New Project Wizard. To create a project using the New Project Wizard, please follow the following steps:

- 1. Select **New Project Wizard** from the File menu. The first time you open the New Project Wizard, it shows the introduction page; you can **click Next** to proceed to the first page of the wizard.
- 3. Type a name for the project in the project name box. For this lab, **type shifter**.
- 4. **Type shifter** as the name of the top-level design entity of the project in the top-level design entry box.
- 5. Click Next. The second page of the New Project Wizard appears.
- 6. At this point, there is no file to add because we will create the shifter source file later.
- 7. **Click Next**. The EDA Tools Settings page appears. These exercises will use only Quartus II so the Tool Name should be <NONE> for all the Tool Types.
- 8. **Click Next**. The Device Family page appears. Select Stratix II as the Device Family and select No, I want to allow the Compiler to choose a device.
- 9. Click Next 2 times. The summary page appears. The summary page gives information about your project.
- 10. **Click Finish**. You have just finished the project creation. You should see the top-level entity (mux4) in the Compilation Hierarchies tab of the Project Navigator window.
- 11. From the File menu select new or click on  $\Box$ . New file dialog box will appear and select VHDL file. Click OK.



| esign Files | Other Files  | Project Fil | es   Other [ | Documents |       |
|-------------|--------------|-------------|--------------|-----------|-------|
| AHDL File   |              |             |              | 57        |       |
| Block Diagr | am/Schematic | : File      |              |           |       |
| Verilog HDL | File         |             |              |           |       |
| VHDL File   |              |             |              |           |       |
|             |              |             |              |           |       |
|             |              |             |              |           |       |
|             |              |             |              |           |       |
|             |              |             |              |           |       |
|             |              |             |              |           |       |
|             |              |             |              |           |       |
|             |              |             |              |           |       |
| 8           |              |             |              |           | - ŝ   |
|             |              |             | ОК           |           | ncel  |
|             |              |             | OK           |           | nicci |

Figure 4-2.

- 12. VHDL text editor will appear.
- 13. Before the beginning of your code (before the ENTITY), type the following:

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

USE ieee.std\_logic\_unsigned.all;

14. Write your source code.

Remember to use the same input and output port names as shown in Figure 4-1.

15. Go to File menu and Choose Save As.

Save new VHDL text file to <path>\altera\_trn\vhdl\lab4\shifter.vhd.

## Step 3 (Synthesize the design)

- 1. From the Processing menu choose Start-> Start Analysis and Synthesis
- 2. This will save and check for syntax and semantic errors for the file shifter.vhd. It will then synthesize the design. When you see the message "Analysis and synthesis was successful", click OK.

## **Step 4 (Do a functional simulation)**

1. The stimulus file has been created for you to verify the functionality of your design. If you are

interested in learning how to create your own stimulus file, please go to the Appendix of this manual.



2. Go to the Assignments menu and choose Simulator. In the Simulator mode section select

#### Functional.

| Category:<br>General<br>Files                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| General g                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| <ul> <li>User Libraries</li> <li>Device</li> <li>Timing Requirements &amp; Options</li> <li>EDA Tool Settings</li> <li>Compilation Process</li> <li>Analysis &amp; Synthesis Settings</li> <li>Fitter Settings</li> <li>Timing Analyzer</li> <li>Design Assistant</li> <li>SignalTap II Logic Analyzer</li> <li>SignalProbe Settings</li> <li>Simulator</li> <li>Software Build Settings</li> <li>Stratix GX Registration</li> <li>HardCopy Settings</li> </ul> | Simulation Select options for simulations. Simulation mode: Functional Simulation input: Simulation period Run simulation until all vector stimuli are used End simulation at: Simulation options Automatically add pins to simulation output waveforms Check outputs Setup and hold time violation detection Glitch detection: Simulation coverage reporting Overwrite simulation input file with simulation results uPCore Transaction Model File Name: Power Estimation |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | OK Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |

#### 3. Choose OK.

- 4. From the Processing menu select the Generate Functional Simulation Netlist, Click OK when done.
- 5. From the Processing menu select Start Simulation or click on . When you see the message, "Simulation was successful", click OK.



1. Check to see if you get the same results shown in Figure 4-6.

| Mast                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | er Time Bar: | 50.0 ns    | • • Poin     | ter: 58.06 ns | Interval: | 8.06 ns  | Start:      |       | End:    |          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------|--------------|---------------|-----------|----------|-------------|-------|---------|----------|
| 1 P.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              | Value at   | 0 ps         | 20.0 ns       | 40.0      | ns       | 60.0 ns     | 8     | 10.0 ns | 100.0 ns |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Name         | 50.0 ns    |              | 50.0 ns       |           |          |             |       |         |          |
| <b>i</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 🛨 cnt        | U1         |              | j j           |           |          |             |       |         |          |
| i)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 王 input      | B 11110000 |              |               |           | 11110000 | )           |       |         |          |
| Image: Second secon | B 0000111    |            | 000000001111 | 0000          | X         |          | 00001111000 | 00000 |         |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |            |              |               |           |          |             |       |         |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |            |              |               |           |          |             |       |         |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |            |              |               |           |          |             |       |         |          |



## **Step 5 (Close the project)**

1. From the File menu select Close project option to close the project.

# **END OF EXERCISE 4**



# Exercise 5



Objective: Two-part exercise:

# Part A -- Build a 16-bit register with synchronous operation

## Part B –Build a 2 bit counter with asynchronous operation

# Part A

Functionality of the 16-bit register:

If clr='1' AND clken='1', then in\_reg will be loaded into register at the rising edge of clock. Otherwise, if clr='0', then the register is cleared at the rising edge of clock.

Note: This is a synchronous clear and clock enable register. Therefore, the IF-THEN that checks for clear and clock enable should be inside the IF-THEN statement that that checks for the clock condition.



Figure 5-1.

# Step 1 (Ask the instructor for the <pathname>)

- 1. **<pathname>** is\_\_\_\_\_
- 2. Use this **<pathname>** pathname for this Lab

# Step 2 (Create new project and open VHDL text editor file)

Create a project by using the New Project Wizard. To create a project using the New Project Wizard, please follow the following steps:

1. Select **New Project Wizard** from the File menu. The first time you open the New Project Wizard, it shows the introduction page; you can **click Next** to proceed to the first page of the wizard.



- 3. Type a name for the project in the project name box. For this lab, type reg.
- 4. **Type reg** as the name of the top-level design entity of the project in the top-level design entry box.
- 5. Click Next. The second page of the New Project Wizard appears.
- 6. At this point, there is no file to add because we will create the reg source file later.
- 7. **Click Next**. The EDA Tools Settings page appears. These exercises will use only Quartus II so the Tool Name should be <NONE> for all the Tool Types.
- 8. **Click Next**. The Device Family page appears. Select Stratix II as the Device Family and select No, I want to allow the Compiler to choose a device.
- 9. Click Next 2 times. The summary page appears. The summary page gives information about your project.
- 10. **Click Finish**. You have just finished the project creation. You should see the top-level entity (mux4) in the Compilation Hierarchies tab of the Project Navigator window.
- 11. From the File menu select new or click on  $\Box$ . New file dialog box will appear and select VHDL file.

| ew                                                                         |    |
|----------------------------------------------------------------------------|----|
| Design Files Other Files Project Files Other Documents                     |    |
| AHDL File<br>Block Diagram/Schematic File<br>EDIF File<br>Verilog HDL File |    |
| VHDL File                                                                  |    |
|                                                                            |    |
|                                                                            |    |
|                                                                            |    |
|                                                                            |    |
| OK Cano                                                                    | el |

Figure 5-2.

- 12. VHDL text editor will appear.
- 13. Before the beginning of your code (before the ENTITY), type the following:



LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

USE ieee.std\_logic\_unsigned.all;

14. Write your source code.

Remember to use the same input and output port names as shown in Figure 5-1.

15. Go to File menu and Choose Save As.

Save new VHDL text file to <path>\altera\_trn\vhdl\lab5a\reg.vhd.

#### Step 3 (Synthesize the design)

- 1. From the Processing menu choose Start-> Start Analysis and Synthesis
- 2. This will save and check for syntax and semantic errors for the file reg.vhd. It will then synthesize the

design. When you see the message "Netlist Analysis and synthesis was successful", click OK.

#### **Step 4 (Do a functional simulation)**

- 1. The stimulus file has been created for you to verify the functionality of your design. If you are interested in learning how to create your own stimulus file, please go to the Appendix of this manual.
- 2. Go to the Assignments menu and choose Simulator. In the Simulator mode section select Functional.

| General                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Simulator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Files</li> <li>User Libraries</li> <li>Device</li> <li>Timing Requirements &amp; Options</li> <li>EDA Tool Settings</li> <li>Compilation Process</li> <li>Analysis &amp; Synthesis Settings</li> <li>Fitter Settings</li> <li>Timing Analyzer</li> <li>Design Assistant</li> <li>SignalT ap II Logic Analyzer</li> <li>SignalProbe Settings</li> <li>Simulator</li> <li>Software Build Settings</li> <li>Stratix GX Registration</li> <li>HardCopy Settings</li> </ul> | Select options for simulations.         Simulation mode:       Functional         Simulation input:          Simulation period          © Run simulation until all vector stimuli are used          © End simulation at:       ns         Simulation options          © Automatically add pins to simulation output waveforms          Check outputs          © Setup and hold time violation detection          © Gitch detection:       1.0       ns         © Simulation coverage reporting           Power Estimation |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | OK Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |



3.

- 4. Choose **OK**.
- 5. From the Processing menu select the Generate Functional Simulation Netlist, Click OK when done.
- 6. From the Processing menu select Start Simulation or click on . When you see the message, "Simulation was successful", click OK.
- 7. Check to see if you get the same results shown in Figure 5-6.

| Sim | ulation Waveforms |       |                                     |          |                  |                       |                       |          |
|-----|-------------------|-------|-------------------------------------|----------|------------------|-----------------------|-----------------------|----------|
| Mas | er Time Bar: 16.  | 3 ns  | <ul> <li>Image: Pointer:</li> </ul> | 22.22 ns | Interval: 5.92 r | ns Start:             | End:                  |          |
|     | Name              | ť<br> | 0 ps<br>16.3 ns                     | 40.0 ns  | 80.0 ns          | 120 <sub>,</sub> 0 ns | 160 <sub>,</sub> 0 ns | 200.0 ns |
|     | clk               | 3     |                                     |          |                  |                       |                       |          |
|     | clr               | 3     |                                     |          |                  |                       |                       |          |
|     | clken             | 3     |                                     |          |                  |                       |                       |          |
|     | 🗉 in_reg          | ٩     | 11111                               |          | 1010             |                       | 0101                  |          |
| ٩   | ■ out_reg         | ٩.,   |                                     |          | 0000             |                       | X 01/01               |          |
|     |                   |       |                                     |          |                  |                       |                       |          |



## **Step 5 (Close the project)**

1. From the File menu select Close project option to close the project.



# <u>Part B</u>

The 2-bit counter can be constructed using the +1 operation. It is used to help the state machine track the cycles of the sequential multiplication.

Functionality of the 2-bit counter:

If clr='0', the counter is cleared immediately.

Otherwise, if clr='0', then the count increments by 1 at the rising edge of clock.

Note: This is an asynchronous clear.



Figure 5-7.

## Step 1 (Ask the instructor for the <pathname>)

- 1. **<pathname>** is\_\_\_\_\_
- 2. Use this **<pathname>** pathname for this Lab

## Step 2 (Create new project and open VHDL text editor file)

Create a project by using the New Project Wizard. To create a project using the New Project Wizard, please follow the following steps:

- 1. Select **New Project Wizard** from the File menu. The first time you open the New Project Wizard, it shows the introduction page; you can **click Next** to proceed to the first page of the wizard.
- 3. Type a name for the project in the project name box. For this lab, type counter.
- 4. **Type counter** as the name of the top-level design entity of the project in the top-level design entry box.
- 5. Click Next. The second page of the New Project Wizard appears.
- 6. At this point, there is no file to add because we will create the counter source file later.
- 7. Click Next. The EDA Tools Settings page appears. These exercises will use only Quartus II so the Tool Name should be <NONE> for all the Tool Types.
- 8. **Click Next**. The Device Family page appears. Select Stratix II as the Device Family and select No, I want to allow the Compiler to choose a device.



- 9. Click Next 2 times. The summary page appears. The summary page gives information about your project.
- 10. **Click Finish**. You have just finished the project creation. You should see the top-level entity (mux4) in the Compilation Hierarchies tab of the Project Navigator window.
- 11. From the File menu select new or click on . New file dialog box will appear and select VHDL file.

| New 🗙                                                  |
|--------------------------------------------------------|
| Design Files Other Files Project Files Other Documents |
| AHDL File<br>Block Diagram/Schematic File<br>EDIF File |
| Verilog HDL File<br>VHDL File                          |
|                                                        |
|                                                        |
|                                                        |
|                                                        |
|                                                        |
|                                                        |
| OK Cancel                                              |

Figure 5-8.

- 12. VHDL text editor will appear.
- 13. Before the beginning of your code (before the ENTITY), type the following:

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

USE ieee.std\_logic\_unsigned.all;

14. Write your source code.

Remember to use the same input and output port names as shown in Figure 5-7.

15. Go to File menu and Choose Save As.

Save new VHDL text file to <path>\altera\_trn\vhdl\lab5b\counter.vhd.

#### **Step 3 (Synthesize the design)**

- 1. From the Processing menu choose Start-> Start Analysis and Synthesis
- 2. This will save and check for syntax and semantic errors for the file counter.vhd. It will then synthesize

the design. When you see the message "Analysis and synthesis was successful", click OK.



#### **Step 4 (Do a functional simulation)**

- 1. The stimulus file has been created for you to verify the functionality of your design. If you are interested in learning how to create your own stimulus file, please go to the Appendix of this manual.
- 2. Go to the Assignments menu and choose choose Simulator. In the Simulator mode section select

#### Functional.

| Category:         General         Files         User Libraries         Device         Timing Requirements & Options         EDA Tool Settings         Compilation Process         Analysis & Synthesis Settings         Fitter Settings         Simulation period         SignalTool Settings         Simulation period         SignalToob Settings         Simulation at         SignalToob Settings         Simulation period         Bandatore         Bandatore         Bandatore         Static KX Registration         HardCopy Settings         Simulation coverage reporting         Overwrite simulation input file with simulation results         uPCore Transaction Model File Name:         Power Estimation  | settings - reg                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ×      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| General       Files         User Libraries       Device         Timing Requirements & Options       Select options for simulations.         EDA Tool Settings       Simulation mode:         Fitter Settings       Simulation period         Timing Analyzer       Simulation period         Design Assistant       Simulation at:         SignalTools Settings       Simulation at:         Simulation       Simulation output waveforms         Statist KS Registration       HardCopy Settings         HardCopy Settings       Simulation coverage reporting         Overwrite simulation input file with simulation results       uPCore Transaction Model File Name:         Prover Estimation       Dever Estimation | Category:                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |
| OK Cancel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Category:<br>General<br>Files<br>User Libraries<br>Device<br>Timing Requirements & Options<br>EDA Tool Settings<br>Compilation Process<br>Analysis & Synthesis Settings<br>Fitter Settings<br>Timing Analyzer<br>Design Assistant<br>SignalT ap II Logic Analyzer<br>SignalProbe Settings<br>Simulator<br>Software Build Settings<br>Stratix GX Registration<br>HardCopy Settings | Simulator         Select options for simulations.         Simulation mode:         Functional         Simulation input:         Simulation period         Run simulation until all vector stimuli are used         End simulation at:         Image: Simulation options         Automatically add pins to simulation output waveforms         Deck outputs         Setup and hold time violation detection         Glitch detection:         Simulation coverage reporting         Overwrite simulation input file with simulation results         uPCore Transaction Model File Name:         Power Estimation |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                   | ОК                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Cancel |

#### 3. Choose OK.

- 4. From the Processing menu select the Generate Functional Simulation Netlist, Click OK when done.
- 5. From the Processing menu select Start Simulation or click on . When you see the message, "Simulation was successful", click OK.
- 6. Check to see if you get the same results shown in Figure 5-12.



| Maste | er Time Bar: | 50.0 ns | Pc رو ا | inter: 104.52 r | is Interval: | 54.52 ns | Start    | End:     |          |
|-------|--------------|---------|---------|-----------------|--------------|----------|----------|----------|----------|
| 1     |              | Val     | 0 ps    | 40.0 ns         | 80.(         | Ins      | 120,0 ns | 160,0 ns | 200.0 ns |
|       | Name         | 50      |         | 50.0            | ns           |          |          |          |          |
|       | clk          | BO      |         |                 |              |          |          |          |          |
|       | clr          | B 1     |         |                 |              |          |          |          |          |
| 0     | 🛨 sum        | HO      |         | 0               |              |          | 2 X      | 3 )      |          |
| 18    |              |         |         |                 | Figure 5-    | 2.       |          |          |          |

# **Step 5 (Close the project)**

1. From the File menu select Close project option to close the project.

# **END OF EXERCISE 5**







**Objective:** Three-part exercise:

# Part A – Examine the controlling state machine

## Part B – Build a 4x4 multiplier using LPM\_MULT

# Part C – Putting it all together by declaring and instantiating the lower-level components

# Part A

You have now completed building all of the components necessary to build the 8x8 multiplier, except for the controlling state machine and the 4x4 multiplier (Part B). Due to time, the controlling state machine has been written for you and is located in cpath>\altera\_trn\vhdl\lab6a\control.v.

This state machine will manage all the operation that occurs within the 8 X 8 multiplier.

The state machine will perform the ( $(a[3..0] * b[3..0]) * 2 \land 0$ ) multiplication in the first cycle (LSB state) after the input signal *start* becomes a '1'. This intermediate result is saved in an accumulator.

In the second clock cycle (MID state), the ( (a[3..0] \* b[7..4]) \* 2 ^ 4) multiplication is performed. The multiplication result is added with the content of the accumulator and clocked back into the accumulator.

In the third clock cycle (MID state), the ( (a[7..4] \* b[3..0]) \* 2 ^ 4) multiplication is performed. The multiplication result is added with the content of the accumulator and clocked back into the accumulator.

In the fourth clock cycle (MSB state), the ( $(a[7..4] * b[7..4]) * 2 ^ 8$ ) multiplication is performed. The multiplication result is added with the content of the accumulator and clocked back into the accumulator. This result is the final result:

result[15..0] = a [7..0] \* b[7..0]

 $= ((a[7..4] * b[7..4]) * 2^8) + ((a[7..4] * b[3..0]) * 2^4) + ((a[3..0] * b[7..4]) * 2^4) + ((a[3..0] * b[7..4]) * 2^0)$ 

**NOTE**: There are two inputs to the state machine *start* and *count*[1..0]. The *start* signal is a single cycle high-true signal. When *start* becomes a '1', it indicates that multiplication can begin at next clock cycle. The *start* signal can only be asserted for one clock cycle. The *start* signal shall stay a '0' until next 8 x 8 multiplication is to be performed. The *count*[1..0] signal is the output of a free running 2-bit counter. The *count*[1..0] signal is synchronously initialized by the *start* signal. *Count*[1..0] is used by the state machine to track the cycles of the multiplication.

Please also note that this is NOT the optimal design. The state machine design as you see it is intended for exercising your VHDL skills and not the ability to perform optimum solution.





X means a "don't care" in this state diagram.



# <u>Part B</u>

The last component you will build is a 4x4 multiplier.

You will use the LPM\_MULT supplied by Altera to build a multiplier with a 4-bit multiplicands and an 8-bit result output.



## Step 1 (Ask the instructor for the <pathname>)

- 1. **<pathname>** is\_\_\_\_\_\_
- 2. Use this **<pathname>** pathname for this Lab

## Step 2 (Use the MegaWizard Plug-In Manager to Create the Multiplier)

To create a VHDL file which instantiates the LPM\_MULT, please follow the following steps:

- 1. Choose Tools>MegaWizard Plug-In Manager. In the window that appears, select Create a new custom megafunction variation. Click on Next.
- 2. In the window that appears, expand the **arithmetic** folder and select **LPM\_MULT**. Choose **VHDL** output. Name the **output file pathname>\lab6b\mult4x4**. Click on **Next**.
- 3. Set the width of the **dataa** bus to be **4** bits and the width of the **datab** bus to be **4** bits. For the remaining settings in this window, use the defaults that appear. Select **Next**.
- 4. For the next 2 windows that appear, simply use the default settings by selecting Next.
- 5. Select **Finish** in the final window that appears.

The multiplier is built. A VHDL file (mult4x4.vhd) has been created which instantiates LPM\_MULT. To view this file, go to the File menu, select Open and select mult4x4.vhd.



## Step 3 (Create a Project for the Multiplier)

Create a project by using the New Project Wizard. To create a project using the New Project Wizard, please follow the following steps:

- 1. Select **New Project Wizard** from the File menu. The first time you open the New Project Wizard, it shows the introduction page; you can **click Next** to proceed to the first page of the wizard.
- 3. Type a name for the project in the project name box. For this lab, type mult4x4.
- 4. **Type mult4x4** as the name of the top-level design entity of the project in the top-level design entry box.
- 5. Click Next. The second page of the New Project Wizard appears.
- 6. **Click Next**. The EDA Tools Settings page appears. These exercises will use only Quartus II so the Tool Name should be <NONE> for all the Tool Types.
- 7. **Click Next**. The Device Family page appears. Select Stratix II as the Device Family and select No, I want to allow the Compiler to choose a device.
- 8. Click Next 2 times. The summary page appears. The summary page gives information about your project.
- 9. **Click Finish**. You have just finished the project creation. You should see the top-level entity (mux4) in the Compilation Hierarchies tab of the Project Navigator window.

## Step 4 (Synthesize the design)

- 1. From the Processing menu choose Start-> Start Analysis and Synthesis
- 2. This will save and check for syntax and semantic errors for the file mult4x4.vhd. It will then synthesize

the design. When you see the message "Analysis and synthesis was successful", click OK.

## **Step 5 (Do a functional simulation)**

1. The stimulus file has been created for you to verify the functionality of your design. If you are interested in learning how to create your own stimulus file, please go to the Appendix of this manual.



1

2. Go to the Assignments menu and choose Simulator. In the Simulator mode section select

#### Functional.

| Settings - reg                                                                                                                                                                                                                                                                                                                                                                                       | ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category:                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| General<br>→ Files<br>→ User Libraries<br>→ Device<br>→ Timing Requirements & Options<br>⊕ EDA Tool Settings<br>→ Compilation Process<br>⊕ Analysis & Synthesis Settings<br>⊕ Fitter Settings<br>→ Timing Analyzer<br>→ Design Assistant<br>→ SignalT ap II Logic Analyzer<br>→ SignalProbe Settings<br>→ Simulator<br>⊕ Software Build Settings<br>→ Stratix GX Registration<br>→ HardCopy Settings | Simulator         Select options for simulations.         Simulation mode:         Functional         Simulation input         Simulation period            • Run simulation until all vector stimuli are used            End simulation at:            rst         Simulation options:            Automatically add pins to simulation output waveforms            Check outputs            Stimulation coverage reporting            Overwrite simulation input file with simulation results            uPCore Transaction Model File Name:            Power Estimation |
|                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

- 3. Choose OK.
- 4. From the Processing menu select the Generate Functional Simulation Netlist, Click OK when done.
- 5. From the Processing menu select Start Simulation or click on . When you see the message, "Simulation was successful", click OK.
- 6. Check to see if you get the same results shown in Figure 6-6.



| Mast     | er Time Bar: | 40.0 ns             | • • Pointer | 903 p   | s Interval: | -39.1 ns | Start              | 0 ps    | End:     | 80.0 ns                               |
|----------|--------------|---------------------|-------------|---------|-------------|----------|--------------------|---------|----------|---------------------------------------|
|          | Name         | Value at<br>40.0 ns | 0 ps        | 10.0 ns | 20.0 ns     | 30.0 ns  | 40.0 ns<br>40.0 ns | 50.0 ns | 60.0 ns  | 70.0 ns                               |
| <b>1</b> | 🛨 ina        | U 7                 |             | X 2     | X 4         | X 6      | <del>7</del>       | X 8     | ×        | 9 <u>×</u> 10                         |
| <b>1</b> | 🗉 inb        | U 2                 |             |         |             | 2        | 2                  |         |          |                                       |
| 0        | Шр           | U 14                |             | X4      | <u>X 8</u>  | X 12     | 14                 | X 16    | <u>X</u> | 1 <u>8 X 20</u>                       |
|          |              |                     |             |         |             |          |                    |         |          |                                       |
|          |              |                     |             |         |             |          |                    |         |          |                                       |
|          |              |                     | 1           |         |             |          | 1. i.              |         |          | · · · · · · · · · · · · · · · · · · · |

Figure 6-6.

## **Step 6 (Close the project)**

1. From the File menu select Close project option to close the project.



# <u>Part C</u>

You have now completed building all of the components necessary to build the 8x8 multiplier.

Making use of the knowledge you have gained up to this point, you should instantiate each component in a top-level design and connect all signals as shown in Figure 6-7. To save time, we have completed part of this for you. Please finish this task by instantiating mult4x4 and shifter. You will also need to declare the PRODUCT signals. You have successfully completed the Introduction to VHDL class once your top-level design is compiled and simulated correctly.

### Congratulations!

You have completed the implementation of the following 8x8 multiplier.

result[15..0] = a [7..0] \* b[7..0]

 $= ((a[7..4] * b[7..4]) * 2^8) + ((a[7..4] * b[3..0]) * 2^4) + ((a[3..0] * b[7..4]) * 2^4) + ((a[3..0] * b[7..4]) * 2^0)$ 





Figure 6-7.

## Step 1 (Ask the instructor for the <pathname>)

- 1. <pathname> is\_\_\_\_\_
- 2. Use this **<pathname>** pathname for this Lab



## Step 2 (Create new project and open VHDL text editor file)

Create a project by using the New Project Wizard. To create a project using the New Project Wizard, please follow the following steps:

- 1. Select **New Project Wizard** from the File menu. The first time you open the New Project Wizard, it shows the introduction page; you can **click Next** to proceed to the first page of the wizard.
- 3. Type a name for the project in the project name box. For this lab, type mult8x8.
- 4. **Type mult8x8** as the name of the top-level design entity of the project in the top-level design entry box.
- 5. Click Next. The second page of the New Project Wizard appears.
- 6. Click Add All to add the partially completed mult8x8.vhd file.
- 7. Click Next. The EDA Tools Settings page appears. These exercises will use only Quartus II so the Tool Name should be <NONE> for all the Tool Types.
- 8. **Click Next**. The Device Family page appears. Select Stratix II as the Device Family and select No, I want to allow the Compiler to choose a device.
- 9. Click Next 2 times. The summary page appears. The summary page gives information about your project.
- 10. **Click Finish**. You have just finished the project creation. You should see the top-level entity (mult8x8) in the Compilation Hierarchies tab of the Project Navigator window.
- 11. From the File menu select Open. Open mult8x8.vhd.
- 12. The VHDL text editor will appear.
- 13. Complete the source code to instantiate mult4x4, shifter, and the PRODUCT signals.

Remember to use the same input and output port names as shown in Figure 6-7.

- 14. Go to File menu and Choose Save.
- 15. The lower-level components have been created in different directories than the current directory. In order for Quartus II to find these lower-level components, it must have a search path. Therefore, you must do the following:
  - Go to Assignments menu and Choose Settings. From the Files & Directories category choose User Libraries tab. Browse the file locations:
    - a) Choose the directory structure **<path>\lab1**. Click on **open**.
    - b) Choose the directory structure **<path>\lab2**. Click on **open**.
    - c) Choose the directory structure **<path>\lab3**. Click on **open**.
    - d) Choose the directory structure **<path>\lab4**. Click on **open**.
    - e) Choose the directory structure **<path>** lab5a. Click on open.
    - f) Choose the directory structure **<path>\lab5b**. Click on **open**.

- g) Choose the directory structure **<path>\lab6a**. Click on **open.**
- h) Choose the directory structure **<path>\lab6b**. Click on **open.**
- i) Click OK.

### Step 3 (Synthesize the design)

- 1. From the Processing menu choose Start-> Start Analysis and Synthesis
- 2. This will save and check for syntax and semantic errors for the file mult8x8.vhd. It will then synthesize

the design. When you see the message "Analysis and synthesis was successful", click OK.

### Step 5 (Do a functional simulation)

1. The stimulus file has been created for you to verify the functionality of your design. If you are

interested in learning how to create your own stimulus file, please go to the Appendix of this manual.

2. Go to the Assignments menu and choose Simulator. In the Simulator mode section select

#### Functional.

| egory:                                                                                                                                             |                                                                                                                                                                                                                                                                 |   |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| - General                                                                                                                                          | Simulator                                                                                                                                                                                                                                                       |   |
| Files<br>User Libraries<br>Device                                                                                                                  | Select options for simulations.                                                                                                                                                                                                                                 |   |
| - Timing Requirements & Options<br>EDA Tool Settings<br>Compilation Process<br>Analysis & Synthesis Settings<br>Fitter Settings<br>Timing Analyzer | Simulation mode: Functional Simulation input: Simulation period Function all vector stimuli are used                                                                                                                                                            | • |
| - Design Assistant<br>- SignalTap II Logic Analyzer                                                                                                | C End simulation at:                                                                                                                                                                                                                                            |   |
| - Simulator<br>- Simulator<br>- Software Build Settings<br>Stratix GX Registration<br>HardCopy Settings                                            | Simulation options<br>Automatically add pins to simulation output waveforms<br>Check outputs<br>Setup and hold time violation detection<br>Glitch detection: 1.0 ns<br>Simulation coverage reporting<br>Overwrite simulation input file with simulation results |   |
|                                                                                                                                                    | uPCore Transaction Model File Name:                                                                                                                                                                                                                             |   |
|                                                                                                                                                    | Power Estimation                                                                                                                                                                                                                                                |   |
|                                                                                                                                                    | DK Cance                                                                                                                                                                                                                                                        |   |

#### 3. Choose OK.

4. From the Processing menu select the Generate Functional Simulation Netlist, Click OK when done.



- 5.
- 6. From the Processing menu select Start Simulation or click on . When you see the message, "Simulation was successful", click OK.
- 7. Check to see if you get the same results shown in Figure 6-11.

| Simulation Waveforms     |           |                     |                   |         |         |                       |          |               |                       |          |          |                       |                       |                       |
|--------------------------|-----------|---------------------|-------------------|---------|---------|-----------------------|----------|---------------|-----------------------|----------|----------|-----------------------|-----------------------|-----------------------|
| Master Time Bar: 12.5 ns |           |                     | Pointer:          |         | : 14    | 141.38 ns             |          | ıl: 128.88 ns |                       | Start:   |          | End:                  |                       |                       |
|                          | Name      | Value at<br>12.5 ns | 0 ps 4<br>12.5 ns | 40.0 ns | 80.0 ns | 120 <sub>,</sub> 0 ns | 160,0 ns | 200,0 ns      | 240 <sub>,</sub> 0 ns | 280,0 ns | 320,0 ns | 360 <sub>,</sub> 0 ns | 400 <sub>1</sub> 0 ns | 440 <sub>,</sub> 0 ns |
|                          | clk       | BO                  |                   |         |         |                       |          |               |                       |          |          |                       |                       |                       |
|                          | reset     | B 1                 |                   |         |         |                       |          |               |                       |          |          |                       |                       |                       |
|                          | start     | B 1                 |                   |         |         |                       |          |               |                       |          |          |                       |                       |                       |
| <b>B</b>                 | ± a       | H 01                |                   |         | 0       | 1                     |          | X             |                       |          | 00       |                       |                       |                       |
| <b>B</b>                 | Шb        | H 01                |                   |         | 0       | 1                     |          |               |                       |          | 00       |                       |                       |                       |
| 1                        | 🖭 result  | H 0000              |                   |         |         |                       | 0100     | n             |                       |          | X        |                       | 0090                  |                       |
| ٦                        | 🔳 abcdefg | H 7E                |                   |         |         | 71                    |          |               |                       | Х 3      | ο χ      | 6D                    |                       | X 79                  |
|                          | done_flag | BO                  |                   |         |         |                       |          |               |                       |          |          |                       |                       |                       |
|                          | control:u | B code              |                   |         |         | code                  | idle     |               |                       | X cod    | e.lsb X  | code.m                | id                    | Xcode.msb             |
|                          |           |                     |                   |         |         |                       |          |               |                       |          |          |                       |                       |                       |

Figure 6-11.

## **Step 7 (Close the project)**

1. From the File menu select Close project option to close the project.

# **END OF EXERCISE 6**

# APPENDIX





# How to create a stimulus file:

- 1. Create a new waveform stimulus for simulation. Click on
- 2. Under Other Files tab: Choose Vector Waveform File



- 3. Click OK.
- 4. Enter nodes into the waveform file. Edit menu -> Insert Node or Bus
- 5. Set the inputs to the appropriate values.
- 6. Save the file.



