# **Instruction format**

|          | 15 14 13 12 | 11 10 | 98 | 76     | 5 4 3 2 1 0       |
|----------|-------------|-------|----|--------|-------------------|
| R-format | opcode      | rs    | rt | rd     | function          |
| I-format | opcode      | rs    | rt | in     | nmediate / offset |
| J-format | opcode      |       |    | target | address           |

# **Instruction Opcodes**

| Instruction | Opcode | Function Code | Format |
|-------------|--------|---------------|--------|
| [ADD]       | 15     | 0             | R      |
| [SUB]       | 15     | 1             | R      |
| [AND]       | 15     | 2             | R      |
| [ORR]       | 15     | 3             | R      |
| [NOT]       | 15     | 4             | R      |
| [TCP]       | 15     | 5             | R      |
| [SHL]       | 15     | 6             | R      |
| [SHR]       | 15     | 7             | R      |
| [ADI]       | 4      | _             | I      |
| [ORI]       | 5      | _             | I      |
| [LHI]       | 6      | _             |        |
| [RWD]       | 15     | 27            | R      |
| [WWD]       | 15     | 28            | R      |
| [LWD]       | 7      | _             | I      |
| [SWD]       | 8      | _             | I      |
| [BNE]       | 0      | _             |        |
| [BEQ]       | 1      | _             |        |
| [BGZ]       | 2      | _             |        |
| [BLZ]       | 3      | _             | I      |

| [JMP] | 9  | _  | J |
|-------|----|----|---|
| [JAL] | 10 | _  | J |
| [JPR] | 15 | 25 | R |
| [JRL] | 15 | 26 | R |
| [HLT] | 15 | 29 | R |
| [ENI] | 15 | 30 | R |
| [DSI] | 15 | 31 | R |

# **Assembler Directive**

- [BSC]
- [BSS]
- [END]
- [EQU]
- [ORG]

# **Instruction Description**

# ADD

- 1. Assembler Format
  - ADD \$rd, \$rs, \$rt
- 2. Description
  - The contents of \$rs and the contents of \$rt are added to form the result. The result is placed into \$rd.
- 3. Operation
  - \$rd <-- \$rs + \$rt
- 4. Examples

 ○
 ADD \$1, \$2, \$0
 ;\$1 <-- \$2 + \$0</td>

 ○
 ADD \$2, \$2, \$2
 ;\$2 <-- \$2 + \$2</td>

# SUB

- 1. Assembler Format
  - SUB \$rd, \$rs, \$rt
- 2. Description
  - The contents of \$rt are subtracted from the contents of \$rs to form the result. The result is placed into \$rd.
- 3. Operation
  - \$rd <-- \$rs + !\$rt + 1

4. Examples

```
o SUB $3, $0, $1 ;$3 <-- $0 - $1
o SUB $0, $0, $0 ;$0 <-- $0 - $0 ;This clears
$0.</pre>
```

#### AND

- 1. Assembler Format
  - AND \$rd, \$rs, \$rt
- 2. Description
  - The contents of \$rs are combined with the contents of \$rt in a bit-wise logical AND operation. The result is placed into \$rd.
- 3. Operation
  - \$rd <-- \$rs & \$rt
- 4. Examples

```
o AND $0, $1, $2 ;$0 <-- $1 & $2
o AND $3, $3, $3 ;;$3 <-- $3 & $3
o ;Contents of $3 are unchanged
```

# ORR

- 1. Assembler Format
  - ORR \$rd, \$rs, \$rt
- 2. Description
  - The contents of \$rs are combined with the contents of \$rt in a bit-wise logical OR operation. The result is placed into \$rd.
- 3. Operation
  - \$rd <-- \$rs | \$rt
- 4. Examples

```
    ORR $1, $2, $1
    ORR $3, $3, $3
    ;$1 <-- $2 | $1</li>
    ;$3 <-- $3 | $3</li>
    ;Contents of $3 are unchanged
```

#### NOT

- 1. Assembler Format
  - NOT \$rd, \$rs
- 2. Description
  - The bit-wise inverse of the contents of \$rs are placed into \$rd.
- 3. Operation
  - \$rd <-- !\$rs
- 4. Examples

• NOT \$0, \$1 ;\$0 <-- !\$1

