# **Milestone 1 Documentation**

## Team 1A - Khaled Alfayez, Shaun Davis, Trinity Merrell, and Logan Smith

## **CONTENTS:**

| 1. Register Descriptions |    |
|--------------------------|----|
| 2. Assembly              | 2  |
| 3. Machine Language      | 12 |
| 4. Journal               | 21 |

# **Register Descriptions**

**Summary of Registers** 

|                    |        | Outilinary 0                                 |                                                                                                                      |
|--------------------|--------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| Register           | Number | Availability                                 | Description                                                                                                          |
| \$sn (0-3)         | 0-3    | Read/write                                   | General purpose registers. The intent is to store long term computation results and save values over functions calls |
| \$t <i>n (0-3)</i> | 4-7    | Read/write                                   | General purpose registers, to be used like \$sn registers. Will NOT be saved over function calls.                    |
| \$cr               | 8      | Read only                                    | This register holds the result of the most recent computation instruction (arithmetic or logical)                    |
| \$ra               | 9      | Read/write                                   | Stores the return address of a function                                                                              |
| \$a <i>n</i> (0-1) | 10-11  | Read/write                                   | These registers are used to store arguments for use in a called function                                             |
| <b>\$v</b>         | 12     | Read/write                                   | This register is for storing the return value from a function                                                        |
| <b>\$</b> d        | 13     | Read/write                                   | This register is used for communication between the display and the processor                                        |
| \$st               | 14     | Read/write                                   | Reference to the top bit of the stack                                                                                |
| \$i <i>n</i> (0-1) | 15-16  | Not available                                | Used by assembler for pseudoinstructions.                                                                            |
| \$ex               | 17     | Read only                                    | Cause register for interrupt and exception handling; NOT accessible by regular users                                 |
| \$k <i>n</i> (0-1) | 18-19  | Read/write<br>(while handling<br>exceptions) | OS registers; NOT accessible by regular users                                                                        |
| in/output          | 20     | Read (input)<br>Write (output)               | The user can only interact with these registers indirectly using some instructions.                                  |

Unsafe between procedure calls Safe between procedure calls

## **Assembly**

## **Procedure Call Conventions:**

- 1. Registers \$in, \$kn (where n is 0-1) are reserved for the assembler and operating system and should not be used by user programs or compilers.
- 2. Registers \$an (where n is 0-1) are used to pass arguments to procedures, any other arguments should go on the stack. Register \$v is used to return a value from functions.
- 3. Registers \$an, \$tn, \$d, \$cr, and \$v are temporary and volatile. Expect them to contain different data after a procedure call.
- 4. \$sn registers must be backed up on the stack at the beginning of a procedure and restored before returning from the procedure. This preserves values in these registers over procedure calls.
- 5. \$st is the stack register. It points to the top memory location in the stack. If the stack is grown at any time in a procedure, it must be reduced before returning from that procedure.
  - a. Memory is allocated to the stack by subtracting from the value in \$st. Memory is deallocated from the stack by adding to the value in \$st.
- 6. \$ra is the return address of a procedure. Jal will overwrite \$ra to be the next instruction, so \$ra must ALWAYS be backed up on the stack before a procedure call and restored after returning from the procedure.
- 7. The instruction jr will return the program to the value in \$ra.

## **Syntax and Semantics:**

## **Arithmetic and Logical Instructions**

Arithmetic and Logical Instructions are C-type instructions (see Machine Language for more information). These instructions take two registers as operands to their computations. Their results are always stored in the specialized \$cr register.

## Addition:

add r1, r2

| 4    | 4  | 12 | 4    |
|------|----|----|------|
| 0000 | r1 | r? | 0000 |

Stores the sum of r1 and r2 into register \$cr

#### Subtraction:

sub r1, r2 0000 r1 r2 0001 Stores the difference between r1 and r2 into register \$cr and r1, r2

#### AND:

| 0000 | r1 | r2 | 0010 |
|------|----|----|------|
| 4    | 4  | 4  | 4    |

Stores the logical AND of r1 and r2 into register \$cr

### OR:

r1, r2 or

| 4    | 4  | 12 | 4    |
|------|----|----|------|
| 0000 | r1 | r? | 0011 |

