#### ECE 271

# Digital Logic Design Final Project

Nick Olson Michael ASD Sienna ASD

November 30, 2019 Instructor Shuman Oregon State University

# Contents

| 1                | Pro               | ject Description                                                                                                                                                                                                                                                                                                                    | 2                |
|------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 2                | <b>Hig</b> 2.1    | h Level Description Functional Unit 1 Name                                                                                                                                                                                                                                                                                          | 4<br>5<br>6<br>8 |
| A                | A.1               | temVerilog Files Functional Unit Name                                                                                                                                                                                                                                                                                               | 9<br>9<br>12     |
| В                | Sim<br>B.1<br>B.2 | ulation Files (Do Scripts)         Functional Unit Name                                                                                                                                                                                                                                                                             | 15<br>15<br>18   |
| $\mathbf{L}_{i}$ | ist               | of Figures                                                                                                                                                                                                                                                                                                                          |                  |
|                  | 1                 | This image is legible, and conveys the point of the design. Your image can be hand drawn, but it must have straight lines, use your OSU ID. I don't recommend drafting this on the computer, because there aren't any decent tools to draw these                                                                                    | c                |
|                  | 2                 | block diagrams quickly.  The hardware diagram shows which pins are used on the FPGA, module boards, and relevant supply voltages for the different pieces of hardware used in the system.                                                                                                                                           | 3                |
|                  | 3                 | The top level design for the project. This would be improved by combining the priority encoder and Mux4 into a single clock select block. Combining the ArrowLogic and Counter14 would also make this diagram better. Use chapter 1 concepts wisely on this diagram, specifically hierarchy, modularity, regularity, and discipline | 4                |
|                  | 4                 | The simulation results of the top level design for the project.                                                                                                                                                                                                                                                                     | 4                |
|                  | 5                 | The logic design of the (NAME) functional unit used in the final design                                                                                                                                                                                                                                                             | 5                |
|                  | 6                 | The simulation results of the top level design for the project                                                                                                                                                                                                                                                                      | 5                |
|                  | 7                 | The block symbol of the (NAME) individual block used in the (NAME) functional unit, the block diagram of the logic of the testbench used to further simulate the                                                                                                                                                                    |                  |
|                  | 8                 | block, and the block symbol of the test chip used in the testbench of the block. The simulation results of the block alone, the testbench used to further simulate the block, and the simulation results for the testbebch of the (NAME) individual block used in the (NAME) functional unit.                                       | 6<br>7           |
|                  | 9                 | The block symbol of the (NAME) individual block used in the (NAME) functional                                                                                                                                                                                                                                                       | 1                |
|                  | 10                | unit                                                                                                                                                                                                                                                                                                                                | 8                |
|                  |                   | tional unit                                                                                                                                                                                                                                                                                                                         | C                |

# 1 Project Description

Intro to Project paragraph. The inputs and outputs of the overall design immediately follow. An overall description diagram is then shown in **Figure 1** and a hardware diagram is shown in **Figure 2**.

• Inputs: inputs

• Outputs: outputs



Figure 1: This image is legible, and conveys the point of the design. Your image can be hand drawn, but it must have straight lines, use your OSU ID. I don't recommend drafting this on the computer, because there aren't any decent tools to draw these block diagrams quickly.



Figure 2: The hardware diagram shows which pins are used on the FPGA, module boards, and relevant supply voltages for the different pieces of hardware used in the system.

# 2 High Level Description

Top level introduction. The input and output specifications follow, a toplevel diagram follows in **Figure 3**, and the simulation results follow in **Figure 4**.

• Inputs: inputs

• Outputs: outputs



Figure 3: The top level design for the project. This would be improved by combining the priority encoder and Mux4 into a single clock select block. Combining the ArrowLogic and Counter14 would also make this diagram better. Use chapter 1 concepts wisely on this diagram, specifically hierarchy, modularity, regularity, and discipline.



Figure 4: The simulation results of the top level design for the project.

The following subsections will discuss the inputs, outputs, designs, and simulation results of all elements of the design at two levels of scrutiny: functional units and individual blocks of digital logic.

#### 2.1 Functional Unit 1 Name

