# CE869 Assignment 2: CPU design

Set by: Dr Xiaojun Zhai (xzhai@essex.ac.uk)

Distributed to students: week 20 Submission deadline: see FASer

Feedback: three weeks from submission deadline

Submission mode: electronic only via FASer

### Assignment objectives

This document specifies the second coursework assignment to be submitted by students taking CE869. This assignment is more challenging than the first one and it is meant to provide an opportunity to improve the knowledge of the VHDL language and, more importantly, to design a digital "system". You will be expected to learn to: a) implement digital system design in VHDL code; b) synthesise and download it to the target hardware; a) test, debig and verify that the design meets the specifications, d) report about your design.

You are required to design code for your target hardware (a Digilent Basys3 board with a Xilinx Artix 7 FPGA) in order to implement a design that meets the specifications (below). Your design will be varied by testbodies by ivade similar of the required to submit working and correct code and you are strongly encouraged to use a modular coding style (allowing for greater flexibility, maintainability, modularity, and reusability). To show that you master all aspects of the language, your code should prevalently use concurrent statements for combinatorial circuits and sequential code for sequential circuits. To ditionally the use of Industry packages (e.g. STD\_LOGIC\_ARITH, STD\_LOGIC\_UNSIGNED, STD\_LOGIC\_SIGNED) and BUFFER ports is forbidden, while the use of INOUT ports is accepted only when strictly necessary.

You are supposed to gain familiarity with VHDL coding during the supporting CE869 lectures and through self-study hours, also with the help of the recommended textbooks or any other book about VHDL. You are expected to work on this assignment mostly during lab hours. Your design project should be stored under the Gitlab repository that was assigned to you at the beginning of the course. You are supposed to commit often and describe your progress in the commit messages. In order to promote a learning scheme that values the learning process in addition to the submitted final design, your weekly progress (as traced back by the commit logs) will contribute to your assignment mark.

#### Design specifications

Your task for this assignment is to implement a 16 bit CPU. To make the assignment feasible within the time frame available for this module, the type of CPU will be fairly simple. In particular, the "program sequencing/control flow instruction" datapath can be modelled after the one on the left of Figure 1, while the "arithmetic/logic instruction" datapath can follow a structure like the one on the right in the same figure. Please notice that when RAE and/or RBE are low, the corresponding output(s) will simply match the input "I" to the register file. The opcodes for the instructions that the CPU is required to implement are given in Table 1. You are also required to implement a decode unit in control unit to interpret the 'Affects' and control signals from the output of each instruction.



Figure 1: The figure shows the "program sequencing/control flow instruction" datapath (left and bottom) and the "arithmetic/logic instruction" datapath (right).

| Instruction       | Encoding   | Affects | Operation                                          |
|-------------------|------------|---------|----------------------------------------------------|
| HALT              | 000000000  |         | Halt                                               |
| MOV Rdd, Rss      | 000100ddss |         | $Rdd \leftarrow Rss$                               |
| IN Rdd            | 00100000dd |         | $Rdd \leftarrow Input$                             |
| OUT Rss           | 00110000ss |         | Output $\leftarrow Rss$                            |
| NOT Rdd, Rss      | 010000ddss | Z       | $Rdd \leftarrow NOT Rss$                           |
| JMP aaaa          | 010100aaaa |         | Jump to aaaa                                       |
| JNZ aaaa          | 011000aaaa |         | Jump to aaaa if Z status flag is unset (i.e. is 0) |
| JN aaaa           | 011100aaaa |         | Jump to aaaa if Z status flag is set (i.e. is 1)   |
| LT Rrr, Rqq       | 100000rrqq | Z       | Set Z to 0 if $Rrr < Rqq$ , to 1 otherwise         |
| INC Rrr, #nnnn    | 1001rrnnnn | Z       | $Rrr \leftarrow Rrr + nnnn$                        |
| DEC Rrr, #nnnn    | 1010rrnnnn | Z       | $Rrr \leftarrow Rrr - nnnn$                        |
| ADD Rdd, Rrr, Rqq | 1011ddrrqq | Z       | $Rdd \leftarrow Rrr + Rqq$                         |
| SUB Rdd, Rrr, Rqq | 1100ddrrqq | Z       | $Rdd \leftarrow Rrr - Rqq$                         |
| AND Rdd, Rrr, Rqq | 1101ddrrqq | Z       | $Rdd \leftarrow Rrr \text{ AND } Rqq$              |
| OR Rdd, Rrr, Rqq  | 1110ddrrqq | Z       | $Rdd \leftarrow Rrr \ OR \ Rqq$                    |
| MOV Rdd, #nnnnnnn | 1111ddnnnn |         | $Rdd \leftarrow nnnn$                              |

