# up2

## Ashley J. Robinson

November 26, 2017

1

 $\mathbf{2}$ 

- 2.1 ADD
- 2.2 SUB
- 2.3 OR
- 2.4 NOR
- 2.5 XOR
- 2.6 NAND
- 2.7 LSL

Logical Shift Left

#### 2.8 LSR

Logical Shift Right

## 2.9 BNE

Branch Not Equals

## 2.10 BE

Branch Equals

## 2.11 JMP

Jump

Table 1: My caption

| Opcode | Opcode |          |        |                                           |           |
|--------|--------|----------|--------|-------------------------------------------|-----------|
| Hex    | Binary | Mnemonic | Use MX | Description                               | Flags set |
| 0x0    | 0000   | ADD      | Yes    | iR0,R1,R2,?i = iR1,R2i + i+1,R0i          | Z         |
| 0x1    | 0001   | SUB      | Yes    | iR0,R1,R2,?; = $iR1,R2$ ; - $i+1,R0$ ;    | Z         |
| 0x2    | 0010   | OR       | Yes    | iR0,R1,R2,?; = $iR1,R2$ ; OR $i+1,R0$ ;   | Z         |
| 0x3    | 0011   | NOR      | Yes    | iR0,R1,R2,?; = $iR1,R2$ ; NOR $i+1,R0$ ;  | Z         |
| 0x4    | 0100   | XOR      | Yes    | iR0,R1,R2,?; = $iR1,R2$ ; XOR $i+1,R0$ ;  | Z         |
| 0x5    | 0101   | NAND     | Yes    | iR0,R1,R2,?; = $iR1,R2$ ; NAND $i+1,R0$ ; | Z         |
| 0x6    | 0110   | LSL      | Yes    | iR0,R1,R2,?; $=iR1,R2$ ; $ii$ 1           | Z         |
| 0x7    | 0111   | LSR      | Yes    | iR0,R1,R2,? $i = iR1,R2$ $i : i : 1$      | Z         |
| 0x8    | 1000   | BNE      | No     | if(Z != 1) PC += W                        |           |
| 0x9    | 1001   | BE       | No     | if(Z == 1) PC += W                        |           |
| 0xA    | 1010   | JMP      | No     | PC = CS[PC]                               |           |
| 0xB    | 1011   | INT      | No     | Enable ints                               |           |
| 0xC    | 1100   | DDS      | No     | DSP = 1                                   |           |
| 0xD    | 1101   | IDS      | No     | DSP += 1                                  |           |
| 0xE    | 1110   | DPS      | No     | PSP -= 1                                  |           |
| 0xF    | 1111   | IPS      | No     | PSP += 1                                  |           |

#### 2.12 INT

Enable/Disable interrupts

#### 2.13 DDS

Decrement Data Stack Pointer

#### 2.14 IDS

Increment Data Stack Pointer

#### 2.15 DPS

Decrement Program Counter Stack Pointer

#### 2.16 IPS

Increment Program Counter Stack Pointer

## 3 Programming Tips

#### 3.1 Zero a register

Objective: Set R1 to zero

 $LSL,R1,R1\ LSL,R1,R1\ LSL,R1,R1\ LSL,R1,R1$ 

## 3.2 Load Immediate

Objective: Load 0xA(1010) in to R2

 $\mathrm{OR,R1,R1,}{+1}\ \mathrm{LSL}\ \mathrm{LSL}\ \mathrm{OR,R1,R1,}{+1}\ \mathrm{LSL}$ 

## 3.3 Swapping registers

Objective: Swap R0 and R1  $\,$ 

 $\mathsf{XOR},\!\mathsf{R0},\!\mathsf{R1},\!\mathsf{R0}\;\mathsf{XOR},\!\mathsf{R1},\!\mathsf{R1},\!\mathsf{R0}\;\mathsf{XOR},\!\mathsf{R0},\!\mathsf{R1},\!\mathsf{R0}$