Introduction to functional unit. The input and output specifications follow, a block diagram of the unit follows in **Figure A**, the simulation results for the unit follows in **Figure B**, and the details for each individual block comprising the unit follow after.

• Inputs: inputs

• Outputs: outputs



Figure 5: The logic design of the (NAME) functional unit used in the final design.



Figure 6: The simulation results of the top level design for the project.

#### 2.1.1 Individual Block 1 Name (with testbench)

Introduction to individual block. The input and output specifications follow, as well as the block diagram (**Figure C**), and simulation results **Figure D** for the individual block.

• Inputs: inputs

• Outputs: outputs



(a) The block symbol of the (NAME) in- (b) The block symbol of the test block used dividual block used in the (NAME) func- in the testbench made to further simulate tional unit. the (NAME) individual block.



(c) The testbench used to further simulate the (NAME) individual block.

Figure 7: The block symbol of the (NAME) individual block used in the (NAME) functional unit, the block diagram of the logic of the testbench used to further simulate the block, and the block symbol of the test chip used in the testbench of the block.



(a) The simulation results for the (NAME) individual block alone.



(b) The simulation results of the test block used in the testbench.



(c) The simulation results of the testbench used.

Figure 8: The simulation results of the block alone, the testbench used to further simulate the block, and the simulation results for the testbench of the (NAME) individual block used in the (NAME) functional unit.

#### 2.1.2 Individual Block 2 Name (without testbench)

Introduction to individual block. The input and output specifications follow, as well as the block diagram (**Figure C**), and simulation results **Figure D** for the individual block.

• Inputs: inputs

• Outputs: outputs



Figure 9: The block symbol of the (NAME) individual block used in the (NAME) functional unit.



Figure 10: The simulation results of the (NAME) individual block used in the (NAME) functional unit.

### A SystemVerilog Files

This appendix will list the SystemVerilog code used for each block used in the design project.