Table 1: Table of opcodes.

To test your CPU, you will design a main entity that instantiates the CPU and connects it to the Basys3 peripherals. The sixteen switches of the Basys3 board will represent the input to the CPU while its output will be shown as hexadecimal number in the four digits of the 7-segment display. The central button will be used as reset signal to the CPU.

To test the CPU you will be asked to code two programs in the assembly and machine languages of the CPU, implementing the following tasks (A VHDL testbench should be used to test the functions of the CPU.):

A. Given a nonzero number N as input, output the sum of the natural numbers less than N;

These design specifications should be interpreted as guidelines and should not constrain you from improving the CPU by doing modifications that you think would result in a better "product". The test programs above, though, should be implemented using only the instructions in Table 1. You are welcome to implement more elaborated programs to test the capabilities and the limitations of the CPU.

## Report

You should write a report introducing the project and then describing your codings and designs for the assignment. It should first describe the design at a higher level and then detail the implementation of each module in a top-down fashion (rather than in chronological order). Also report if your code worked at the first attempt, what was wrong and how you fixed it. The repository log (if you used it properly) should help you possiderably in this task. Your report should also include a discussion of design attribute that you buside to Card he Activations for your final choice.

Your document should have a title page and be sub-divided into appropriately headed sections. It MUST contain references to material used in your work (e.g., VHDL code or information available in books or on the Interpet). All of the VHDL code submitted should be included in the report in the form of code appendices and be typeset in Courier font (or a suitable fixed-width alternative font of your choice). Your report should consist of approximately 1500–2000 words of narrative (i.e. excluding references, code fragments, pictures, diagrams and schematics). Please write registration number and word counter the title page of con report 1010 S

#### Submission

Your work must be submitted to the university's online FASer submission system at the address https://faser.essex.ac.uk/ by the deadline given on the system. No other mode of submission is acceptable.

You are required to submit <u>one ZIP archive</u> (not RAR or other formats) containing the following files:

- 1. All source files needed to synthesize your project (but not the temporary files created by Xilinx);
- 2. A report document submitted in PDF format. DO NOT SUBMIT THIS FILE IN .DOC OR .DOCX OR SIMILAR FORMATS SUBMIT PDF.
- 3. Your repository log in .TXT format.
- 4. If you want (in your own interest, see next section), submit a .TXT or .PDF file with the transcripts of relevant forum discussions you contributed to.

DO NOT WAIT UNTIL CLOSE TO THE DEADLINE TO MAKE YOUR FIRST SUBMISSION. Difficulties with the submission system will not be accepted as an excuse for a missing submission.

# Marking criteria

Marks will be awarded for the VHDL code, including coding style and quality, and for the descriptive document, including content, presentation, and discussions. In addition to the report, each students will be expected to demonstrate and explain her/his design with confidence and competence during a demo lab session. Marks will be assessed based on:

| • | Imp. | lementation |
|---|------|-------------|
|   |      |             |

| - Quality of the implementation           | 15%   |
|-------------------------------------------|-------|
| – Modular design                          | 6%    |
| - Generic and re-usable code              | 6%    |
| - Proper use of comments                  | 6%    |
| - Steady progress, adequate use of GIT    | 6%    |
| - Quality and confidence of demonstration | 15%   |
| Report                                    |       |
| - Correctness and completeness of report  | 12%   |
| - Clarity of presentation                 | 12%   |
| - Organisation of report                  |       |
| - Aissignment Project Exam H              | elp8% |
| Others                                    | 1     |
| - Compliance with submission instructions |       |

# Late Submission and Plagiarism

Please refer to the Students' Handbook for details of the Departmental policy regarding submission and University regulations regarding plagiarism Studiol S

Revision 1.021/12/2022Xiaojun Zhai