| Name:                                         | Servando_Olvera | ID#          | 1001909287   |  |
|-----------------------------------------------|-----------------|--------------|--------------|--|
| Date Submi                                    | tted:04-04-2024 | _ Time Submi | itted7:00_pm |  |
| CSE 3341 Digital Logic Design II              |                 |              |              |  |
| CSE 5357 Advanced Digital Logic Design        |                 |              |              |  |
| Spring Semester 2024                          |                 |              |              |  |
| Lab 5 – Eight-Bit Divider                     |                 |              |              |  |
| 150 points                                    |                 |              |              |  |
| Due Date – April 4, 2024, 11:59 PM            |                 |              |              |  |
| Submit on Canvas Assignments                  |                 |              |              |  |
| Note – Late submissions will not be accepted! |                 |              |              |  |

# **USIGNED VERISON**

# **DESIGN REQUIREMENTS**

Your assignment is to design a registered eight-bit divider that has the input/output diagram shown shown in class, and incorporates the non-restoring divider also discussed in class. Verilog code for the divider is posted on Canvas in the Reference Materials module.

### **DESIGN REQUIREMENTS**

- 1. Eight-bit divider
- 2. Unsigned numbers
- 3. Verilog implementation
- 4. Design verification (simulation)
- 5. DE10-Lite realization

#### **DESIGN PROCESS**

- 1. Design, implement, verify, and realize an unsigned version. (150 points)
- 2. Design, implement, verify, and realize a signed version. Extra credit (50 points).

#### **DESIGN VERIFICATION**

- 1. Simulate your design to verify its correctness. Use the following values of A and B in your simulations.
  - (a) 0FFF ÷ FF Display in hexadecimal on the HEX displays.
  - (b) 0FFF ÷ EE
  - (c)  $00AC \div FF$
  - (d)  $0067 \div 67$
  - (e)  $0000 \div 0A$
- 2. Include a screen shot of your simulation waveforms in your report.
- 3. Record the simulation results in a table for your report (use hexadecimal)
- 4. How many clock cycles does it take each case to complete? What would be the corresponding divide times for your fastest clock?

#### RTL ANALYSIS

- 1. Generate RTL diagrams using the Quartus Prime Netlist Viewer.
- 2. Record the compilation summary for your report. How many ALM, registers, and pins does your design require?

### **DE10-Lite IMPLEMENTATION (each version)**

1. Implement your design on the DE10-Lite using the following inputs/outputs using pin assignments of your choice.

Inputs A, B, Load A, Load B, Start, Clock (50 MHz), Reset

Outputs Aout, Bout, Q, R, Done.

Display Aout, Bout, A, B, Q, and R in hexadecimal on the HEX displays.

- 2. Include a table of your assignments in your report.
- 3. Program the DE10-Lite with your design.

*Note:* Since it was required to display A, B, Q & R in the same HEX display I deviated from the inputs/outputs listed above.

#### **DE10-Lite TESTING**

- 1. Test your implementations by applying the same patterns as above.
- 2. Record the test results in a table for your report.
- 3. Take a picture (or video) of your results for your report.

# **DATA PATH DIAGRAM**



# **CONTROL PATH DIAGRAM**



## **SYSTEM-VERILOG CODE**

#### **Top Module**

