

### **CPE 324 Advanced Logic Design Laboratory**

# Laboratory Assignment #3 Design Capture and FPGA-based Rapid Prototyping using the DE2-115 Platform (Implementation of an 8-bit Subtractor/Adder)

(10% of Final Grade)

The purpose of this laboratory project is to provide an opportunity for students to gain experience using the Quartus  $II^{\otimes}$  Computer Aided Design tool suite to implement a simple digital design. Students will first gain experience creating a hierarchical design using traditional schematic capture techniques. They will then enter the same general design using the Verilog Hardware Description Language. In this case, students will first create a structural Verilog representation and then a behavioral one. Design correctness will be validated experimentally by configuring the DE2-115's Cyclone  $IV^{\otimes}$  Field Programmable Gate Array, FPGA.

#### Subtractor/Adder Module

The example design that is to be created in three forms and verified in this laboratory is an eight-bit two's complement subtractor/adder module as shown in Figure 1.



#### **Function:**

```
if (SUB_ADD) = '1' then D\_S <= A \cdot B \cdot B\_Cin --subtract B \text{ and } B\_Cin \text{ from } A if (B>A) B_Cout <= '1' {borrow} else B_Cout <= '0' {no borrow} else {-- if SUB_ADD='0'} D_S <= (A + B)[7.0]+B_Cin; {lower 8 bits of A + B + B_Cin} B_Cout <= (A+B+B_Cin)[8]; {most significant bit of A+B+B_Cin} }
```

Figure 1: Eight -Bit Two's Complement Subtractor/Adder Module

Its function is to output the valid two's complement difference or sum between two eight-bit quantities that are present on its A and B input buses. This module is designed to be cascaded with itself to create proportionately larger size subtraction/addition operations. This is accomplished through the use of the borrow/carry input,  $B_{-}CIN$ , and a borrow/carry output,  $B_{-}COUNT$ . The  $SUB_{-}ADD$  input is used to determine whether the other inputs will be subtracted or added to one another. Whenever the  $SUB_{-}ADD$  line is set to a logic high, the  $D_{-}S$  output produces a two's complement difference of A-B and the  $B_{-}COUNT$  indicates if there is a borrow is required at the most significant bit position. Whenever the  $SUB_{-}ADD$  line is set to a logic low, the  $D_{-}S$  output produces the sum of A+B and the  $B_{-}COUNT$  line indicates if a borrow or carry is generated at the most significant bit position. The module itself can be implemented in a number of ways (such as a ripple or look-ahead type logic) with each style of implementation presenting various complexity/performance trade-offs.

#### Prelab Assignment:

It is expected that students are able to enter designs into Quartus II using both schematic capture and Verilog HDL techniques. This is discussed in some detail in the manual "Design Entry, Simulation, and Emulation using the Altera Quartus II<sup>®</sup> and ModelSim<sup>®</sup> CAD Software and the Terasic DE2-115 Rapid Prototyping Platform" that is present on the course canvas course delivery website. Simulation will not be used in this laboratory. Instead designs will be validated experimentally using an actual hardware implementation made on the Altera Terasic DE2-115<sup>®</sup> rapid prototyping platform. This design will temporarily replace the Logic Trainer application that was utilized in the first two laboratory experiments.

## Part I -- Hierarchical Schematic Capture Design Entry and Implementation using Quartus II

#### **Background:**

In this part of the laboratory you will be asked to utilize schematic capture techniques to create a two's complement ripple Subtractor/A dder module using hierarchical schematic capture design entry methods. As the name implies, hierarchical designs utilize a hierarchy of levels of abstraction to represent the design. In this type of design, one does not implement the design in a flat manner where the entire design is placed on a single design sheet that utilizes the lowest-level gate/flip-flop components (i.e. primitives) but rather, the design is implemented on multiple sheets that are used to form a hierarchy of components. In this manner complex components are created using a set of less complex components, which themselves may be made up of more basic components. This continues until the components that are the lowest level to be modeled are encountered. These primitive components are usually at the gate, flip-flop or latch level.

#### Design Capture Assignment:

You are to develop of multi-level hierarchical design of a ripple adder using schematic capture techniques. The top level of the design should be as shown in Figure 2. It is to be made up of two four-bit adders that are cascaded together by connecting the  $B\_COUT$  output of one four\_bit module to the  $B\_Cin$  input of the other module.