Stores the logical OR of r1 and r2 into register \$cr

### NOR:

r1 ,r2 nor

| 0000 | r1 | r2 | 0100 |
|------|----|----|------|
| 4    | 4  | 4  | 4    |

Stores the logical NOR of r1 and r2 into register \$cr

## NAND:

nand r1, r2

| 0000 | r1 | r2 | 0101 |
|------|----|----|------|
| 4    | 1  | 1  | 4    |

Stores the logical NAND of r1 and r2 into register \$cr

### **Exclusive OR:**

xor r1, r2

| 0000 | r1 | r2 | 0110 |
|------|----|----|------|
| 4    | 4  | 4  | 4    |

Stores the logical Exclusive OR of r1 and r2 into register \$cr

#### **Set Less Than:**

slt r1, r2

| 0000 | r1 | r2 | 0111 |
|------|----|----|------|
| 4    | 4  | 4  | 4    |

Stores either a 1(True) or a 0(False) in \$cr depending on if r1 is less than r2

### **Branch Instructions**

Branch instructions require a comparative value to be computed before execution. The branch instruction will then succeed or fail based on equivalence or inequality.

## Branch if equal:

bieq r1, location



Conditional branch to address in immediate if r1 is equal to register \$cr

## Branch not equal:

bneq r1, location



Conditional branch to address in immediate if r1 does not equal register \$cr

## **Jump Instructions**

### Jump:

i location

| 0011 | XXXXXXX | JumpAddr |
|------|---------|----------|
| 4    | 4       | 8        |

Unconditional jump to the address in immediate

## Jump and link:

jal location

| 0100 | XXXXXXX | JumpAddr |
|------|---------|----------|
| 4    | 4       | 8        |

Unconditional jump to the address in immediate, storing the address of subsequent instruction into register \$ra

## Jump register:

jr r1

| 0101 | r1 | xxxxxxxxxxxxxx |
|------|----|----------------|
| 4    | 4  | 8              |

Unconditional jump to the address in r1

### **Load/Store Instructions**

Load/Store instructions often require a value to be computed and stored in \$cr prior to execution. Specific requirements are denoted for each instruction.

## Load to register:

Itr r1, small

| 0110 | r1 | immediate |
|------|----|-----------|
| 4    | 4  | 8         |

Take an immediate value and store in r1. If immediate is greater than 8-bits, becomes a pseudo instruction utilizing load upper immediate and load lower immediate.

Translates to:

## Copy to register:

ctr r1



Take a previously computed value from \$cr and store in r1

#### Load word:

lw r1



Take a value from a previously computed memory address from \$cr and store in r1

## Load upper immediate:

*lui* r1, upper(big)

| 1001 | r1 | immediate |
|------|----|-----------|
| 4    | 4  | 8         |

Load top half of 16-bit immediate into r1

#### Load lower immediate:

lli r1, lower(big)

| 1010 | r1 | immediate |
|------|----|-----------|
| 4    | 4  | 8         |

Load lower half of 16-bit immediate into r1

#### Store word:

sw r1



Store value in r1 at the previously computed memory address in register \$cr.

#### Read from input:

rfi r1

| 1110 | r1 | XXXXXXXXXXXXXXXX |
|------|----|------------------|
| 4    | 4  | 8                |

Reads whatever is in the input register and copies it to r1.

### Write to Output:

rto r1



Writes whatever is in the given register to the output register.

### **Pseudo Instructions**

These are instructions that do not actually exist, but that our processor will handle with smaller instructions. All pseudo instructions are I-type. Translations are provided.

#### **OR** immediate:

ori r1, big

| 1100 | r1 | immediate |
|------|----|-----------|
| 4    | 4  | 8         |

Stores the logical OR of r1 and immediate into register \$cr

Translation:

lui \$i0, upper(big)

Ili \$i1, lower(big)

or \$i0, \$i1

or r1, \$cr

#### Load address:

la r1, address

| 1 | 101 | r1 | address |
|---|-----|----|---------|
|   | 4   | 4  | 8       |

Stores the address in immediate into r1

#### Translation:

