Course Project

Programmable Processer

TCES330 Digital System Design

Spring 2025

**Authors:**

Student A: \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACYAAAAsCAMAAAA+eDr6AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAGUExURQAAAAAAAKVnuc8AAAACdFJOU/8A5bcwSgAAAAlwSFlzAAAOwwAADsMBx2+oZAAAACVJREFUOE/tyqEBAAAMwjD4/+n5Kvwanaw6sIENbGADG7xqg+QA02EF6TSEIOwAAAAASUVORK5CYII=)

Student B: \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_

Submission Date: xxx\_xx, 2025

**Table of Contents:**

1: Requirements \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ page number

1.1 Controller.sv

1.2 Datapath.sv

1.3 Processor.sv

1.4 Project.sv

2: Design ­­­­­\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ page number

2.1 Controller.sv

2.2 Datapath.sv

2.3 Processor.sv

2.4 Project.sv

3: Test Procedures and Result \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ page number

3.1 FSM\_tb.sv

3.3 Controller\_tb.sv

3.4 Datapath\_tb.sv

3.2 testProcessor.sv

4: DE2 Board Test Results \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ page number

5: Conclusion \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ page number

6: References

Appendix

Before you start reporting the details involved in this course project, first briefly talk about the purpose of this project; then introduce your team members and how you manage the workload.

**1.Requirements**

Briefly describe the project requirements in general. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references. See below.

Add your picture here

Figure x. Brief describe the picture you insert here, e.g., Processor Structure, etc

* 1. **Requirements for Controller.sv**

Briefly describe design requirements for the module **Controller**. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references.

* 1. **Requirements for Datapath.sv**

Briefly describe the design requirements for the module **Datapath**. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references.

* 1. **Requirements for Processor.sv**

Briefly describe the design requirements for the module **Processor**. Use pictures/figures is always a good idea. When using pictures/figures, please add captions for references.

* 1. **Requirements for Project.sv**

Briefly describe the design requirements for the top-level module **Project** (by adding other modules like **Buttonsync**, **Keyfilter**, **Decoder**, **Mux\_nW\_8\_to\_1** to the **processor**). Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references.

**2. Design**

Describe in detail the project modules’ design procedure. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references.

**2.1 Controller.sv**

Describe in detail the design of the **Controller** module. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references. If you think certain segments of the SystemVerilog codes can reflect your design idea, you can add them here for discussion too (and don’t forget to add captions).

**2.2 Datapath.sv**

Describe in detail the design of the **Datapath** module. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references. If you think certain segments of the SystemVerilog codes can reflect your design idea, you can add them here for discussion too (and don’t forget to add captions).

**2.3 Processor.sv**

Describe in detail the design of the **Processor** module. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references. If you think certain segments of the SystemVerilog codes can reflect your design idea, you can add them here for discussion too (and don’t forget to add captions).

**2.4 Project.sv**

Describe in detail the design of the top level **Project** module. Discuss the usage of submodules including Button Synchronizer, Key Filter, etc. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references. If you think certain segments of the SystemVerilog codes can reflect your design idea, you can add them here for discussion too (and don’t forget to add captions).

**3. Test Procedures and Results**

Describe in detail the testbench design of each module. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references. If you think certain segments of the SystemVerilog codes can reflect your design idea, you can add them here for discussion too (and don’t forget to add captions).

Also please include the simulation results by running each testbench. Comment properly on whether the testing results meet the design requirements presented in **Section 1: Requirements**.

**3.1 FSM\_tb**

Describe in detail the design of FSM testbench. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references. If you think certain segments of the SystemVerilog codes can reflect your design idea, you can add them here for discussion too (and don’t forget to add captions).

**3.2 Controller\_tb**

Describe in detail the design of the Controller testbench. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references. If you think certain segments of the SystemVerilog codes can reflect your design idea, you can add them here for discussion too (and don’t forget to add captions).

**3.3 Datapath\_tb**

Describe in detail the design of the Datapath testbench. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references. If you think certain segments of the SystemVerilog codes can reflect your design idea, you can add them here for discussion too (and don’t forget to add captions).

**3.4 testProcessor**

The Processor testbench, **testProcessor.sv** will be provided. Show your understanding of the test bench. If you have ever tried anything different from the given version, properly talk about it and explain why your version is a reasonable (or preferable) alternative.

**4. DE2 Board Test Results**

Provide your observations through project testing on DE2 board. If you or your group ever encountered some warning messages, or error messages during Quartus compilation, how your group solved the problem and removed those warning/error messages. Using pictures/figures is always a good idea. When using pictures/figures, please add captions for references.

**5. Conclusion**

Provide a summary of your learning from the course project, learning of course subjects, as well as learning from the teamwork experience.

**6. References**

List documents/materials/webpages you and/or your group referred to when you work on this project and when you write this report.

**Appendix**

If you and/or your group has some extra information/work to share, please put it in this section. As an example, if you tried the extra credits part, you can have description and discussion on those contents here.