Figure 2: Top-Level Representation of Eight-bit Adder in Quartus II (eight bit sub add module)

Each four-bit module should be composed of four one-bit full subtractor/adder modules as shown in Figure 3.



Figure 3: Representation of Four-bit Adder In Quartus II (four\_bit\_sub\_add module)

Each full Subtractor/Adder module should then be represented as shown in Figure 4.



Figure 4: Representation of full Subtractor/Adder (fullSubAdd module)

The 2-to-1 multiplexer should then be represented as shown in Figure 5.



Figure 5: Representation of 2 to 1 Multiplexer ( $mux2_1$  module)

Components are to be created from the bottom level up. After the design has been entered, it should be successfully compiled. Note that the XOR3 gate can also be represented in the same manner by using two XOR2 gates if desired but there does exist an XOR3 component in one of the Quartus II libraries so this is not absolutely necessary.

#### Implementation:

After successful compilation, *record the number of Logic Elements and other FPGA resources used in this version of the design*. This should appear as part of the main compilation window. After successful compilation, the design should then be verified by implementing it directly on the DE2-115 rapid prototyping platform. In most cases simulation would be a precursor to this step since it provides the more detailed information but in some cases it makes sense to proceed directly to implementation. This is made possible because of the relative speed at which implementation can occur (much faster that wiring up TTL logic on a wireless protoboard!). Before doing this you will need to assign the correct FPGA pin numbers that correspond to the DE2-115's connection to switches and discrete LED's to the top level Input and Output pins of the design. The manner in which this is to be done is shown in Table 1.

Table 1: Cyclone IV Pin Location to be used on DE2-115 Board.

| Design I/O  |           | DE2-115 Connections   |         |
|-------------|-----------|-----------------------|---------|
| Signal Name | Direction | Cyclone IV Pin Number | Element |
| A[7]        | Input     | PIN_AB26              | SW[7]   |
| A[6]        | Input     | PIN_AD26              | SW[6]   |
| A[5]        | Input     | PIN_AC26              | SW [5]  |
| A[4]        | Input     | PIN_AB27              | SW [4]  |
| A[3]        | Input     | PIN_AD27              | SW[3]   |
| A[2]        | Input     | PIN_AC27              | SW[2]   |
| A[1]        | Input     | PIN_AC28              | SW[1]   |
| A[0]        | Input     | PIN_AB28              | SW[0]   |
| B[7]        | Input     | PIN_AA22              | SW [15] |
| B[6]        | Input     | PIN_AA23              | SW [14] |
| B[5]        | Input     | PIN_AA24              | SW [13] |
| B[4]        | Input     | PIN_AB23              | SW [12] |
| B[3]        | Input     | PIN_AB24              | SW [11] |
| B[2]        | Input     | PIN_AC24              | SW [10] |
| B[1]        | Input     | PIN_AB25              | SW [9]  |
| B[0]        | Input     | PIN_AC25              | SW [8]  |
| B_CIN       | Input     | PIN_Y 24              | SW [16] |
| SUB_ADD     | Input     | PIN_Y 23              | SW [17] |
| B_COUT      | Output    | PIN_F17               | LEDG[8] |
| D_S[7]      | Output    | PIN_G21               | LEDG[7] |
| D_S[6]      | Output    | PIN_G22               | LEDG[6] |
| D_S[5]      | Output    | PIN_G20               | LEDG[5] |
| D_S[4]      | Output    | PIN_H21               | LEDG[4] |
| D_S[3]      | Output    | PIN_E24               | LEDG[3] |
| D_S[2]      | Output    | PIN_E25               | LEDG[2] |
| D_S[1]      | Output    | PIN_E22               | LEDG[1] |
| D_S[0]      | Output    | PIN_E21               | LEDG[0] |

As a minimum the correct functionality of the design should be demonstrated to the laboratory instructor which will

- 1) Add two numbers that do not generate a carry.
- 2) Subtract two numbers that do not generate a borrow.
- 3) Add two numbers in which there is a pending carry.
- 4) Subtract two numbers when there is a pending borrow.
- 5) Add two numbers where a carry in propagates all the way from LSB to carry out
- 6) Subtract two numbers where a borrow in propagates all the way from LSB and generates a borrow out request.
- 7) Add two numbers that causes an overflow into the carry bit.
- 8) Subtract a larger positive number from a smaller one generating a negative result if the MSB is interpreted as the sign bit.