```
lui $i0, upper(address)
lli $i1, lower(address)
or $i0, $i1
ctr r1
```

## Register to Register:

rtr r1, r2

| 1110 | r1 | r2 | XXXXXXX |
|------|----|----|---------|
| 4    | 4  | 4  | 4       |

Moves the value in r2 to r1.

#### Translation:

Itr \$i0, 0 add \$r2, \$i0 ctr r1

## Example 1 - relPrime and Euclid's algorithm:

```
relPrimeSetup:
      Itr $t0 -4
      add $st $t0
      sw $ra
      add $st $t0
      sw $s0
      Itr $t1 2
                  # m = 2
      rtr $a1 $t1 # m in $a1
      rtr $s0 $a1 # m in $s0
      rfi $a0
relPrimeLoop:
      Itr $t0 1
      Itr $t1 0
      add $t1 $t0
      jal gcd
      bieq $v cleanup # if gcd(n, m) == 1 jump to cleanup
      # body of while loop
```

```
Itr $t0 1
      add $s0 $t0 # m + 1
                          # m = m + 1
      ctr $s0
      rtr $a1 $s0
      j relPrimeLoop
gcd:
      Itr $t0 0
      add $t0 $t0
      bneq $a0 subOne # if a != 0, go to subOne
      rtr $v $a1
      jr $ra # return to loop
subOne:
      slt $a1 $a0
      Itr $t0 1
      bieq t0 subTwo # if (a > b) go to subTwo
      sub $a1 $a0 #b-a
      ctr $a1
                  #b = b - a
      rtr $v $a0 # return a
      jr $ra
subTwo:
      sub $a0 $a1 #a-b
      ctr $a0
                  # a = a - b
      rtr $v $a0
                   # return a
      jr $ra
cleanup:
      # restore $s0 from stack
      rtr $v $a1
                   # return m
      Itr $t0 0
      add $st $t0
      lw $s0
      Itr $t0 4
      add $st $t0
      lw $ra
      add $st $t0
      jr $ra
```

## Example 2 - Common operations:

## **Table of Common Operations**

|                          | SAPA                                                                                                                                | 1.0               |                                                                                 | Description                                                                                                                                                                 |  |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Load Address             | la                                                                                                                                  | \$s2, 0           | )x4EF6                                                                          | Loading an address is a pseudoinstruction. Refer to <i>Pseudoinstruction</i> for full details on how <i>la</i> works.                                                       |  |
| Iterations               | Itr \$s1, 15  Itr \$t0, 1  Itr \$t1, 0  Itr \$t2, 3  Ioop: slt \$s1, \$t1  bieq \$t0, exit  add \$t1, \$t2  ctr \$t1  j Ioop  exit: |                   | \$t0, 1<br>\$t1, 0<br>\$t2, 3<br>\$s1, \$t1<br>\$t0, exit<br>\$t1, \$t2<br>\$t1 | This for-loop keeps adding 3 to register \$s3 (0) until \$t1 becomes greater than \$s1 (15), resulting with a 18 stored in \$t1 after the loop has exited.                  |  |
| Branches                 |                                                                                                                                     | S                 | ee above                                                                        | The example above utilizes <i>slt</i> and <i>bieq</i> to create a branch on greater than, which isn't an instruction itself but can be created using multiple instructions. |  |
| Reading from inputs      |                                                                                                                                     | rfi               | \$s1                                                                            | In this example, this function reads whatever is in the input register and copies it to the given register.                                                                 |  |
| Writing to outputs       | func:                                                                                                                               | <br>wto<br>       | \$s1                                                                            | This function writes whatever is in the given register to the output register.                                                                                              |  |
| Reading from display reg |                                                                                                                                     | ltr<br>add<br>ctr | \$t0, 0<br>\$d, \$t0<br>\$s0                                                    | Here, we read the data in the display reg \$d into \$cr and copy the data to a general purpose register (\$s0).                                                             |  |
| Writing to display reg   |                                                                                                                                     | ltr<br>out        | \$d, 415                                                                        | In this example, we write a value into \$d and then output it into a 16-bit LCD screen.                                                                                     |  |

## **Machine Language**