```
module Lab5
       input CLK, CLR, LOAD_NEXT,
input [7:0] X,
output logic [0:6] HEX,
output logic [3:0] CAT
);
        logic [15:0] A; // Dividend logic [7:0] B; // Divisor
       logic [7:0] Quotient;
logic [7:0] Remainder;
logic [15:0] Quo_Rem, OUT;
logic [3:0] load_val;
logic DONE;
       StateMachine A_B_Q_R_Display // Chose value to Display ( // Dividend .CLEAR(CLR), // Divisor .A(A), // Quotient, Remainder
            .CLEAR(CLR),
.A(A),
.B(B),
.Q_R(Quo_Rem),
.display(OUT),
.ins(load_val)
       );
       NBitRegister DIVIDEND_2
                                                              // Upper Half of Dividend
            .D(X) ,
.CLK(~load_val[0]) ,
.CLR(CLR),
.Q(A[15:8])
       NBitRegister DIVIDEND_1
                                                                // Lowr half of Dividend
            .D(X) ,
.CLK(~load_val[1]) ,
.CLR(CLR),
.Q(A[7:0])
                                                              // Divisor
       NBitRegister DIVISOR
            .D(X) ,
.CLK(~load_val[2]) ,
.CLR(CLR),
            .Q(B)
       );
       Divider DIVIDE
            .Dividend(A),
.Divisor(B),
             .Quotient(Quotient),
.Remainder(Remainder),
             .CLOCK(CLK),
.START(~load_val[3]),
             . DONE (DONE)
       );
```

```
NBitRegister QUOTIENT
                                                         // Quotient
▣
           .D(Quotient),
.CLK(~DONE),
.CLR(CLR),
.Q(Quo_Rem[15:8])
       NBitRegister REMAINDER
                                                         // Remainder
.D(Remainder),
            .CLK(~DONE),
.CLR(CLR),
.Q(Quo_Rem[7:0])
       Controller Mux
                                                       // Display Stuff
            .CLK(CLK).
            .CLEAR(CLR),
            .CLEAR(CLR),
.MODE(1'b1),
.D0(OUT[3:0]),
.D1(OUT[7:4]),
.D2(OUT[11:8]),
.D3(OUT[15:12]),
.CAT(CAT),
            .HEX(HEX)
       );
  endmodule
```

#### **Register Module**

```
module NBitRegister #(parameter N = 8)

E(
    input [N-1:0] D,
    input CLK, CLR,
    output logic [N-1:0] Q
);

always @ (negedge CLK, negedge CLR) begin
    if (CLR == 1'b0)
        Q <= 0;
    else if (CLK == 1'b0)
        Q <= D;
    end
endmodule</pre>
//data input values loaded in
```

### **Display Different Registers State Machine**

(Display Dividend or Divisor or Quotient & Remainder at the push of a button)

#### **Divider Module**

#### **Divider Control Module**

```
odule D Control
                 input Clock,
input Start,
input Rsign,
output logic AddSub,
output logic Dload,
output logic Rload,
input logic Rload,
input logic Rload,
inable load D register
output logic Rload,
inable load Q register
output logic Rshift,
output logic Rshift,
output logic Shift,
industry
output logic CDONE,
output logic CDONE,
output logic CDONE,
output logic ODNE,
[);
                    // State definitions
parameter Inits = 4'h0;
parameter Adds = 4'h1;
parameter Subs = 4'h3;
parameter Subs = 4'h3;
parameter Shifts1 = 4'h4;
parameter Shifts2 = 4'h5;
parameter Shifts3 = 4'h6;
parameter Shifts4 = 4'h7;
parameter Shifts4 = 4'h8;
parameter Shifts5 = 4'h8;
parameter Restore = 4'h8;
                      logic [3:0] State;
logic [2:0] Count;
                    // decode state variable for Moore model outputs
assign Rload = ((State == Inits) || (State == Subs1) || (State == Subs) || (State == Adds) || (State == Restore)) ? 1'b1 : 1'b0;
assign Dload = (State == Inits) ? 1'b1 : 1'b0;
assign AddSub = ((State == Inits) ? 1'b1 : 1'b0;
assign AddSub = ((State == Adds) || (State == Restore)) ? 1'b1 : 1'b1;
assign Rshift = ((State == Shifts1) || (State == Shifts2)) ? 1'b1 : 1'b0;
assign Qshift = ((State == Shifts1) || (State == Shifts2)) || (State == Shifts3) || (State == Shifts3) || (State == Shifts4)) ? 1'b1 : 1'b0;
assign DONE = (State == Ends) ? 1'b1 : 1'b0;
                      // counter for number of iterations
initial State = Inits;
                    always @(posedge Clock) begin
  if (State == Inits)
    Count = 0;
else if ((State == Shifts1) || (State == Shifts2)) begin
  if (Count == 7)
    Count = 0;
else
                                                 else
                                                              Count = Count + 1:
                                    end
                     end
                    // state transitions
always @(posedge Clock) begin
case (State)
Ends: if (Start == 1'b1) State = Inits; else State = Ends;
Inits: State = Subs1;
Subs1: if (Rsign == 1'b1) State = Shifts1; else State = Shifts2;
Subs1: if (Count == 0) begin if (Rsign == 1'b0) State = Shifts4; else State = Restore; end
else if (Rsign == 1'b1) State = Shifts1;
else State = Shifts2;
Adds: if (Count == 0) begin if (Rsign == 1'b0) State = Shifts4; else State = Restore; end
else if (Rsign == 1'b1) State = Shifts1; else State = Shifts2;
Shifts1: State = Adds;
Shifts2: State = Subs;
Shifts3: State = Ends;
Shifts4: State = Ends;
Shifts4: State = Ends;
                                    Shifts4: State = Ends;
Restore: State = Shifts3;
                                      endcase
                      end
       endmodule
```

