# Instruction Set Architecture

#### Contents

- Instruction
- Instruction set
  - Number of Address
  - Addressing modes
  - Operand types
  - Operations types
- Assembly programming



#### Instruction Length

- Affected by
  - Memory size/organization, register numbers, bus structure, etc
- Flexibility vs. Implementation Complexity
- Memory–transfer consideration
- Fixed vs. non-fixed instructions

#### Instruction Set

- The collection of different instructions CPU can understand and execute
- Different instructions
  - Number of addresses/addressing modes
  - Operand types
  - Operation types

#### Number of Addresses

#### 3 addresses

- Operand 1, Operand 2, Result
- e.g. a=b+c
- 2 address
  - One address doubles as operand and result
     e.g. a = a+c
- 1 address
  - Implicit second address (accumulator)
- 0 address
  - All addresses are implicitly defined
  - Stack based computer

| Example: Y=(.                                                                                        | A-B)/(C+D x E)                               |  |
|------------------------------------------------------------------------------------------------------|----------------------------------------------|--|
| <ul> <li>Three Addresses:<br/>SUB Y, A, B<br/>MPY T, D, E<br/>ADD T, T, C<br/>DIV Y, Y, T</li> </ul> | # Y← A-B<br># T← DxE<br># T← T+C<br># Y← Y/T |  |
| Two Addresses                                                                                        |                                              |  |
| MOV Y, A                                                                                             | #Y← A                                        |  |
| SUB Y, B                                                                                             | #Y←Y-B                                       |  |
| MOV T, D                                                                                             | #T←D                                         |  |
|                                                                                                      | #1€IXE                                       |  |
|                                                                                                      | # 1 <del>&lt; 1+</del> 6<br># V < V/T        |  |
|                                                                                                      | #151/1                                       |  |

## Example: $Y=(A-B)/(C+D \times E)$

|--|

#### A little bit about Stack

- A list of data element
- Data can be added or removed from one of its end (top of the stack)
- Static operations
  - Push
  - Pop
  - Unary operation (such as negation)
  - Binary operation (such as multiplication)









#### How Many Addresses

#### More addresses

- Description: More complex (powerful?) instructions
- More registers
  - Inter-register operations are quicker
- Fewer instructions per program
- Fewer addresses
  - Less complex (powerful?) instructions
  - In More instructions per program
  - Faster fetch/execution of instructions

#### Instruction Addressing

#### What

- □ How is the address of an operand specified
- Different addressing mode
  - Immediate
  - Direct
  - Indirect
  - Register
  - Register indirect
  - Displacement
  - Stack



#### Direct Addressing

- Address field contains address of operand
- Effective address (EA) = address field (A)
- e.g. ADD A
  - Add contents of cell A to accumulator
     Look in memory at address A for operand
- Single memory reference to access data
- No additional calculations to work out effective address
- Limited address space





#### Indirect Addressing

- Memory cell pointed to by address field contains the address of (pointer to) the operand
- EA = (A)
  - Look in A, find address (A) and look there for operand
- e.g. ADD (A)
  - Add contents of cell pointed to by contents of A to accumulator

#### Indirect Addressing (Cont'd)

- Large address space
- 2<sup>n</sup> where n = word length
- May be nested, multilevel, cascaded
   e.g. EA = (((A)))
   Draw the diagram ?
- Multiple memory accesses to find operand
- Hence slower





#### Register Addressing

- Operand is held in register named in address filed
- EA = R
- Limited number of registers
- Very small address field needed
   Shorter instructions
  - Faster instruction fetch

#### Register Addressing (cont'd)

- No memory access
- Very fast execution
- Very limited address space
- Multiple registers helps performance
   Requires good assembly programming or compiler writing
  - Compare with Direct addressing





#### Register Indirect Addressing

- EA = (R)
- Operand is in memory cell pointed to by contents of register R

   Compare with indirect addressing