• NOT \$3, \$3 ;\$3 <-- !\$3

# TCP

- 1. Assembler Format
  - $\circ$  TCP \$rd, \$rs
- 2. Description
  - The two's complement of the contents of \$rs is placed into \$rd.
- 3. Operation
  - \$rd <-- !\$rs + 1
- 4. Examples

```
      o
      TCP $0, $2
      ;$0 <-- !$2 + 1</td>

      o
      TCP $1, $1
      ;$1 <-- !$1 + 1</td>
```

# SHL

- 1. Assembler Format
  - $\circ$  SHL \$rd, \$rs
- 2. Description
  - The contents of \$rs are shifted left one bit, inserting zero into the least significant bit. The result is placed into \$rd.
- 3. Operation
  - \$rd <-- \$rs14..0 ## 0
- 4. Examples

• SHL \$0, \$1 ;\$0 <-- \$1 << 1

# SHR

- 1. Assembler Format
  - ∘ SHR \$rd, \$rs
- 2. Description
  - The contents of \$rs are shifted right one bit, sign-extending the most significant bit i.e. the value of the most significant bit is preserved. The result is placed into \$rd.
- 3. Operation
  - o \$rd <-- \$rs15 ## \$rs15..1</p>
- 4. Examples

| 0 | SHR | \$2 <b>,</b> | \$1 | ;\$2 | < | \$1 | >> | 1 |
|---|-----|--------------|-----|------|---|-----|----|---|
| 0 | SHR | \$1,         | \$1 | ;\$1 | < | \$1 | >> | 1 |

- 1. Assembler Format
  - o ADI \$rt, \$rs, imm
- 2. Description
  - The 8-bit immediate value is sign-extended to 16 bits and added to the contents of \$rs to form the result. The result is placed into \$rt.