## **Instruction Types:**

## **Basic Instruction Formats:**

C-type, Computation types (register to register)

| opcode | r1 | r2 | func |   |
|--------|----|----|------|---|
| 15     | 11 | 7  | 3    | 0 |

C-type instructions are used for register to register computations. They handle arithmetic and logical computations such as add, sub, and, or, etc. These instructions share a single opcode, and are distinguishable by their func code.

*I-type, Immediate types (register to data, register to memory)* 

| opcode | r1 | immediate |   |
|--------|----|-----------|---|
| 15     | 11 | 7         | 0 |

I-type instructions are used for register to data and register to memory computations. These instructions handle storing data from registers into memory and loading data into registers from memory, immediate values, and the \$cr register. They also handle control flow such as branches and jumps that are necessary for loops and procedure calls.

## Rules for Translating Assembly to Machine Language:

Arithmetic and logical instructions are directly translated from their assembly to the machine language. For example, the following assembly would translate accordingly into binary:

add \$s2. \$t3

| 0000 | 0010 | 0111 | 0000 |
|------|------|------|------|
| ор   | r1   | r2   | func |

Registers are directly translated from their respective numbers in the registry (see chart in Registers).

*Branch instructions* are PC-relative, meaning they use an 8-bit offset that allows a user to jump to 2<sup>7</sup>-1 instructions forward or 2<sup>7</sup> backward. A translation may appear as below (where "loop" is 3 instructions above bieq):

bieq \$s0, loop

| 0001 | 0000 | 1101 |            |
|------|------|------|------------|
| OD   | r1   | _    | BranchAddr |

*Jump instructions* use an 8-bit immediate with the top 8 bits of the PC concatenated to create a 16-bit address. Jump instructions use this address for the new PC address to jump to, allowing us to jump  $2^7$ -1 instructions forward or  $2^7$  backward.

Load/store instructions are directly translated from like arithmetic and logical instructions. The following assembly would translate accordingly:

Iw \$t0

| 1000 | 0101 | unused |
|------|------|--------|
| ор   | r1   | lmm    |

For the assembly to machine language translation of all instructions, refer to the chart below.

Key: 8 = \$cr, 9 = \$ra

| Instruction                                                       | Instruction Type Verilog |                                | Descript | on of bit | s and ru | ıles  |
|-------------------------------------------------------------------|--------------------------|--------------------------------|----------|-----------|----------|-------|
| Add                                                               | С                        | R[8] = R[r1] + R[r2]           | 0000     | r1        | r2       | 0000  |
| Sub                                                               | С                        | R[8] = R[r1] - R[r2]           | 0000     | r1        | r2       | 0001  |
| AND                                                               | С                        | R[8] = R[r1] & R[r2]           | 0000     | r1        | r2       | 0010  |
| OR                                                                | С                        | R[8] = R[r1]    R[r2]          | 0000     | r1        | r2       | 0011  |
| NOR                                                               | С                        | R[8] = ~(R[r1]    R[r2])       | 0000     | r1        | r2       | 0100  |
| Set Less<br>Than                                                  | С                        | R[8] = (R[r1] < R[r2]) ? 1 : 0 | 0000     | r1        | r2       | 0101  |
| Branch I If $(R[8] = R[r1])$<br>Equal PC = PC + 4 +<br>BranchAddr |                          | 0001                           | r1       | Branch    | nAddr    |       |
| Branch<br>Not Equal                                               | \ \ \ \ \ \ \ \ \ \ \ \  |                                | 0010     | r1        | Branch   | nAddr |