- Large address space (2<sup>n</sup>)
- One fewer memory access than indirect addressing





#### Displacement Addressing

- EA = A + (R)
- Address field hold two values
  - A = base value
  - R = register that holds displacement
  - or vice versa





# Stack Addressing

- Operand is (implicitly) on top of stack
- ∎ e.g.
  - ADD Pop top two items from stack and add

#### Basic Addressing Mode Summary

| Mode              | Algorithm                           | Principal Advantage | Principal Disadvantage     |
|-------------------|-------------------------------------|---------------------|----------------------------|
| Immediate         | Operand = A                         | No memory reference | Limited operand magnitude  |
| Direct            | $\mathbf{E}\mathbf{A} = \mathbf{A}$ | Simple              | Limited address space      |
| Indirect          | EA = (A)                            | Large address space | Multiple memory references |
| Register          | EA = R                              | No memory reference | Limited address space      |
| Register indirect | EA = (R)                            | Large address space | Extra memory reference     |
| Displacement      | EA = A + (R)                        | Flexibility         | Complexity                 |
| Stack             | EA = top of stack                   | No memory reference | Limited applicability      |

# Memory alignment Addressing a data type large than byte must be aligned An access to an object of size S bytes at byte address A is aligned if A mod s = 0. Obxxxxxxxx byte (8bit) aligned Obxxxxxxx0 half word (16bit) aligned Obxxxxxx00 word (32bit) aligned Obxxxxxx00 double word (64bit) aligned Why aligned? Misalignment causes implementation complications

#### Little/Big Endian

- Little Endian:
   put the least-significant byte first
- Big Endian:
   put the most-significant byte first

#### Big/Little Endian Example

32bit data 0xFABC0123 at address 0xFF20

|               | 0xFF20 | 0xFF21 | 0xFF22 | 0xFF23 |
|---------------|--------|--------|--------|--------|
| Big Endian    | 0xFA   | 0xBC   | 0x01   | 0x23   |
| Little Endian | 0x23   | 0x01   | 0xBC   | 0xFA   |
|               |        |        |        |        |

## Operand Types

Numbers

- Integer
  - Byte, short, word, long word
  - Unsigned/signed
- Floating point
  - Float
  - Double
- Characters
- Logical Data





#### Transfer of Control

Branch

e.g. branch to x if result is zero

Procedure call

#### Branch

- Unconditional branch
  - One of its operands is the address of next instruction to be executed
- Conditional branch
  - Using status register
    - Execution of an instruction may change the status, e.g. positive, negative, overflow, ...
  - Multi-address format

























#### MIPS Addressing

- Can be big/little endian
- All memory access must be aligned
- Addressing modes
  - Register indirect
    - Ex: JR R1
  - Displacement
    - Ex: ST R1, 100(R2)
- Addressing modes encoded in opcode

#### Encoding MIPS64 ISA

- Fixed length encoding 32 bits
  - I-type instructions
  - R-type instructions
  - J-type instructions









- Simple instructions
  - □ Load/store, add, subtract, multiply, divide, shift, ...
  - Ex: DADD, DADDI, DADDU
- Control Flow
  - □ Compare equal/not equal, compare less, ...
  - Ex: BEQZ, JR
- Floating point
  - □ Load/store, add, subtract,...
  - Ex: ADD.D, ADD.S, MUL.D, MUL.S

# Load/Store

| Instruction type/opcode | Instruction meaning                                                                                                                                                |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Data transfers          | Move data between registers and memory, or between the integer and FP or special<br>registers; only memory address mode is 16-bit displacement + contents of a GPR |  |
| LB,LBU,SB               | Load byte, load byte unsigned, store byte (to/from integer registers)                                                                                              |  |
| LH, LHU, SH             | Load half word, load half word unsigned, store half word (to/from integer registers)                                                                               |  |
| LW,LWU,SW               | Load word, load word unsigned, store word (to/from integer registers)                                                                                              |  |
| LD, SD                  | Load double word, store double word (to/from integer registers)                                                                                                    |  |
| L.S,L.D,S.S,S.D         | Load SP float, load DP float, store SP float, store DP float                                                                                                       |  |
| WFCO, MTCO              | Copy from/to GPR to/from a special register                                                                                                                        |  |
| MOV.S,MOV.D             | Copy one SP or DP FP register to another FP register                                                                                                               |  |
| NFC1.MTC1               | Copy 32 bits from/to FP registers to/from integer registers                                                                                                        |  |