#### **MUX Module**

#### **Shift Register Module**

#### **ALU Register**

#### **Four to One Decoder Module**

```
module four2one

[] (
    input [1:0] A,
    input [3:0] DO, D1, D2, D3,
    output logic [3:0] OUTPUT
);

always_comb
    case({A})
    2'b00: OUTPUT = D0; // 1st digit
    2'b01: OUTPUT = D1; // 2nd digit
    2'b10: OUTPUT = D2; // 3rd digit
    2'b11: OUTPUT = D3; // 4th digit
    endcase

endmodule
```

#### **MUX/Controller Module**

```
module Controller
⊟(
     input CLK, CLEAR, MODE,
input [3:0] D0, D1, D2, D3,
output logic [3:0] CAT,
output logic [0:6] HEX
 );
                                          // Digit in-code
// Active Digit on Hex Display
      logic [1:0] RA;
logic [3:0] out;
      logic clk190;
     clk_ladder clock
.CLK(CLK)
         .clk190(clk190)
                                       // Four to one module
      four2one decoder
.A(RA)
         .DO(DO),
         .D1(D1),
.D2(D2),
         .D3(D3)
         .OUTPUT(out)
     FSM digit
                                         // Finite State Machine
// Actively updates HEX digit
.CLK(clk190)
         .CLEAR(CLEAR),
         .SEL(RA)
         .CAT(CAT)
     binary2seven Hex
                                // Display Numbers
.BIN(out)
          .MODE (MODE),
          .SEV(HEX)
      );
 endmodule
```

### **Finite State Machine Module**

#### **Clock Ladder Module**

```
module clk_ladder #(parameter N = 32)

(input CLK,
output logic clk190, clk1
);
logic [N-1:0] ladder;
always_ff @(negedge CLK)
ladder <= ladder + 1;
assign clk190 = ladder[17]; // 50MHz/2^n+1
endmodule
```

### Binary to Seven-Seg Display Decoder Module

# **RTL DIAGRAMS**

## **Top Module**



# **Dividend & Divisor Registers**



## Divider



# **Shift Register**

(Same RTL Diagram on Shifting Divisor, Quotient & Remainder)



## Mux



## ALU



# **Divider Control Unit**



# **Remainder & Quotient Registers**



# **Display Different Registers State Machine**



### **MUX/Controller**



### **Clock Ladder**



### **Finite State Machine**



### Four to One Decoder



# **Binary to Seven Segment Display Hex**



# **Compilation Summary**



```
# of ALMs = 173
# of REGISTERS = 101
# of PINS = 22
```

## SIMULATION RESULTS WAVEFORM



| Test | Quotient<br>(Hex) | Remainder<br>(Hex) | Clock Cycles |
|------|-------------------|--------------------|--------------|
| a)   | 10                | 0F                 | ~ 34         |
| b)   | 11                | 31                 | ~ 40         |
| c)   | 00                | AC                 | ~ 42         |
| d)   | 01                | 00                 | ~ 40         |
| e)   | 00                | 00                 | ~ 42         |