| Jump                       | I                        | PC = JumpAddr                  | 0011 | xxx | JumpAd  | ddr |
|----------------------------|--------------------------|--------------------------------|------|-----|---------|-----|
| Jump and<br>Link           | I                        | R[9] = PC + 8<br>PC = JumpAddr | 0100 | r1  | JumpAd  | ddr |
| Jump<br>Register           | I                        | PC = R[r1]                     | 0101 | r1  | XXX     |     |
| Load to<br>Register        | I                        | R[r1] = SignExtImm             | 0110 | r1  | Immedia | ate |
| Copy to<br>Register        | I R[r1] = R[8]           |                                | 0111 | r1  | XXX     |     |
| Load<br>Word               | 1 2 2 2 2 3              |                                | 1000 | r1  | XXX     |     |
| Load<br>Upper<br>Immediate | Upper                    |                                | 1001 | r1  | Immedia | ate |
| Load<br>Lower<br>Immediate | wer                      |                                | ate  |     |         |     |
| Store<br>Word              |                          |                                | 1011 | r1  | XXX     |     |
| ORi                        | I R[8] = r1   ZeroExtImm |                                | 1100 | r1  | Immedia | ate |
| Load<br>Address            | I                        | R[r1] = SignExtImm             | 1101 | r1  | Immedia | ate |
| Register<br>to<br>Register | С                        | R[r1] = R[r2]                  | 1110 | r1  | r2      | XXX |

# **Machine Language Translations:**

| imeSetup:<br>Itr \$t0 -4 |                    |      |       |      |
|--------------------------|--------------------|------|-------|------|
| , , ,                    | 0110               | 0100 | 11111 | 1100 |
| add \$st \$t0            |                    |      |       |      |
|                          | 0000               | 1110 | 0100  | 0000 |
| sw \$ra                  |                    |      |       |      |
|                          | 1011               | 1001 | xxxxx | xxx  |
| add \$st \$t0            |                    |      |       |      |
|                          | 0000               | 1110 | 0100  | 0000 |
| sw \$s0                  |                    |      |       |      |
|                          | 1011               | 0000 | xxxxx | xxx  |
| Itr \$t1 2               | # m <u>= 2</u>     |      |       |      |
|                          | 0110               | 0101 | 00000 | 0010 |
| rtr \$a1 \$t1            | # m <u>in \$a1</u> |      |       |      |
|                          | 0110               | 1111 | 00000 | 0000 |
|                          | 0000               | 0101 | 1111  | 0000 |
|                          | 0111               | 1011 | xxxxx | xxx  |
| rtr \$s0 \$a1            | # m in \$s0        |      |       |      |
|                          | 0110               | 1111 | 00000 | 0000 |
|                          | 0000               | 1011 | 1111  | 0000 |
|                          |                    |      |       |      |

|                             |                   |                 | 1            |          | 1    |
|-----------------------------|-------------------|-----------------|--------------|----------|------|
|                             | 0111              | 0000            |              | XXXXXXXX |      |
| rfi \$a0                    |                   |                 |              |          |      |
|                             | 1110              | 1010            |              | xxxxxxx  |      |
|                             |                   |                 |              |          |      |
| relPrimeLoop:<br>Itr \$t0 1 |                   |                 | <del>-</del> |          |      |
|                             | 0110              | 0100            |              | 00000001 | 1    |
| Itr \$t1 0                  |                   |                 |              |          |      |
|                             | 0110              | 0101            |              | 00000000 | )    |
| add \$t1 \$t0               |                   |                 |              |          |      |
|                             | 0000              | 0101            | 0100         | )        | 0000 |
| jal gcd                     |                   |                 |              |          |      |
| jai goa                     | 0100              | xxxx            |              | 01010100 | )    |
| bieq \$v cleanup a          | # if acd(n, m) == | 1 iump to clean | ın           |          |      |
| bied w cleanup              | 0001              | 1100            | цρ           | 1010000  |      |
|                             |                   |                 |              |          |      |
| # body of while lo          | оор               |                 |              |          |      |
|                             | 0110              | 0100            |              | 00000001 | 1    |
| add \$s0 \$t0 # m           | ı + 1             |                 |              |          |      |
| 333 733 733                 | 0000              | 0000            | 0100         | )        | 0000 |
| ctr \$s0                    | # m = m + 1       |                 | •            |          |      |
| ou çoo                      | 0111              | 0000            |              | xxxxxxx  |      |
| rtr \$a1 \$s0               |                   | <u> </u>        |              |          |      |
| τα φαι φου                  | 0110              | 1111            |              | 00000000 | )    |
|                             |                   |                 |              |          |      |