#### A.1 Functional Unit Name

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
   // Delay will have scale of 1ns per #n listed (resolution 100ps)
   'timescale 1ns/100ps
   module L293D_test_chip (
      input logic
                      enable_1,
                                  // pin 1
                                               - enable for inputs 1 and 2
8
                                  // pin 2
                      input_1,
                                                  input 1 (forward for motor 1)
9
                                  // pin 7
                      input_2,
                                                  input 2 (backward for motor 1)
10
11
                      enable_2,
                                  // pin 9
                                                  enable for inputs 3 and 4
12
                      input_3,
                                  // pin 10
                                                  input 3 (forward for motor 2)
13
                                  // pin 15
                      input_4,
                                                  input 4 (backward for motor 2)
14
15
      output logic
                      output_1,
                                   // pin 3
                                                  output 1 (forward for motor 1)
16
                                                  output 2 (backward for motor 2)
                      output_2,
                                   // pin 6
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14
                                          - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
28
         output_4 <= (enable_2) ? (input_4) : (1'bz);
29
      end
30
31
   endmodule
32
```

(a) SystemVerilog code for the (NAME) block used in the design.

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
  // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
   module L293D_test_chip (
      input logic
                      enable_1,
                                   // pin 1
                                               - enable for inputs 1 and 2
                                                  input 1 (forward for motor 1)
9
                      input_1,
                                  // pin 2
                                                   input 2 (backward for motor 1)
                      input_2,
                                  // pin 7
10
11
                                   // pin 9
                                                   enable for inputs 3 and 4
                      enable_2,
12
                                                   input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                      input_4,
                                  // pin 15
                                                   input 4 (backward for motor 2)
14
15
                                  // pin 3
      output logic
                      output_1,
                                                   output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                   output 2 (backward for motor 2)
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14 - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
      \verb"end"
30
31
   endmodule
32
```

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
  // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
   module L293D_test_chip (
      input logic
                      enable_1,
                                   // pin 1
                                               - enable for inputs 1 and 2
                                                  input 1 (forward for motor 1)
9
                      input_1,
                                  // pin 2
                                                   input 2 (backward for motor 1)
                      input_2,
                                   // pin 7
10
11
                                   // pin 9
                                                   enable for inputs 3 and 4
                      enable_2,
12
                                                   input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                      input_4,
                                  // pin 15
                                                   input 4 (backward for motor 2)
14
15
                                  // pin 3
      output logic
                      output_1,
                                                   output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                   output 2 (backward for motor 2)
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14 - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
      \verb"end"
30
31
   endmodule
```

#### A.2 Functional Unit Name

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
2
3
   // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
6
   module L293D_test_chip (
      input logic
                                  // pin 1
                                               - enable for inputs 1 and 2
8
                      enable_1,
                                  // pin 2
                                                  input 1 (forward for motor 1)
                      input_1,
9
                                  // pin 7
                      input_2,
                                                  input 2 (backward for motor 1)
10
11
                      enable_2,
                                  // pin 9
                                              - enable for inputs 3 and 4
12
                                               - input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                      input_4,
                                  // pin 15
                                                  input 4 (backward for motor 2)
14
15
      output logic
                      output_1,
                                  // pin 3
                                                  output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                  output 2 (backward for motor 2)
17
18
                                  // pin 11
19
                      output_3,
                                               - output 3 (forward for motor 3)
                      output_4 // pin 14  - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
30
      end
31
   endmodule
32
```

(a) SystemVerilog code for the (NAME) block used in the design.

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
  // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
   module L293D_test_chip (
      input logic
                      enable_1,
                                   // pin 1
                                               - enable for inputs 1 and 2
                                                  input 1 (forward for motor 1)
9
                      input_1,
                                  // pin 2
                                                  input 2 (backward for motor 1)
                      input_2,
                                  // pin 7
10
11
                                   // pin 9
                                                  enable for inputs 3 and 4
                      enable_2,
12
                                                  input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                      input_4,
                                  // pin 15
                                                  input 4 (backward for motor 2)
14
15
                                  // pin 3
      output logic
                      output_1,
                                                   output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                  output 2 (backward for motor 2)
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14 - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
      \verb"end"
30
31
   endmodule
```

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
  // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
   module L293D_test_chip (
      input logic
                      enable_1,
                                   // pin 1
                                               - enable for inputs 1 and 2
                                                  input 1 (forward for motor 1)
9
                      input_1,
                                  // pin 2
                                                  input 2 (backward for motor 1)
                      input_2,
                                  // pin 7
10
11
                                   // pin 9
                                                  enable for inputs 3 and 4
                      enable_2,
12
                                                  input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                      input_4,
                                  // pin 15
                                                  input 4 (backward for motor 2)
14
15
                                  // pin 3
      output logic
                      output_1,
                                                   output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                  output 2 (backward for motor 2)
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14 - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
      \verb"end"
30
31
   endmodule
```

## B Simulation Files (Do Scripts)

This appendix will list the Do Scripts used to simulate each block used in the design project.

#### **B.1** Functional Unit Name

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
   // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
   module L293D_test_chip (
                                  // pin 1
      input logic
                      enable_1,
                                                 enable for inputs 1 and 2
                                  // pin 2
                      input_1,
                                                  input 1 (forward for motor 1)
9
                                  // pin 7
                      input_2,
                                                  input 2 (backward for motor 1)
10
11
                      enable_2,
                                  // pin 9
                                               - enable for inputs 3 and 4
12
                                  // pin 10
                                                  input 3 (forward for motor 2)
                      input_3,
13
                                  // pin 15
                      input_4,
                                                  input 4 (backward for motor 2)
14
15
      output logic
                      output_1,
                                  // pin 3
                                                  output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                  output 2 (backward for motor 2)
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14
                                          - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
28
         output_4 <= (enable_2) ? (input_4) : (1'bz);
30
31
   endmodule
32
```

(a) Do Script for the (NAME) block used in the design.

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
  // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
   module L293D_test_chip (
      input logic
                      enable_1,
                                   // pin 1
                                               - enable for inputs 1 and 2
                                                  input 1 (forward for motor 1)
9
                      input_1,
                                  // pin 2
                                  // pin 7
                                                  input 2 (backward for motor 1)
                      input_2,
10
11
                                   // pin 9
                                                  enable for inputs 3 and 4
                      enable_2,
12
                                                  input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                      input_4,
                                  // pin 15
                                                  input 4 (backward for motor 2)
14
15
                                  // pin 3
      output logic
                      output_1,
                                                   output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                  output 2 (backward for motor 2)
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14 - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
      \verb"end"
30
31
   endmodule
```

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
  // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
   module L293D_test_chip (
      input logic
                      enable_1,
                                   // pin 1
                                               - enable for inputs 1 and 2
                                                  input 1 (forward for motor 1)
9
                      input_1,
                                  // pin 2
                                                  input 2 (backward for motor 1)
                                   // pin 7
                      input_2,
10
11
                                   // pin 9
                                                  enable for inputs 3 and 4
                      enable_2,
12
                                                  input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                      input_4,
                                  // pin 15
                                                  input 4 (backward for motor 2)
14
15
                                  // pin 3
                                                   output 1 (forward for motor 1)
      output logic
                      output_1,
16
                      output_2,
                                  // pin 6
                                                  output 2 (backward for motor 2)
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14 - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
      \verb"end"
30
31
   endmodule
```

#### **B.2** Functional Unit Name

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
3
   // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
6
   module L293D_test_chip (
      input logic
                                  // pin 1
                                               - enable for inputs 1 and 2
8
                      enable_1,
                                  // pin 2
// pin 7
                                                  input 1 (forward for motor 1)
                      input_1,
9
                      input_2,
                                                  input 2 (backward for motor 1)
10
11
                      enable_2,
                                  // pin 9
                                               - enable for inputs 3 and 4
12
                                               - input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                                  // pin 15
                      input_4,
                                                  input 4 (backward for motor 2)
14
15
      output logic
                      output_1,
                                  // pin 3
                                                  output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                  output 2 (backward for motor 2)
17
18
                                  // pin 11
19
                      output_3,
                                               - output 3 (forward for motor 3)
                      output_4 // pin 14  - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
30
      end
31
   endmodule
32
```

(a) Do Script for the (NAME) block used in the design.

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
  // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
   module L293D_test_chip (
      input logic
                      enable_1,
                                   // pin 1
                                               - enable for inputs 1 and 2
                                                  input 1 (forward for motor 1)
9
                      input_1,
                                  // pin 2
                                  // pin 7
                                                  input 2 (backward for motor 1)
                      input_2,
10
11
                                   // pin 9
                                                  enable for inputs 3 and 4
                      enable_2,
12
                                                  input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                      input_4,
                                  // pin 15
                                                  input 4 (backward for motor 2)
14
15
                                  // pin 3
      output logic
                      output_1,
                                                   output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                  output 2 (backward for motor 2)
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14 - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
      \verb"end"
30
31
   endmodule
```

```
// https://www.st.com/content/ccc/resource/technical/document/datasheet/04/ac/22/f9/20/5d/4
  // Delay will have scale of 1ns per #n listed (resolution 100ps)
4
   'timescale 1ns/100ps
5
   module L293D_test_chip (
      input logic
                      enable_1,
                                   // pin 1
                                               - enable for inputs 1 and 2
                                                  input 1 (forward for motor 1)
9
                      input_1,
                                  // pin 2
                                  // pin 7
                                                  input 2 (backward for motor 1)
                      input_2,
10
11
                                   // pin 9
                                                  enable for inputs 3 and 4
                      enable_2,
12
                                                  input 3 (forward for motor 2)
                      input_3,
                                  // pin 10
13
                      input_4,
                                  // pin 15
                                                  input 4 (backward for motor 2)
14
15
                                  // pin 3
      output logic
                      output_1,
                                                   output 1 (forward for motor 1)
16
                      output_2,
                                  // pin 6
                                                  output 2 (backward for motor 2)
17
18
                      output_3,
                                  // pin 11
                                               - output 3 (forward for motor 3)
19
                      output_4 // pin 14 - output 4 (backward for motor 4)
20
      );
21
22
      always_comb begin
23
24
         output_1 <= (enable_1) ? (input_1) : (1'bz);
25
         output_2 <= (enable_1) ? (input_2) : (1'bz);
26
27
         output_3 <= (enable_2) ? (input_3) : (1'bz);
         output_4 <= (enable_2) ? (input_4) : (1'bz);
      \verb"end"
30
31
   endmodule
```