#### Part II -- Verilog HDL Entry and Implementation using Quartus II

In this part of the laboratory experiment, you are to implement two functionally equivalent designs of the two's complement adder/subtractor module Quartus II using the Verilog HDL.

#### Structural Verilog HDL Design Implementation:

The Verilog HDL design shown in Figure 6 is a structural (hierarchical) Verilog model of the ripple two's complement subtractor/adder design that was implemented using schematic capture techniques in Part 1 of this laboratory. A soft copy of this listing can be found on Canvas. The purpose of this laboratory is not design creation but is for each student to develop proficiency with the Quartus II design tool and to make relevant observations that can be generally applied to designs that the student may create in the future.

```
// Structural Representation of Adder/Subtractor Module
// presented in Part I of Laboratory Experiment
// B. Earl Wells -- University of Alabama Huntsville, 2014
// This version places all component modules in a single file
// Note: it is also possible to include each of the component
// modules in separate files and set up the profile such that
// it references each of these files.
// It is good practice in Quartus to give the project the same
// name as the top-level module
// Top level module
// eight-bit subtractor/adder
module eight bit sub add(D S,B COUT,A,B,B CIN,SUB ADD);
    output [7:0] D S;
    output B COUT;
    input [7:0] A,B;
    input B_CIN,SUB ADD;
    wire n0;
    four_bit_sub_add C0(D_S[3:0],n0,A[3:0],B[3:0],B_CIN,SUB_ADD);
    four_bit_sub_add C1(D_S[7:4],B_COUT,A[7:4],B[7:4],n0,SUB_ADD);
endmodule
// four-bit subtractor/adder
module four bit sub add(d s,b cout,a,b,b cin,sub add);
   output [3:0] d_s;
   output b cout;
   input [3:0] a,b;
   input b_cin,sub_add;
   wire n0, n1, n2;
   fullsubadd C0(d_s[0],n0,a[0],b[0],b_cin,sub_add);
   fullsubadd C1(d s[1],n1,a[1],b[1],n0,sub add);
   fullsubadd C2(d s[2],n2,a[2],b[2],n1,sub add);
   fullsubadd C3(d_s[3],b_cout,a[3],b[3],n2,sub_add);
endmodule
```

Figure 6: Representation of Eight-bit Adder/Subtractor in Structural Verilog HDL

```
-// full subtractor/adder
module fullsubadd(dif_sum,b_cout,x,y,b_cin,sub_add);
   output dif sum,b cout;
   input x,y,b_cin,sub add;
   wire n0, n1, n2, n3, n4;
   not
        CO(n0,x);
   mux2_1 C1(n1,x,n0,sub_add);
   and C2(n2,y,n1);
and C3(n3,y,b_cin);
   and C4(n4,n1,b_cin);
        C5(b_cout,n2,n3,n4);
   or
   xor C6(dif sum,x,y,b cin);
endmodule
// 2 to 1 multiplexer
module mux2 1(o,i0,i1,sel);
   output o;
   input i0,i1,sel;
   wire n0, n1, n2;
   not G0(n0,sel);
   and G1(n1,i0,n0);
   and G2(n2,i1,sel);
   or G3(o,n1,n2);
endmodule
```

Figure 6 (continued): Representation of Eight-bit Adder/Subtractor in Structural Verilog HDL

#### Implementation Assignment (structural design):

After successful compilation, *record the number of Logic Elements and other FPGA resources used in this version of the design*. This should appear as part of the main compilation window. Then verify the functionality of the design using the DE2-115 rapid prototyping platform. Before doing this you will need to assign the correct FPGA pin numbers that correspond to the DE2-115's connection to switches and discrete LED's to the top level Input and Output pins of the design. The manner in which this is to be done is shown in Table 1 from the first part of this laboratory.

As in the schematic design entry case of Part 1 the correct functionality of the design should be demonstrated to the laboratory instructor which will