| Load/S              | tore               |                                                                                                                   |
|---------------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
|                     |                    |                                                                                                                   |
|                     |                    |                                                                                                                   |
|                     |                    |                                                                                                                   |
| Example instruction | Instruction name   | Meaning                                                                                                           |
| LD R1,30(R2)        | Load double word   | Regs[R1] ← 44 Mem[30+Regs[R2]]                                                                                    |
| LD R1,1000(R0)      | Load double word   | Regs[R1] +- sa Mem[1000+0]                                                                                        |
| LW R1,60(R2)        | Load word          | Regs[R1] ← 44 (Mem[60+Regs[R2]])32 ## Mem[60+Regs[R2]]                                                            |
| LB R1,40(R3)        | Load byte          | Regs[R1]+-64 (Mem[40+Regs[R3]] <sub>0</sub> ) <sup>56</sup> ##<br>Mem[40+Regs[R3]]                                |
| LBU R1,40(R3)       | Load byte unsigned | Regs[R1]++++ 056 ## Mem[40+Regs[R3]]                                                                              |
| LH R1,40(R3)        | Load half word     | Regs[R1] ← <sub>64</sub> (Mem[40+Regs[R3]] <sub>0</sub> ) <sup>40</sup> ##<br>Mem[40+Regs[R3]] ##Mem[41+Regs[R3]] |
| L.S F0,50(R3)       | Load FP single     | Regs[F0]+-#4 Mem[50+Regs[R3]] ## 012                                                                              |
| L.D F0,50(R2)       | Load FP double     | Regs[F0]++AA Mem[50+Regs[R2]]                                                                                     |
| SD R3,500(R4)       | Store double word  | Mem[500+Regs[R4]]+-++ Regs[R3]                                                                                    |
| SW R3,500(R4)       | Store word         | Mem[500+Regs[R4]]←12 Regs[R3]                                                                                     |
| S.S F0,40(R3)       | Store FP single    | Mem[40+Regs[R3]] -32 Regs[F0]0.31                                                                                 |
| 5.D F0,40(R3)       | Store FP double    | Mem[40+Regs[R3]]+-se Regs[F0]                                                                                     |
| 5H R3,502(R2)       | Store half         | Mem[502+Regs[R2]]+-14 Regs[R3]44 43                                                                               |
| 58 R2,41(R3)        | Store byte         | Mem[41+Regs[R3]]+-+ Regs[R2]++++                                                                                  |

| Arithmetic/logical                   | Operations on integer or logical data in GPRs; signed arithmetic trap on overflow                                     |
|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| DADD, DADDI, DADDU, DADDIU           | Add, add immediate (all immediates are 16 bits); signed and unsigned                                                  |
| DSUB, DSUBU                          | Subtract; signed and unsigned                                                                                         |
| DMUL,DMULU,DDIV,<br>DDIVU,MADD       | Multiply and divide, signed and unsigned; multiply-add; all operations take and yield 64-<br>bit values               |
| AND, ANDI                            | And, and immediate                                                                                                    |
| OR,ORI,XOR,XORI                      | Or, or immediate, exclusive or, exclusive or immediate                                                                |
| WI                                   | Load upper immediate; loads bits 32 to 47 of register with immediate, then sign-extend                                |
| OSLL,DSRL,DSRA,DSLLV,<br>DSRLV,DSRAV | Shifts: both immediate (DS_) and variable form (DS_V); shifts are shift left logical, right logical, right arithmetic |
| SLT.SLTI,SLTU,SLTIU                  | Set less than, set less than immediate; signed and unsigned                                                           |