|      |                                            | 0000 | 0000 | 111 | 1        | 0000 |  |  |  |
|------|--------------------------------------------|------|------|-----|----------|------|--|--|--|
|      |                                            | 0111 | 1011 |     | xxxxxxx  |      |  |  |  |
|      | j relPrimeLoop                             |      |      |     |          |      |  |  |  |
|      |                                            | 0011 | xxxx |     | 00101000 |      |  |  |  |
| gcd: | Itr \$t0 0                                 |      |      |     |          |      |  |  |  |
|      | π φτο σ                                    | 0110 | 0100 |     | 00000000 | )    |  |  |  |
|      | add \$t0 \$t0                              |      |      |     |          |      |  |  |  |
|      |                                            | 0000 | 0100 | 010 | 0        | 0000 |  |  |  |
|      | bneq \$a0 subOne # if a != 0, go to subOne |      |      |     |          |      |  |  |  |
|      |                                            | 0010 | 1010 |     | 01101100 | )    |  |  |  |
|      | rtr \$v \$a1                               |      |      |     |          |      |  |  |  |
|      |                                            | 0110 | 1111 |     | 00000000 |      |  |  |  |
|      |                                            | 0000 | 1011 | 111 | 1        | 0000 |  |  |  |
|      |                                            | 0111 | 1100 |     | xxxxxxx  |      |  |  |  |
|      | jr \$ra # return to                        | loop |      |     |          |      |  |  |  |
|      |                                            | 1010 | 1001 |     | xxxxxxx  |      |  |  |  |
| subO | ne:<br>slt \$a1 \$a0                       |      |      |     |          |      |  |  |  |
|      | 2.0 400                                    | 0000 | 1011 | 101 | 0        | 0111 |  |  |  |

Itr \$t0 1

