# **Table of Contents**

| A) 15 | SA Intro                                            | . 2 |
|-------|-----------------------------------------------------|-----|
| 1.    | Introduction                                        | . 2 |
| 2.    | Instruction List                                    | . 2 |
| 3.    | Register Design                                     | . 2 |
| 4.    | Control Flow (Branches)                             | . 3 |
| 5.    | Data addressing modes                               | . 3 |
| B) A  | Answers to Questions                                | . 4 |
| C) S  | Software Package                                    | . 4 |
| 1.    | Algorithms (in assembly code) of the two programs   | . 4 |
| 2.    | Machine code for each of the programs               | . 4 |
| 3.    | Output of your Python disassembler for each program | . 4 |
| 4.    | Python code for your ISA's disassembler             | . 5 |
| D) H  | lardware Implantations                              | . 5 |
| 1.    | ALU schematic                                       | . 5 |
| 2.    | CPU Datapath                                        | . 5 |
| 3.    | Control logic                                       | . 5 |

### A) ISA Intro

### 1. Introduction

Name of Architecture: JHT

Overall Philosophy:

The philosophy behind this architecture is to have an efficient and user-friendly ISA Design.

Goals:

o Achieve Modular Exponentiation Program for any 16-bit P and Q

o Achieve Best Match Count Program for any best-matching score

### 2. Instruction List

| Instruction | Format         | Opcode     | Example            |
|-------------|----------------|------------|--------------------|
| Add         | Add Rx, Ry     | 000 xx yy  | Rx = Rx + Ry       |
| Sub         | Sub Rx, Ry     | 001 xx yy  | Rx = Rx - Ry       |
| load        | Load Rx, (Ry)  | 010 xx yy  | Rx <- M[Ry]        |
| Store       | Store Rx, (Ry) | 011 xx yy  | M[Ry] <- Rx        |
| Jump        | Jump Rx        | 100 00 xx  | PC -= Rx           |
| bezR1       | bezR1 Rx       | 101 00 xx  | If R1==0, PC += Rx |
| SltR1       | SltR1 Rx, Ry   | 110 xx yy  | if Rx < Ry, R1 = 1 |
| Init        | Init Rx, imm   | 111 0 xx i | Rx = imm           |
| ShiftL      | ShiftL         | 111 10 00  | R2 <<              |
| ShiftR      | ShiftR         | 111 10 01  | R2>>               |
| And         | AndR3          | 111 11 01  | R3 AND 1           |
| XOR         | XorR2R1        | 111 11 00  | R2 = R2 XOR R1     |

### 3. Register Design

Number of registers: 4 (R0 to R3)

R1 is for testing purposes when using bezR1 or sltR1.

### 4. Control Flow (Branches)

Branches supported:

o Jump: only goes backward

o bezR1: branch if R1 == 0, only goes forward

Target address calculus: PC = PC ± immediate

Maximum branch distance:

o For Jump: 1111 (bin) = -15 (only goes backward)

 $\circ$  For bezR1: 1111 (bin) = +15 (only goes forward)

### Examples:

| Assembly Instruction | Machine Code | Function                                      |
|----------------------|--------------|-----------------------------------------------|
| Jump 12              | 1100 1100    | PC = PC - 12                                  |
| bezR1 9              | 0101 1001    | <u>If R1==0:</u> PC += 9<br><u>Else:</u> PC++ |

#### 5. Data addressing modes

What addressing modes are supported for data memory? How are the addresses calculated? Give examples of your assembly load / store instructions and their corresponding machine code.

Addressing Modes: M[Rx] with Rx being a register with a 16-bit value

Address Calculation: M[0] is the 16-bit word in address 0 of the data memory

### Examples:

| Assembly Instruction | Machine Code | Function    |
|----------------------|--------------|-------------|
| Load R0, (R1)        | 0010 0001    | R0 <- M[R1] |
| Store R2, (R3)       | 1011 1011    | M[R3] <- R2 |

### B) Answers to Questions

- 1. Comparing to the sample of "My\_straightforward\_ISA", what are the unique features of your ISA? Explain why your ISA is better.
- 2. In what ways did you optimize for the two goals? If you optimized for anything additional, what and how?
- 3. What would you have done differently if you had 1 more bit for instructions? How about 1 fewer bit?
- 4. How did your team work together to accomplish this project? (Role of each team member, progress milestones, time spent individually and together?)
- 5. If you had a chance to restart this project afresh with 3 weeks' time, how would your team have done differently?

## C) Software Package

#### 1. Algorithms (in assembly code) of the two programs

Make sure your assembly format is either obvious or well described, and that the code is well commented.

**Extra credits:** provide a convincing estimation:

- on the dynamic instruction count for P1 (ME) with  $P = \sim 1000$  and  $Q = \sim 500$
- on the worst-case scenario of dynamic instruction count for P2(BMC).

#### 2. Machine code for each of the programs

We will not correct/grade the machine code. You will also not be able to verify whether your code works correctly or not in this project (without a simulator). Therefore, you have to rely on the help of the disassembler, strive to make your algorithm simple and easy to understand, as well as pursue the sw-hw "codesign" – this will avoid putting tremendous complexity at either the software or the hardware end. State any assumptions you make. You cannot assume anything about the values in registers or data memory, other than those specifically given, when the program starts. This means, for example, that if you need zeroes in registers or memory, you need to put them there.

### 3. Output of your Python disassembler for each program

This should be a line-by-line explanation of the machine code, what is done by each line of code.

### 4. Python code for your ISA's disassembler

## D) Hardware Implantations

### 1. ALU schematic

A hierarchical sketch of your Arithmetic Logic Unit which implements whatever computation that your ISA instructions use (See textbook ch 5.2.4).

### 2. CPU Datapath

A schematic including your register file, ALU, PC logic, and memory components (see textbook ch 7.3.1).

### 3. Control logic

Decoder truth-table indicating how each control signal is generated from an instruction (see textbook ch 7.3.2).