MIT OpenCourseWare http://ocw.mit.edu

6.004 Computation Structures Spring 2009

For information about citing these materials or our Terms of Use, visit: http://ocw.mit.edu/terms.

## **Summary of β Instruction Formats**

## **Operate Class:**

| 31  | 26     | 25 | 21 | 20 | 16 | 15 | 11 | 10 |        | 0 |
|-----|--------|----|----|----|----|----|----|----|--------|---|
| 102 | 10xxxx |    | lc | R  | la | R  | 'h |    | unused |   |

| Register | Symbol | Usage                 |
|----------|--------|-----------------------|
| R31      | R31    | Always zero           |
| R30      | XP     | Exception pointer     |
| R29      | SP     | Stack pointer         |
| R28      | LP     | Linkage pointer       |
| R27      | BP     | Base of frame pointer |

OP(Ra,Rb,Rc):  $Reg[Rc] \leftarrow Reg[Ra] \text{ op } Reg[Rb]$ 

Opcodes: **ADD** (plus), **SUB** (minus), **MUL** (multiply), **DIV** (divided by) **AND** (bitwise and), **OR** (bitwise or), **XOR** (bitwise exclusive or)

**CMPEQ** (equal), **CMPLT** (less than), **CMPLE** (less than or equal) [result = 1 if true, 0 if false]

SHL (left shift), SHR (right shift w/o sign extension), SRA (right shift w/ sign extension)

| 31 | 26     | 25 21 | 20 16 | 15 0                       |
|----|--------|-------|-------|----------------------------|
|    | 11xxxx | Rc    | Ra    | literal (two's complement) |

 $OPC(Ra, literal, Rc): Reg[Rc] \leftarrow Reg[Ra] \text{ op } SEXT(literal)$ 

Opcodes: ADDC (plus), SUBC (minus), MULC (multiply), DIVC (divided by)

ANDC (bitwise and), ORC (bitwise or), XORC (bitwise exclusive or)

**CMPEQC** (equal), **CMPLTC** (less than), **CMPLEC** (less than or equal) [result = 1 if true, 0 if false]

SHLC (left shift), SHRC (right shift w/o sign extension), SRAC (right shift w/ sign extension)

## Other:

| 31     | 26 | 25 | 21 | 20 | 16 | 15                     | 0    |
|--------|----|----|----|----|----|------------------------|------|
| 01xxxx |    | R  | .c | R  | la | literal (two's complem | ent) |

**LD**(Ra,literal,Rc):  $Reg[Rc] \leftarrow Mem[Reg[Ra] + SEXT(literal)]$ **ST**(Rc,literal,Ra):  $Mem[Reg[Ra] + SEXT(literal)] \leftarrow Reg[Rc]$ 

**JMP**(Ra,Rc):  $Reg[Rc] \leftarrow PC + 4$ ;  $PC \leftarrow Reg[Ra]$ 

**BEQ/BF**(Ra,label,Rc): Reg[Rc]  $\leftarrow$  PC + 4; if Reg[Ra] = 0 then PC  $\leftarrow$  PC + 4 + 4\*SEXT(literal) **BNE/BT**(Ra,label,Rc): Reg[Rc]  $\leftarrow$  PC + 4; if Reg[Ra]  $\neq$  0 then PC  $\leftarrow$  PC + 4 + 4\*SEXT(literal)

**LDR**(label,Rc): Reg[Rc]  $\leftarrow$  Mem[PC + 4 + 4\*SEXT(literal)]

## **Opcode Table: (\*optional opcodes)**

| 2:0 |      |      |       |       |        |        |        |     |
|-----|------|------|-------|-------|--------|--------|--------|-----|
| 5:3 | 000  | 001  | 010   | 011   | 100    | 101    | 110    | 111 |
| 000 |      |      |       |       |        |        |        |     |
| 001 | IOR  | IOW  |       |       |        |        |        |     |
| 010 |      |      |       |       |        |        |        |     |
| 011 | LD   | ST   | LDI   | JMP   | SVC    | BEQ    | BNE    | LDR |
| 100 | ADD  | SUB  | MUL*  | DIV*  | CMPEQ  | CMPLT  | CMPLE  |     |
| 101 | AND  | OR   | XOR   |       | SHL    | SHR    | SRA    |     |
| 110 | ADDC | SUBC | MULC* | DIVC* | CMPEQC | CMPLTC | CMPLEC |     |
| 111 | ANDC | ORC  | XORC  |       | SHLC   | SHRC   | SRAC   |     |