|      |                      |                 | 0110            | 0100      |     | 00       | 000001                                         |
|------|----------------------|-----------------|-----------------|-----------|-----|----------|------------------------------------------------|
|      | bieq \$t0 sub        | Two             | # if (a > b) go | to subTwo |     |          |                                                |
|      | • •                  |                 | 0001            | 0100      |     | 10       | 001100                                         |
|      | sub \$a1 \$a0        | # b             | - a             |           |     |          |                                                |
|      | σασ φαι φασ          | <i></i> <b></b> | 0000            | 1011      |     | 1010     | 0001                                           |
|      | ctr \$a1             | # h             | = b - a         |           |     |          |                                                |
|      | σι φαι               | πIJ             | 0111            | 1011      |     | XX       | (XXXXXX                                        |
|      | rtr \$v \$a0         | # ro            | turn a          |           |     |          |                                                |
|      | τιι ψν ψάο           | <del>π</del> 10 | 0110            | 1111      |     | 00       | 000000                                         |
|      |                      |                 |                 | I         |     |          |                                                |
|      |                      |                 | 0000            | 1010      |     | 1111     | 0000                                           |
|      |                      |                 | 0111            | 1100      |     |          | (XXXXXX                                        |
|      |                      |                 | 0111            | 1100      |     |          | ~~~~                                           |
|      | jr \$ra              |                 |                 |           |     |          |                                                |
|      |                      |                 | 0101            | 1001      |     | XX       | XXXXXX                                         |
|      |                      |                 |                 |           |     |          |                                                |
| subT | wo:<br>sub \$a0 \$a1 | # a             | - b             |           |     |          |                                                |
|      | σασ φασ φα ι         | <i>"</i> α      | 0000            | 1010      | 101 | 1        | 0001                                           |
|      | ctr \$a0             | # 2             | = a- b          |           | l   |          |                                                |
|      | Cii ψao              | πа              | 0111            | 1010      |     | xxxxxxx  |                                                |
|      |                      |                 |                 |           |     | <u> </u> |                                                |
|      | rtr \$v \$a0         | # re            | turn a          | 4444      |     | 0000000  | <u>,                                      </u> |
|      |                      |                 | 0110            | 1111      |     | 00000000 | J                                              |
|      |                      |                 | 0000            | 1010      | 111 | 1        | 0000                                           |
|      |                      |                 |                 |           |     |          |                                                |

|                                                 | 0111                 | 1100 | xxx  | xxxxx     |
|-------------------------------------------------|----------------------|------|------|-----------|
| jr \$ra                                         |                      |      |      |           |
| •                                               | 0101                 | 1001 | xxx  | xxxxx     |
|                                                 |                      | ·    | ·    |           |
| cleanup:<br># restore \$s0 fr<br>rtr \$v \$a1 # | om stack<br>return m |      |      |           |
|                                                 | 0110                 | 1111 | 000  | 00000     |
|                                                 | 0000                 | 1011 | 1111 | 0000      |
|                                                 | 0111                 | 1100 | xxx  | xxxxxxx   |
| Itr \$t0 0                                      |                      |      |      |           |
|                                                 | 0110                 | 0100 | 000  | 00000     |
| add \$st \$t0                                   |                      |      |      |           |
|                                                 | 0000                 | 1110 | 0100 | 0000      |
| lw \$s0                                         |                      |      |      |           |
|                                                 | 1000                 | 0000 | xxxx | (XXXX     |
| Itr \$t0 4                                      |                      |      |      |           |
|                                                 | 0110                 | 0100 |      | 00000100  |
| add \$st \$t0                                   |                      |      |      |           |
|                                                 | 0000                 | 1110 | 0100 | 0000      |
| lw \$ra                                         |                      |      |      |           |
|                                                 | 1000                 | 1001 | xxxx | (XXXXXXXX |
| add \$st \$t0                                   |                      |      |      |           |
|                                                 | 0000                 | 1110 | 0100 | 0000      |
|                                                 |                      |      |      |           |

jr \$ra

| 0101 | 1001 | xxxxxxxx |
|------|------|----------|
|------|------|----------|

## **Journal**

## Meeting 1: Tuesday, 10 January 2017

We began the meeting by discussing the features we most wanted to include in our processor. We hoped this would guide our design throughout the meeting.

We decided to build a processor that is primarily based on a combination of load-store and accumulator designs. One specific register will hold the value of the last arithmetic or logical computation. This register will be read only for users to copy and read the value of the last computation. We will also allow users a small set of registers to save values beyond a computation and save values over procedure calls.

Our processor will have 18 registers in total, 15 of which are available to the user in some capacity (read/write). There are 8 general purpose registers, and 8 special registers. We decided on a small, specific instruction set made up of one major type, an arithmetic/logical type that returns all results to the special computation register, as well as other instructions of varying sizes. We believe that varying sizes will help keep our programs small in size and more efficient.

For procedure calls, we thought it would be interesting to make arguments and return values memory addresses only. We acknowledge the inefficiencies of that design but felt that the value of having direct access to the memory address of the arguments and return values was a valuable asset to our design.

## Work log:

(majorly a group effort worked on during the 3 hour period):

Design and description of registers, instruction type and format, procedure call conventions (Discussion)

Trinity - Journal Notes

## Meeting 2: Wednesday, 11 January 2017

We are doing a lot of redesigning based on feedback and more direction with the project. We decided to standardize the size of instructions to 16 bits. We now have two types of instructions, a C-type for register to register computations and an I-type for other instructions that require a register and immediate values such as load/store, branch, jump. The I-type include all of our instructions with previously varying sizes. By establishing a standard size and design for instructions, we are able to greatly simplify our design and get a better direction on designing instructions.

We decided to scrap the memory address-only idea for arguments and return values as it would be a cumbersome design at our current state of progress.

By the end of the day, we've ended up with 20 registers, deciding to split our general purpose registers between saved and temporary registers. Our number of instructions has grown to include a number of pseudoinstructions as Shaun began coding the programs

## Work log:

Over 5 hour group time:

Khaled and Shaun - Register Descriptions (write up)

Logan - Assembly Syntax and Semantics, addressing modes, grammar and formatting

Trinity - Procedure Call Conventions (write up), Journal, Machine language instruction format type and semantics, rules for translating assembly to machine language

Khaled - Assembly fragments

Shaun (assisted by Trinity) - Euclid's algorithm and relPrime (Assembly)

Group - moderate redesign of instruction format, registers, and instructions After meeting (2 hours):

Shaun (assisted by Khaled) - Euclid's algo/relPrime (Machine Language)