# ICOM 4215 Project 1 Fall 2012 Processor Simulator

Today: Sept 19, 2012

Due date: Oct 8, 2012

Points: 100 points (Penalties: Next day: -10 points, Two days late: -25 points, Three days late: -40 points, Four days late or more: not accepted)

Group project – Three students per group

Submission:

- Report, via email, subject on the email: Project 1 ICOM 4215, students will lose 5 points if the subject is changed. Send the email to <u>navdag.santiago@upr.edu</u>. Email due time, 11:59pm. Please use as part of the filename the initial letter of last names of the members of the group.
- Via oral exam, aka "Happy Hour".<u>mailto:fvega@ece.uprm.edu</u>

## Project

In order to understand how a processor works and the different aspects taken into consideration when designing a processor, we are requesting that you design a simulator for a simple processor. The following sections describe the processor.

# **General Processor Description: RISC AR4**

The RISC AR5 is a processor designed by your professor, taking the ideas from the Simple Risc Processor, from the Jordan and Heuring textbook, a processor designed by Manuel Jimenez, Sunil Vaidya, Bradley Vansant, and Dave Dorner for the EE 813 graduate course at Michigan State University, and the processor designed by Adem Kader and Mustafa Paksoy for the E25 : COMPUTER ARCHITECTURE course at Swathmore University.

## **Processor Features:**

- 8-bit internal data bus
- Internal 256-word 8 bit wide program memory
- 8 byte register file
- On chip adder providing 8 bit results. On chip vector adder providing 8 bit results.
- 2 external I/O pins
- RISC instruction set: 21 instructions
  - o 6 arithmetic
  - 4 logical
  - o 5 data transfer
  - o 5 control flow instructions
  - o 1 machine control

## Processor Block Diagram



Figure 1: Block diagram of the RISC AR5

## **Memory and Registers**

The size of the memory is 256 organized as 256 addresses of 1 byte each.



Figure 2: Visual illustration of the memory of the RISC AR5

Internally, the processor has 8 general purpose registers, 8 bits each. The names of the registers are from **R0** to **R7**.

|   | 7 | 0 |    |
|---|---|---|----|
| 1 |   |   | RO |
| Ì |   |   | R1 |
| ĺ |   |   | R2 |
|   |   |   | R3 |
|   |   |   | R4 |
| ĺ |   |   | R5 |
| ĺ |   |   | R6 |
|   |   |   | R7 |

Figure 3: Visual illustration of the general purpose register structure of the RISC AR5

The processor has a 8 bit program counter called **PC**, an 8 bit accumulator called **A**, and a 16 bit instruction register called **IR**. There is a 4-bit status register called **SR**. The format of the Status

Register is **ONCZ** where O is overflow, N is negative, C is Carry, and Z is zero. When instructions are saved into memory, big endian ordering is used (A big-endian machine stores the most significant byte first).

Four addressing modes are supported by the processor:

- a) Implicit
- b) Immediate
- c) Direct
- d) Register indirect

The list below shows the different addressing modes supported and the corresponding instruction formats for each (see figures 4 to 7).

(a) Implicit addressing: The only operand needed is contained in the accumulator (A)

| 5 bit opcode |    |    |    |    |    | Don't care |   |   |   |   |   |   |   |   |   |
|--------------|----|----|----|----|----|------------|---|---|---|---|---|---|---|---|---|
| 15           | 14 | 13 | 12 | 11 | 10 | 9          | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Figure 4: Instruction format for the Implicit addressing mode

(b) Immediate addressing: The data to be operated is part of the instruction itself.

| 5 bit opcode |    |    |    |    |    |   | Immediate Operand |   |   |   |   |   |   |   |   |
|--------------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 15           | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Figure 5: Instruction format for the Immediate addressing mode

(c) *Direct*: The memory location is indicated within the instruction.

| 5 bit opcode |    |    |    | Regf |    | Direct Address |   |   |   |   |   |   |   |   |   |
|--------------|----|----|----|------|----|----------------|---|---|---|---|---|---|---|---|---|
| 15           | 14 | 13 | 12 | 11   | 10 | 9              | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Figure 6: Instruction format for the Direct addressing mode

(d) *Register direct addressing*: Register f contains the operand.

| 5 bit opcode |    |    |    | Regf |   |   | Don't care |   |   |   |   |   |   |   |
|--------------|----|----|----|------|---|---|------------|---|---|---|---|---|---|---|
| 15 14        | 13 | 12 | 11 | 10   | 9 | 8 | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Figure 7: Instruction format for the Register Direct addressing mode

### **Instruction Set**

The following table is a summary of the instruction set of the RISC AR5. Note that register f refers to one of the eight general purpose registers.