- 3. Operation
  - o \$rt <-- \$rs + { (imm7)8 ## imm7..0 }</pre>
- 4. Examples

```
• ADI $0, $1, -17 ;$0 <-- $1 - 17
```

# ORI

- 1. Assembler Format
  - ORI \$rt, \$rs, imm
- 2. Description
  - The 8-bit immediate value is zero-extended to 16 bits and combined with the contents of \$rs in a bit-wise logical OR operation. The result is placed into \$rt.
- 3. Operation

```
o $rt <-- $rs | ( 08 ## imm7..0 )</pre>
```

4. Examples

```
    ORI $0, $1, 0xff;
    ORI $1, $0, 1000;
    IS this valid? Why or why
    ORI $2, $3, 0;
    ;$2 <-- $3;</li>
    ;Contents of $3 are copied to
```

# LHI

- 1. Assembler Format
  - ∘ LHI \$rt, imm
- 2. Description
  - The 8-bit immediate value is concatenated to 8 bits of zeros, the immediate value being the most significant halfword. The result is placed into \$rt.
- 3. Operation
  - o \$rt <-- imm7..0 ## 08</pre>
- 4. Examples

```
LHI $3, 15 ;$3 <-- 15 << 8</li>
LHI $2, 0 ;$2 <-- 0 This clears $2</li>
```

#### RWD

- 1. Assembler Format
  - RWD \$rd
- 2. Description
  - Program execution is halted until an input signal is received on the
  - input port. A 16-bit word is read from the input port and placed into \$rd.
- 3. Operation
  - \$rd <-- inputport
- 4. Examples

```
o RWD $2 ;$2 <-- inputport</pre>
```

#### WWD

- 1. Assembler Format
  - WWD \$rs
- 2. Description
  - The contents of \$rs are written to the output port and the output signal is asserted. Execution stops until an acknowledge is received from the output device.
- 3. Operation
  - outputport <-- \$rs</li>
- 4. Examples

```
    WWD $0
    ;outputport <-- $0</li>
```

# LWD

- 1. Assembler Format
  - LWD \$rt, \$rs, offset
- 2. Description
  - The 8-bit address offset is sign-extended and added to the contents of \$rs to form a memory address. The word at the specified memory location is loaded into \$rt.
- 3. Operation
  - o \$rt <-- M[\$rs + { (offset7)8 ## offset7..0 }]</pre>
- 4. Examples

```
      o
      LWD $0, $0, 16
      ;$0 <-- M[$0 + 16]</td>

      o
      LWD $0, $3, -4
      ;$0 <-- M[$3 - 4]</td>

      o
      LWD $0, $3, 0
      ;$0 <-- M[$3]</td>
```

# SWD

- 1. Assembler Format
  - SWD \$rt, \$rs, offset
- 2. Description

- The 8-bit address offset is sign-extended and added to the contents of \$rs to form a memory address. The contents of \$rt are stored at the specified memory location.
- 3. Operation
  - o M[\$rs + { (offset7)8 ## offset7..0 }] <-- \$rt</pre>
- 4. Examples

```
○SWD $1, $1, 120;M[$1 + 120] <-- $1</td>○SWD $1, $3, -2;M[$3 - 2] <-- $1</td>○SWD $1, $3, 0;M[$3] <-- $1</td>
```

#### BNE

- 1. Assembler Format
  - BNE \$rs, \$rt, offset
- 2. Description
  - A branch target address is computed from the sum of the address of the instruction after the branch instruction and the 8-bit, sign-extended offset. The contents of \$rs and \$rt are compared. If they are not equal, then the target address is written into the PC and program execution continues with the instruction at the target address. Otherwise, program execution continues with the instruction following the branch.
- 3. Operation
  - o If \$rs != \$rt then \$pc <-- \$pc + { (offset7)8 ## offset7..0 }</pre>
- 4. Examples

```
BNE $0, $2, 6 ; If $0 != $2 then $pc <-- $pc + 7
0
    BNE $1, $2, LOOP1 ; If $1 != $2 then $pc <-- LOOP1
0
    ; The last example is the common usage.
0
    ;Note that if a label is in the offset field in
0
    ;the assembly instruction, the assembler
0
    ; will compute the offset and insert it into
0
   ;the binary instruction. If a number is in
0
    ;the offset field, the number itself will be
0
    ; inserted into the binary instruction.
0
```

#### BEQ

- 1. Assembler Format
  - BEQ \$rs, \$rt, offset
- 2. Description
  - A branch target address is computed from the sum of the address of the instruction after the branch instruction and the 8-bit, sign-extended offset. The contents of \$rs and \$rt are compared. If they are equal, then the target address is written into the PC and program execution continues with the instruction at the target address. Otherwise, program execution continues with the instruction following the branch.
- 3. Operation

- o If \$rs == \$rt then \$pc <-- \$pc + { (offset7)8 ## offset7..0 }</pre>
- 4. Examples

| 0 | BEQ \$0, \$3, 6 ; If \$0 == \$3 then \$pc < \$pc + 7    |
|---|---------------------------------------------------------|
| 0 | BEQ \$2, \$0, -36 ; If \$2 == \$0 then \$pc < \$pc - 35 |
| 0 | BEQ \$0, \$2, BYE ; If \$0 == \$2 then \$pc < BYE       |
| 0 | ;The last example is the common usage.                  |
| 0 | ;Note that if a label is in the offset field in         |
| 0 | ;the assembly instruction, the assembler                |
| 0 | ;will compute the offset and insert it into             |
| 0 | ;the binary instruction. If a number is in              |
| 0 | ;the offset field, the number itself will be            |
| 0 | ; inserted into the binary instruction.                 |

#### BGZ

- 1. Assembler Format
  - BGZ \$rs, offset
- 2. Description
  - A branch target address is computed from the sum of the address of the instruction after the branch instruction and the 8-bit, sign-extended offset. The contents of \$rs and zero are compared. If the contents of \$rs are greater than zero, then the target address is written into the PC and program execution continues with the instruction at the target address. Otherwise, program execution continues with the instruction following the branch.
- 3. Operation
  - o If \$rs > 0 then \$pc <-- \$pc + { (offset7)8 ## offset7..0 }</p>
- 4. Examples

```
BGZ $3, 42 ; If $3 > 0 then $pc <-- $pc + 43
0
    BGZ $2, -3
                 ; If $2 > 0 then $pc <-- $pc - 2
0
    BGZ $0, N2 ; If $0 > 0 then $pc <-- N2
0
    ; The last example is the common usage.
0
    ;Note that if a label is in the offset field in
0
    ; the assembly instruction, the assembler
0
    ; will compute the offset and insert it into
0
    ;the binary instruction. If a number is in
0
    ; the offset field, the number itself will be
0
    ; inserted into the binary instruction.
0
```

#### BLZ

- 1. Assembler Format
  - BLZ \$rs, offset
- 2. Description
  - A branch target address is computed from the sum of the address of the instruction after the branch instruction and the 8-bit, sign-extended

offset. The contents of \$rs and zero are compared. If the contents of \$rs are less than zero, then the target address is written into the PC and program execution continues with the instruction at the target address. Otherwise, program execution continues with the instruction following the branch.

3. Operation

```
o If $rs < 0 then $pc <-- $pc + { (offset7)8 ## offset7..0 }</pre>
```

4. Examples

| 0 | BLZ \$3, 200 ; Is this valid? Why or why not?   |
|---|-------------------------------------------------|
| 0 | BLZ \$0, -17 ; If \$0 < 0 then \$pc < \$pc - 16 |
| 0 | BLZ \$3, JEFF ;If \$3 < 0 then \$pc < JEFF      |
| 0 | ;The last example is the common usage.          |
| 0 | ;Note that if a label is in the offset field in |
| 0 | ;the assembly instruction, the assembler        |
| 0 | ;will compute the offset and insert it into     |
| 0 | ;the binary instruction. If a number is in      |
| 0 | ;the offset field, the number itself will be    |
| 0 | ; inserted into the binary instruction.         |

#### JMP

- 1. Assembler Format
  - JMP target
- 2. Description
  - A target address is computed by concatenating the four high-order bits of the instruction's address with the 12-bit, unsigned target offset. The target address is written into the PC and program execution continues with the instruction at the target address.
- 3. Operation
  - o \$pc <-- \$pc15..12 ## target11..0</p>
- 4. Examples

```
o JMP LOOP ;$pc <-- LOOP
o jf four high-order bits of $pc are 0
;$pc <-- 0xc100
o jMP 0x0100 ;$pc contained 0xc68f
o JMP 0xeeff ;Is this valid? No, it's not. Why
not?
```

# JAL

- 1. Assembler Format
  - o JAL target
- 2. Description
  - The address of the next instruction is placed in \$2. A target address is computed by concatenating the four high-order bits of the instruction's address with the 12-bit, unsigned target offset. The target address is

written into the PC and program execution continues with the instruction at the target address.

3. Operation

```
o $2 <-- $pc $pc <-- $pc15..12 ## target11..0</p>
```

4. Examples

```
JAL LOOP
                   ;$2 <-- $pc ;$pc <-- LOOP
0
                  ; if four high-order bits of $pc are 0
0
    JAL 0x05b0
                   ;$2 <-- $pc ;$pc <-- 0x95b0
0
                  ; if $pc previously contained 0x91ae
0
                   ; Is this valid? No, why not?
    JAL 0xff34
0
                  ; JAL is normally used to jump to a
0
  procedure.
                  ;Why isn't JMP used instead?
0
```

### JPR

- 1. Assembler Format
  - JPR \$rs
- 2. Description
  - The contents of \$rs are written to the PC. Program execution continues with the instruction at that address.
- 3. Operation
  - \$pc <-- \$rs</p>
- 4. Examples

```
JPR $2 ;$pc <-- $2</li>
;JPR is commonly used in conjunction with JAL to
;return from procedure calls.
;JPR and JRL are the only control instructions that
;allow branching to any address in physical memory.
```

#### JRL

- 1. Assembler Format
  - JRL \$rs
- 2. Description
  - The address of the next instruction is placed in \$2. The contents of \$rs are written to the PC. Program execution continues with the instruction at that address.
- 3. Operation
  - \$2 <-- \$pc \$pc <-- \$rs
- 4. Examples

```
JRL $3 ;$2 <-- $pc ;$pc <-- $3</li>
JRL $2 ;What happens when this is executed?
;JRL is commonly used to jump to procedures that
;are out of range for a JAL instruction.
```

;JPR and JRL are the only control instructions that;allow branching to any address in physical memory.

# HLT

- 1. Assembler Format
  - ∘ HLT
- 2. Description
  - Indicates the end of a program. When executed, the machine does not fetch the next instruction.
- 3. Operation
  - The machine halts.
- 4. Examples

o HLT

#### ENI

- 1. Assembler Format
  - ∘ ENI
- 2. Description
  - If interrupts are disabled, interrupts are re-enabled. Otherwise nothing occurs.
- 3. Operation
  - $_{\odot}$  Unknown at this time.
- 4. Examples

```
o ENI
```

;Enables interrupts

# DSI

- 1. Assembler Format
  - DSI
- 2. Description
  - If interrupts are enabled, interrupts are disabled. Otherwise nothing occurs.
- 3. Operation
  - $^{\circ}$  0 Unknown at this time.
- 4. Examples

```
DSI ;Disables interrupts
```

# **Assembler Directive Descirption**

```
BSC
```

- 1. Assembler Format
  - BSC operand list
- 2. Description
  - The BSC directive reserves blocks of memory for data storage and initializes the locations in the block to the values in the commadelimited operand list (comma-delimited means the elements in a list are separated by commas.) The number of elements in the operand list determines the number of memory locations to be reserved. A label is optional but BSC is generally useless without one. The elements in the operand list can be literal numbers (in hex or decimal), symbolic names, or mathematical expressions. If the operand is a symbolic name (label), it must have been previously defined. The elements can be positive or negative.
- 3. Examples

```
o NEG2 .BSC -2 ;-2 stored at NEG2
o X .BSC 0x0005, 10, 0x000f, -5
o ;The X block has 4 words initialized
;to the values in the list
o Y .BSC X+1, X+2 ;The value X+1 is stored at Y
o ;The value X+2 is stored at Y+1
```

See the sample code for an example of how the values defined by BSS are accessed by other instructions.

# BSS

- 1. Assembler Format
  - BSS operand
- 2. Description
  - The BSS directive reserves blocks of memory for data storage. The operand indicates the number of memory locations to be reserved. The TSC Assembler initializes all locations in the block to 0x0000. A label is optional but BSS is generally useless without one. The operand can be a literal number (in hex or decimal), a symbolic name, or a mathematical expression although expressions and symbolic names usually are not useful in the context of BSS. If the operand is a symbolic name (label), it must have been previously defined. The operand must be positive.
- 3. Examples

A .BSS 10 ;The A block has 10 words
B .BSS 0x0011 ;The B block has 17 words

See the sample code for an example of how the locations reserved by BSS are accessed by other instructions.

#### END

1. Assembler Format

- END operand
- 2. Description
  - The END directive marks the physical end of the program. All code after END is discarded. All TSC programs must have an END directive. END cannot have a label because it does not translate into an instruction or reserved memory location. The operand is optional and is ignored by the assembler.
- 3. Examples

```
    .END ;Pretty simple
    .END BEGIN ;The operand indicates where the program began
```

### EQU

- 1. Assembler Format
  - o label .EQU operand
- 2. Description
  - The EQU directive assigns the operand value to the label. The value can represent a memory location or a data constant. The operand can be a literal number (in hex or decimal), a symbolic name, or a mathematical expression. If the operand is a symbolic name (label), it must have been previously defined. The value of the operand can be positive or negative. EQU is not needed to write TSC programs but is provided as a convenience to the advanced assembly programmer.
- 3. Examples

```
;EQU used to duplicate label values
0
    Х
         OR $3, $2, $0
0
         .EQU X
    Υ
                         ;Y=X
0
    ;EQU used to create constants
0
         .EQU 56
0
    А
                        ;A=56
         .EQU A+4
                         ;B=60
    В
0
         ADI $2, $2, B-A ;Add 4 to $2
0
```

# ORG

- 1. Assembler Format
  - ORG address
- 2. Description
  - The ORG directive provides the assembler with the memory address where the next instruction is to be placed. ORG is often on the first line of the program but is not required there (the TSC Assembler defaults to address zero if ORG is not found.) ORG is the means by which separate program segments are created. The address operand can be a literal number (in hex or decimal), a symbolic name, or a mathematical expression. If the operand is a symbolic name (label), it

must have been previously defined. ORG cannot have a label because it does not translate into an instruction or reserved memory location.

#### 3. Examples

```
    ORG 0x56ff ;Next instruction placed at 0x56ff
    ORG START ;Next instruction placed at the value
    ;of the label START ;Next instruction placed at START+3
```

See the sample code for an example of how ORG is used to create segments.