- 1) Add two numbers that do not generate a carry.
- 2) Subtract two numbers that do not generate a borrow.
- 3) Add two numbers in which there is a pending carry.
- 4) Subtract two numbers when there is a pending borrow.
- 5) Add two numbers where a carry in propagates all the way from LSB to carry out
- 6) Subtract two numbers where a borrow in propagates all the way from LSB and generates a borrow out request.
- 7) Add two numbers that causes an overflow into the carry bit.
- 8) Subtract a larger positive number from a smaller one generating a negative result if the MSB is interpreted as the sign bit.

This can be the same set of design stimulus as was used previously.

#### Behavioral Verilog HDL Design Implementation:

The Verilog HDL design described in Figure 7 below represents a behavioral Verilog model of the two's complement adder/subtractor design that was implemented using schematic capture techniques and structural Verilog design methods. Enter this version of the subtractor/adder design and verify its

functionality through simulation and implementation. A soft copy of this listing can be found on the Angel page associated with the laboratory.

```
// Behavioral Representation of Adder/Subtractor Module
// presented in Part II of Laboratory 3 Experiment
// B. Earl Wells -- University of Alabama Huntsville, 2014
// Single -- Top-Level Module
module eight bit sub add(D S,B COUT,A,B,B CIN,SUB ADD);
   output reg [7:0] D_S;
   output reg B_COUT;
   input [7:0] A,B;
   input B_CIN,SUB_ADD;
   reg [8:0] Cbuf;
   always @(A or B or B_CIN or SUB_ADD) begin
      if (SUB_ADD) begin
        Cbuf = A - B - B CIN;
      else begin
        Cbuf = A + B + B CIN;
     D S = Cbuf[7:0];
      B COUT = Cbuf[8];
```

endmodule

Figure 7: Representation of Eight-bit Adder/Subtractor in Verilog HDL

#### Implementation Assignment (behavioral design):

After successful compilation, record the number of Logic Elements and other FPGA resources used in this version of the design. This should appear as part of the main compilation window. After successful compilation, the design should once again be verified in the same manner as before using the DE2-115 rapid prototyping platform. Before doing this students will need to assign the correct FPGA pin numbers that correspond to the DE2-115's connection to switches and discrete LED's input and output pins of the design. The manner in which this is to be done was shown in Table 1.

Student's should use the same set of stimulus input from previous designs to verify the correct functionality of the design to the laboratory instructor. This stimulus should as a minimum

- 1) Add two numbers that do not generate a carry.
- 2) Subtract two numbers that do not generate a borrow.
- 3) Add two numbers in which there is a pending carry.
- 4) Subtract two numbers when there is a pending borrow.
- 5) Add two numbers where a carry in propagates all the way from LSB to carry out
- 6) Subtract two numbers where a borrow in propagates all the way from LSB and generates a borrow out request.
- 7) Add two numbers that causes an overflow into the carry bit.
- 8) Subtract a larger positive number from a smaller one generating a negative result if the MSB is interpreted as the sign bit.

#### **Deliverables for Final Lab Report**

In completing this assignment you will be expected to present to the laboratory instructor the following set of deliverables as part of their laboratory report. The requirements for laboratory reports are specified in the Lab Report Format handout which can be referenced on the Laboratory Canvas website.

- 1. Part I screen shots of Quartus II Schematics for the schematic capture design assignment.
- 2. Stimulus input used to verify the functionality of the design.
- 3.Date and time of the DE2-115 demonstrations for each of the three implementations (one schematic capture and the two Verilog implementations).

#### **Post Laboratory Questions**

Students are also expected to answer the following questions that reflect upon their laboratory experiences and the output data of their simulations.

- 1 For your three versions of this design, what kind of compilation errors or warnings did you encounter? How did you correct the errors and how did you determine which warnings were important and which ones could be ignored?
- 2. How does hierarchical schematic capture and hierarchical structural Verilog HDL design techniques help one manage the complexity of the design process?
- 3. Do you think the stimulus you used is good enough to verify the full functionality of your design? Why or why not? Would this stimulus be good enough to be used to automatically test the design for manufacturing defects? Why or why not?
- 4. Were there any differences between the amount of FPGA resources that were used for each design. If so how did they differ. If not do you believe that the designs are implemented in the same manner by the Quartus II synthesis tool?
- 5.Describe the design trade-offs associated with the structural and behavioral Verilog versions in terms of ease of design entry and the ability to control the low level attributes of the design (such as what type of subtractor/adder is created).

Note: The due date of this laboratory is at the beginning of your Laboratory 4 lab session.