| ltem | Opcode | Name       | Operands       | Addressing | Operation                            | Details         |
|------|--------|------------|----------------|------------|--------------------------------------|-----------------|
|      |        | (Mnemonic) |                | Modes      |                                      |                 |
| 1    | 00 000 | AND rf     | Accumulator,   | Register   | A ← A and rf                         | Logical AND     |
|      |        |            | register f     | Direct     |                                      |                 |
| 2    | 00 001 | OR rf      | Accumulator,   | Register   | A 🗲 A or rf                          | Logical OR      |
|      |        |            | register f     | Direct     |                                      |                 |
| 2    | 00 010 | XOR rf     | Accumulator,   | Register   | A ← A xor rf                         | Logical XOR     |
|      |        |            | register f     | Direct     |                                      |                 |
| 3    | 00 011 | ADDC rf    | Accumulator,   | Register   | A ← A + (rf)                         | Addition with   |
|      |        |            | register f     | Direct     | +carry                               | carry           |
| 4    | 00 100 | SUB rf     | Accumulator,   | Register   | A 🗲 A - (rf)                         | Subtraction     |
|      |        |            | register f     | Direct     |                                      |                 |
| 5    | 00 101 | VADD       | TOS and SOS of | Register   | A ←                                  | Add vector.     |
|      |        |            | Vstack (TOSV,  | Direct     | TOSV <sub>0</sub> +SOSV <sub>0</sub> | Add Top of      |
|      |        |            | SOSV)          |            |                                      | stack with      |
|      |        |            |                |            | Vbuff <del>&lt;</del>                | second of       |
|      |        |            |                |            | TOSV <sub>1</sub> +SOSV <sub>1</sub> | stack. Two      |
|      |        |            |                |            |                                      | bytes           |
|      |        |            |                |            |                                      | simultaneously  |
|      |        |            |                |            |                                      | Buffer holds    |
|      |        |            |                |            |                                      | partial result. |
| .6   | 00 110 | NEG        | Accumulator    | Implicit   | A ← ^(A)                             | Two's           |
|      |        |            |                |            |                                      | complement      |
| 7    | 00 111 | NOT        | Accumulator    | Implicit   | A ← not(A)                           | Negate          |
| 8    | 01 000 | RLC        | Accumulator    | Implicit   | A ← A6A0                             | Rotate left     |
|      |        |            |                |            | &Cf, Cf ←A7                          | through carry   |
| 9    | 01 001 | RRC        | Accumulator    | Implicit   | A ← Cf &                             | Rotate right    |
|      |        |            |                |            | A7A1, Cf                             | through carry   |
|      |        |            |                |            | ←A0                                  |                 |
| 10   | 01 010 | LDA rf     | Accumulator,   | Register   | A ← (rf)                             | Load            |
|      |        |            | register f     | Direct     |                                      | accumulator     |
|      |        |            |                |            |                                      | from register f |

Table 1: Instruction set of the RISC AR3

| 11 | 01 011 | STA rf    | Accumulator,    | Register  | (rf)← A    | Store           |
|----|--------|-----------|-----------------|-----------|------------|-----------------|
|    |        |           | register f      | Direct    |            | accumulator to  |
|    |        |           |                 |           |            | register f      |
| 12 | 01 100 | LDA addr  | Accumulator     | Direct    | A ← [addr] | Load            |
|    |        |           |                 |           |            | accumulator     |
|    |        |           |                 |           |            | from memory     |
|    |        |           |                 |           |            | location addr   |
| 13 | 01 101 | STA addr  | Accumulator     | Direct    | [addr]← A  | Store           |
|    |        |           |                 |           |            | accumulator to  |
|    |        |           |                 |           |            | memory          |
|    |        |           |                 |           |            | location addr   |
| 14 | 01 110 | LDI       | Accumulator     | Immediate | A ←        | Load            |
|    |        | Immediate |                 |           | Immediate  | accumulator     |
|    |        |           |                 |           |            | with            |
|    |        |           |                 |           |            | immediate       |
| 15 | 10 000 | BRZ       | Status register | Implicit  | If Z=1, PC | Branch if Zero  |
|    |        |           |                 |           | ←r7        |                 |
| 16 | 10 001 | BRC       | Status register | Implicit  | If C=1, PC | Branch if Carry |
|    |        |           |                 |           | ←r7        |                 |
| 17 | 10 010 | BRN       | Status register | Implicit  | If N=1, PC | Branch if       |
|    |        |           |                 |           | ←r7        | Negative        |
| 18 | 10 011 | BRO       | Status register | Implicit  | If O=1, PC | Branch if       |
|    |        |           |                 |           | ←r7        | Overflow        |
| 19 | 11 111 | STOP      | PC              | Implicit  |            | Stop execution  |
| 20 | 11 000 | NOP       |                 | Implicit  |            | No operation    |

Arithmetic instructions use a 2's complement representation for negative numbers. This format is also used to compute memory addresses when accessing memory. Register 7 is a special register that will be used for branching conditions.

### **Processor Configuration**

The processor operates with instructions located in main memory from address 0 to address 127. When the processor starts, it will always do so from location 0 and 1.

The system will also have two devices connected to I/O ports using the following memory locations:

250-251: 16 bits, input from keyboard

252 – 255: ASCII display, each byte will represent one ascii character

The information coming from the keyboard will be entered at the keyboard of the computer running the simulation. The display will be presented at the computer screen of the computer running the simulation. The data entered in the keyboard will have the corresponding ASCII value and the data written to the display should have the ASCII character corresponding to the code. The following figure illustrates a possible configuration of the graphical user interface for the simulator you will design.



Figure 8: Possible graphical user interface arrangement

#### **Project requirements**

#### **Simulator characteristics**

The simulator must simulate all instructions in the instruction set, including all addressing modes. The simulator will run the instructions located in the main memory, starting with address zero (PC=0). The contents of memory are changed as a file with instructions is loaded into the simulator. Your professor will bring a simulation file on the oral exam day. This file will contain one line per instruction, and it will be represented in HEX characters (4 Hex characters).

The following example illustrates an input file:

7019 5900 70F4 5A00 7002 5B00 7028 5F00 6880 1900 F800 The input file may have any name and will be provided as input.

The simulator should run in two different modes: run or step. Run mode will allow programs to run from start to end. Step mode will run one instruction at a time. Please notice that the last instruction in any file should be stop. The simulator must show the contents of all registers, program counter, instruction register, and the contents of a section of memory. The directions in memory should be shown in HEX representation.

Projects that do not run in step mode will not be graded and a 0 Grade awarded to the project. Your design may use a graphical user interface or a plain text interface. Use any programming language of your preference.