# Arithmetical/Logical

| Exampl | e instruction | Instruction name       | Meaning                                                              |  |
|--------|---------------|------------------------|----------------------------------------------------------------------|--|
| DADDU  | R1,R2,R3      | Add unsigned           | $Regs[R1] \leftarrow Regs[R2] + Regs[R3]$                            |  |
| DADDIU | R1,R2,#3      | Add immediate unsigned | Regs[R1]←Regs[R2]+3                                                  |  |
| LUI    | R1,#42        | Load upper immediate   | Regs[R1]←0 <sup>32</sup> ##42##0 <sup>16</sup>                       |  |
| DSLL   | R1,R2,#5      | Shift left logical     | Regs[R1] $\leftarrow$ Regs[R2] << 5                                  |  |
| DSLT   | R1,R2,R3      | Set less than          | if (Regs[R2] <regs[r3])<br>Regs[R1]←1 else Regs[R1]↔(</regs[r3])<br> |  |



| Floating point        | FP operations on DP and SP formats                                                                                                                                      |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADD.D.,ADD.S,ADD.PS   | Add DP, SP numbers, and pairs of SP numbers                                                                                                                             |
| SUB.D, SUB.S, ADD. PS | Subtract DP, SP numbers, and pairs of SP numbers                                                                                                                        |
| HUL.D, MUL.S, MUL.PS  | Multiply DP, SP floating point, and pairs of SP numbers                                                                                                                 |
| MADD.D,MADD.S,MADD.PS | Multiply-add DP, SP numbers and pairs of SP numbers                                                                                                                     |
| DIV.D,DIV.S,DIV.PS    | Divide DP, SP floating point, and pairs of SP numbers                                                                                                                   |
| tit                   | Convert instructions: CVT. x. y converts from type x to type y, where x and y are l<br>(64-bit integer), W (32-bit integer), D (DP), or S (SP). Both operands are FPRs. |
| CD.CS                 | DP and SP compares: "_" = LT, GT, LE, GE, EQ, NE; sets bit in FP status register                                                                                        |

| Exan | ple        | Instruction name            | Manning                                                                                                                                   |
|------|------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| J    | name       | Jump                        |                                                                                                                                           |
| JAL  | name       | Jump and link               | Regs[R31] $\leftarrow$ PC+4; PC <sub>3663</sub> $\leftarrow$ name;<br>((PC+4)-2 <sup>27</sup> ) $\leq$ name $<$ ((PC+4)+2 <sup>27</sup> ) |
| JALR | R2         | Jump and link register      | Regs[R31] ← PC+4; PC←Regs[R2]                                                                                                             |
| JR   | R3         | Jump register               | PC Regs [R3]                                                                                                                              |
| BEQZ | R4,name    | Branch equal zero           | if (Regs[R4]==0) PC $\leftarrow$ name;<br>((PC+4)-2 <sup>17</sup> ) $\leq$ name < ((PC+4)+2 <sup>17</sup> )                               |
| BNE  | R3,R4,name | Branch not equal zero       | if (Regs[R3] != Regs[R4]) PC $\leftarrow$ name;<br>((PC+4)-2 <sup>17</sup> ) $\leq$ name $<$ ((PC+4)+2 <sup>17</sup> )                    |
| MOVZ | R1,R2,R3   | Conditional move<br>if zero | if $(Regs[R3]==0)$ Regs[R1] $\leftarrow$ Regs[R2]                                                                                         |



## MIPS Assembly Programming

"MIPS Assembly Language Programming", http://www.eecs.harvard.edu/~ellard/Courses/cs50-asm.pdf

#### Summary

- Instructions
- Instruction set
  - Number of Address
  - Addressing modes
  - Operand types
  - Operations types
- Assembly programming