• What would be the corresponding divide times for your fastest clock? Fastest divide time was ~ 34 clock cycles.

$$T = \frac{1}{f} = \frac{1}{50MHz} = 20 \ ns$$

$$T_{34 \text{ Cycles}} = 20 \text{ ns } x \text{ } 34 = 860 \text{ ns}$$

Fastest divide time was 680 ns

# **PIN ASSIGMENTS**

|    | tatu     | From              | То                     | Assignment Name   | Value    | Enabled |
|----|----------|-------------------|------------------------|-------------------|----------|---------|
| 1  | •        |                   | <mark>- CLR CLR</mark> | Location          | PIN_B8   | Yes     |
| 2  | •        |                   | <b>≅</b> CAT[0]        | Location          | PIN_AB19 | Yes     |
| 3  | •        |                   | CAT[1]                 | Location          | PIN_AA19 | Yes     |
| 4  | •        |                   | CAT[2]                 | Location          | PIN_Y19  | Yes     |
| 5  | •        |                   | <b>≅</b> CAT[3]        | Location          | PIN_AB20 | Yes     |
| 6  | •        |                   | SHEX[0]                | Location          | PIN_AA12 | Yes     |
| 7  | •        |                   | SHEX[1]                | Location          | PIN_AA11 | Yes     |
| 8  | •        |                   | SHEX[2]                | Location          | PIN_Y10  | Yes     |
| 9  | •        |                   | SHEX[3]                | Location          | PIN_AB9  | Yes     |
| 10 | •        |                   | HEX[4]                 | Location          | PIN_AB8  | Yes     |
| 11 | <b>*</b> |                   | SHEX[5]                | Location          | PIN_AB7  | Yes     |
| 12 | <b>~</b> |                   | <b>≅</b> HEX[6]        | Location          | PIN_AB17 | Yes     |
| 13 | •        |                   | <u>⊩</u> X[0]          | Location          | PIN_C10  | Yes     |
| 14 | •        |                   | <u>⊩</u> X[1]          | Location          | PIN_C11  | Yes     |
| 15 | <b>*</b> |                   | <u>⊩</u> X[2]          | Location          | PIN_D12  | Yes     |
| 16 | •        |                   | <u>⊩</u> X[3]          | Location          | PIN_C12  | Yes     |
| 17 | <b>*</b> |                   | <u>in</u> _ X[4]       | Location          | PIN_A12  | Yes     |
| 18 | <b>*</b> |                   | <u>⊩</u> X[5]          | Location          | PIN_B12  | Yes     |
| 19 | <b>*</b> |                   | <u>⊩</u> X[6]          | Location          | PIN_A13  | Yes     |
| 20 | <b>*</b> |                   | <u>⊩</u> X[7]          | Location          | PIN_A14  | Yes     |
| 21 | <b>*</b> |                   | L- CLK                 | Location          | PIN_P11  | Yes     |
| 22 | <b>*</b> |                   | LOAEXT                 | Location          | PIN_A7   | Yes     |
| 23 |          | < <new>&gt;</new> | < <new>&gt;</new>      | < <new>&gt;</new> |          |         |

# **DE-10 LITE TEST RESULTS**

# **Unsigned Test Results**

| Test | Dividend ÷ Divisor (Hex) | Quotient<br>(Hex) | Remainder<br>(Hex) |
|------|--------------------------|-------------------|--------------------|
| a)   | 0FFF ÷ FF                | 10                | 0F                 |
| b)   | 0FFF ÷ EE                | 11                | 31                 |
| c)   | 00AC ÷ FF                | 00                | AC                 |
| d)   | 0067 ÷ 67                | 01                | 00                 |
| e)   | 0000 ÷ 0A                | 00                | 00                 |

# PHOTOS OF TEST RESULTS

### Dividend

#### **Divisor**

## {Quotient, Remainder}

a)







b)







c)







d)







e)





