## **Black Widow**

(c) 2022 Robert Finch

### Introduction

The BlackWidow ISA and core is the author's attempt at a VLIW processing core. The issue width is at least three instructions wide.

# Programming Model

### Datapath

The data-path is 128 bits wide.

The primary motivation for an 128-bit data path is to support 128-bit decimal floating-point.

### Instructions

Instructions are a fixed 40-bits in size. More detail on instructions is given in the instruction set description section below.

## General Purpose Registers – GPRs

The ISA provides for 64 general purpose registers. R0 always contains the value zero. The GPRs store either integer or floating-point data. This is referred to as a *unified* register file.

### **Predicate Registers**

The ISA has 64 predicate registers P0 to P63. A predicate is specified for every instruction and the instruction will execute only if the predicate is true. Predicate zero is always false. Predicate one is always true.

### Floating-Point Format

The floating-point format is an 80-bit extended precision decimal format with the following layout:

| 79    | 78 70    | 69 0        |
|-------|----------|-------------|
| Sign  | Exponent | Significand |
| 1 bit | 9 bits   | 70 bits     |

The sign bit is zero for negative, or one for positive numbers

The exponent is a power of ten exponent represented as a binary number, the exponent range is -255 to +256. The exponent bias value is 255.

The significand is a group of seven, ten-bit densely-packed-decimal values. This provides 21 significant digits. There are no hidden bits. There is one whole digit before the decimal point.

Infinity is represented as an exponent of all ones and a zero significand.

Nans are represented as an exponent of all ones and a non-zero significand.

# Instruction Set Description

# Instruction Formats

| В | Opcode <sub>6</sub> | Fund                    | C <sub>6</sub> ~ <sub>3</sub> | Rb <sub>6</sub>      | Ra <sub>6</sub>  | Rt <sub>6</sub> | Pr <sub>6</sub> |              |
|---|---------------------|-------------------------|-------------------------------|----------------------|------------------|-----------------|-----------------|--------------|
| В | Opcode <sub>6</sub> | Immediate <sub>15</sub> |                               |                      | Ra <sub>6</sub>  | Rt <sub>6</sub> | Pr <sub>6</sub> |              |
| В | Opcode <sub>6</sub> | Op <sub>3</sub>         | Imme                          | ediate <sub>12</sub> | Ra <sub>6</sub>  | Rt <sub>6</sub> | Pr <sub>6</sub> | SETI / SETUI |
| В | Opcode <sub>6</sub> | Op₃                     | Pt2 <sub>6</sub>              | Pt1 <sub>6</sub>     | Rb <sub>6</sub>  | Ra <sub>6</sub> | Pr <sub>6</sub> | CMP          |
| В | Opcode <sub>6</sub> | Op₃                     | Pt2 <sub>6</sub>              | Pt1 <sub>6</sub>     | Imm <sub>6</sub> | Ra <sub>6</sub> | Pr <sub>6</sub> | CMPI         |
| В | Opcode <sub>6</sub> |                         |                               | Displaceme           | nt <sub>27</sub> |                 | Pr <sub>6</sub> | BRA / BSR    |
| В | Opcode <sub>6</sub> |                         |                               | Immediate            | 27               |                 | Pr <sub>6</sub> | CON1/2/3     |

# Opcode Maps

# Major Opcode<sub>6</sub>

|    | 0    | 1    | 2    | 3     | 4    | 5     | 6     | 7    |
|----|------|------|------|-------|------|-------|-------|------|
| 0x | 0    | 1    | 2    | 3     | 4    | 5     | 6     | 7    |
|    | SYS  | MOD  | {R2} | {FLT} | ADDI | SUBFI |       |      |
|    | 8    | 9    | 10   | 11    | 12   | 13    | 14    | 15   |
|    | ANDI | ORI  | XORI |       | MULI | BRA   | BSR   | BMR  |
| 1x | 16   | 17   | 18   | 19    | 20   | 21    | 22    | 23   |
|    | CMP  | CMPU | FCMP | CMP   | CMPI | CMPUI | FCMPI | CMPI |
|    | 24   | 25   | 26   | 27    | 28   | 29    | 30    | 31   |
|    | FDP  | FFDP |      |       | SETI | SETUI | FSETI |      |
| 2x | 32   | 33   | 34   | 35    | 36   | 37    | 38    | 39   |
|    | LDB  | LDBU | LDW  | LDWU  | LDT  | LDTU  | LDO   | LDOU |
|    | 40   | 41   | 42   | 43    | 44   | 45    | 46    | 47   |
|    |      |      | LDH  | LDHR  |      |       |       |      |
| 3x | 48   | 49   | 50   | 51    | 52   | 53    | 54    | 55   |
|    | STB  | STW  | STT  | STO   |      | STH   | STHC  |      |
|    | 56   | 57   | 58   | 59    | 60   | 61    | 62    | 63   |
|    |      |      | CON4 | CON5  | NOP  | CON1  | CON2  | CON3 |

# Opcode 2, Major Func<sub>6</sub>

|    | 0    | 1     | 2    | 3     | 4    | 5     | 6     | 7     |
|----|------|-------|------|-------|------|-------|-------|-------|
| 0x | 0    | 1     | 2    | 3     | 4    | 5     | 6     | 7     |
|    | SLL  | SRL   | SRA  |       | ADD  | SUB   |       |       |
|    | 8    | 9     | 10   | 11    | 12   | 13    | 14    | 15    |
|    | AND  | OR    | XOR  |       | MUL  | JMP   |       |       |
| 1x | 16   | 17    | 18   | 19    | 20   | 21    | 22    | 23    |
|    | NAND | NOR   | XNOR |       |      |       |       |       |
|    | 24   | 25    | 26   | 27    | 28   | 29    | 30    | 31    |
|    |      |       |      |       | SET  | SETU  | FSET  |       |
| 2x | 32   | 33    | 34   | 35    | 36   | 37    | 38    | 39    |
|    | LDBX | LDBUX | LDWX | LDWUX | LDTX | LDTUX | LDOX  | LDOUX |
|    | 40   | 41    | 42   | 43    | 44   | 45    | 46    | 47    |
|    |      |       | LDHX | LDHRX |      |       |       | LDCHK |
| 3x | 48   | 49    | 50   | 51    | 52   | 53    | 54    | 55    |
|    | STBX | STWX  | STTX | STOX  |      | STHX  | STHCX |       |
|    | 56   | 57    | 58   | 59    | 60   | 61    | 62    | 63    |
|    |      |       |      |       |      |       |       | REG   |

## **ALU Operations**

### ADD – Addition

### **Description:**

Add two source operands and place the result in the target register. The immediate constant is sign extended to the machine width. The operands are treated as signed two-complement numbers.

#### **Instruction Formats:**

| 39 | 38 | 33 | 32 | 27 | 26 | 24               | 23 | 18     | 17 | 12                    | 11 | 6               | 5   | 0                 |  |
|----|----|----|----|----|----|------------------|----|--------|----|-----------------------|----|-----------------|-----|-------------------|--|
| В  | 2  | 6  | 4  | 6  | ^  | 3                | R  | $Rb_6$ |    | Ra <sub>6</sub>       |    | Rt <sub>6</sub> |     | Pred <sub>6</sub> |  |
| В  | 4  | 6  |    |    | Im | 1M <sub>15</sub> | •  | •      | R  | <b>a</b> <sub>6</sub> | Rt |                 | Pro | $ed_6$            |  |

Exceptions: none

**Execution Units: All ALUs** 

### AND - Bitwise And

### **Description:**

Bitwise and two source operands and place the result in the target register. The immediate constant is sign extended to the machine width.

#### **Instruction Formats:**

| 39 | 38 | 33 | 32 | 27 | 26 | 24               | 23 | 18                    | 17 | 12                    | 11 | 6 | 5   | 0               |
|----|----|----|----|----|----|------------------|----|-----------------------|----|-----------------------|----|---|-----|-----------------|
| В  | 2  | 5  | 8  | 6  | •  | 3                | R  | <b>b</b> <sub>6</sub> | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pro | $ed_6$          |
| В  | 86 | 5  |    |    | Im | 1m <sub>15</sub> |    |                       | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pro | ed <sub>6</sub> |

Exceptions: none

**Execution Units: All ALUs** 

## CMP – Compare

### **Description:**

Compare two source operands for a specified relationship. Set Pt1 to true and Pt2 to false if the relationship is true. Otherwise set Pt1 false and Pt2 true.

### **Instruction Formats:**

| 39 | 38                                  | 33               | 32 30           | 29                                | 24               | 23 | 18               | 17 | 12               | 11 | 6               | 5 | (      | ) |
|----|-------------------------------------|------------------|-----------------|-----------------------------------|------------------|----|------------------|----|------------------|----|-----------------|---|--------|---|
| В  | Opcode <sub>6</sub> Op <sub>3</sub> |                  | Pt              | Pt2 <sub>6</sub> Pt1 <sub>6</sub> |                  |    | Rb <sub>6</sub>  |    | Ra <sub>6</sub>  |    | Pr <sub>6</sub> |   |        |   |
| В  | Opco                                | ode <sub>6</sub> | Op <sub>3</sub> | Pt                                | Pt2 <sub>6</sub> |    | Pt1 <sub>6</sub> |    | Imm <sub>6</sub> |    | Ra <sub>6</sub> |   | $Pr_6$ |   |

| Op <sub>3</sub> |    |
|-----------------|----|
| 0               | LT |
| 1               | GE |
| 2               | LE |
| 3               | GT |
| 4               | EQ |
| 5               | NE |
| 6               | ВС |
| 7               | BS |

| Opcode <sub>6</sub> |       |
|---------------------|-------|
| 16                  | CMP   |
| 17                  | CMPU  |
| 18                  | FCMP  |
|                     |       |
| 20                  | CMPI  |
| 21                  | CMPUI |
| 22                  | FCMPI |
|                     |       |

**Exceptions:** none

**Execution Units:** All ALUs

# CSR – Control and Special Register Access

### **Description:**

Read or write CSR registers.

### **Instruction Formats:**

| 39 | 35 | 34 | 30                    | 2928            | 2726  | 25 | 16                | 15 | 11                    | 10 | 6 | 5  | 0      |
|----|----|----|-----------------------|-----------------|-------|----|-------------------|----|-----------------------|----|---|----|--------|
| 2  | 5  | 1  | <b>5</b> <sub>5</sub> | Op <sub>2</sub> | $M_2$ |    | CSR <sub>10</sub> | R  | <b>a</b> <sub>5</sub> | Rt | 5 | Pr | $ed_6$ |

| Op <sub>2</sub> | Operation      |
|-----------------|----------------|
| 0               | Read CSR       |
| 1               | Write CSR      |
| 2               | Set CSR bits   |
| 3               | Clear CSR bits |

## MUL – Multiply

### **Description:**

Multiply two source operands and place the result in the target register. The immediate constant is sign extended to the machine width. The operands are treated as signed two-complement numbers. If the REG prefix is used then the high order product bits are available in the specified target register of the REG prefix.

#### **Instruction Formats:**

| 39 | 38 | 33 | 32 | 27 | 26 | 24              | 23 | 18         | 17 | 12                    | 11 | 6 | 5   | 0      |
|----|----|----|----|----|----|-----------------|----|------------|----|-----------------------|----|---|-----|--------|
| В  | 26 | ō  | 13 | 26 | •  | 3               | R  | <b>b</b> 6 | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pro | $ed_6$ |
| В  | B  |    |    |    | Im | m <sub>15</sub> |    |            | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pro | $ed_6$ |

| Op₃ | Operation Performed                                       |
|-----|-----------------------------------------------------------|
| 0   | signed multiply                                           |
| 1   | unsigned multiply                                         |
| 2   | signed by unsigned multiply                               |
| 3   |                                                           |
| 4   | (a * b) + (c * d) signed dot product, requires reg prefix |
| 5   | -((a *b) + (c * d)) negate signed dot product             |
| 6   | (a * b) – (c * d)                                         |
| 7   | -((a * b) - (c * d))                                      |

Exceptions: none

Execution Units: ALU #0 Only

# OR – Bitwise Or

### **Description:**

Bitwise or two source operands and place the result in the target register. The immediate constant is sign extended to the machine width.

### **Instruction Formats:**

|   | 39 | 38 | 33 | 32 | 27 | 26 | 24               | 23 | 18                    | 17 | 12                    | 11 | 6              | 5   | 0      |
|---|----|----|----|----|----|----|------------------|----|-----------------------|----|-----------------------|----|----------------|-----|--------|
| ſ | В  | 26 | 5  | 9  | 6  | •  | 3                | R  | <b>b</b> <sub>6</sub> | R  | <b>a</b> <sub>6</sub> | Rt | t <sub>6</sub> | Pro | $ed_6$ |
| ſ | В  | 96 |    |    |    | Im | 1m <sub>15</sub> |    |                       | R  | <b>a</b> <sub>6</sub> | Rt | t <sub>6</sub> | Pro | $ed_6$ |

Exceptions: none

**Execution Units:** All ALUs

## SLL – Shift Left Logical

### **Description:**

Shift the value in Ra to the left by the number of bits specified in the second source operand. Zeros are shifted into the least significant bits.

If the extended precision 'e' bit is set in the instruction then bits from the Ra register of the following REG instruction will be shifted into the low order bits. Bits shifted out of the high order bits will be placed in the Rt register of the following REG instruction.

### **Instruction Formats:**

| 39 | 38 | 33 | 32 | 27 | 26 | 25 | 24 | 23               | 18 | 17 | 12         | 11 | 6 | 5 | (               | ) |
|----|----|----|----|----|----|----|----|------------------|----|----|------------|----|---|---|-----------------|---|
| В  | 2  | 6  | 0  | 6  | 0  | е  | ~  | Rb               | 6  | Ra | <b>3</b> 6 | Rt | 6 |   | $Pr_6$          |   |
| В  | 2  | 6  | 0  | 6  | 1  | е  |    | Imm <sub>7</sub> |    | Ra | <b>3</b> 6 | Rt | 6 |   | Pr <sub>6</sub> |   |

Exceptions: none

**Execution Units: All ALUs** 

## SRA – Shift Right Arithmetic

### **Description:**

Shift the value in Ra to the right by the number of bits specified in the second source operand. The sign bit is preserved in the most significant bit.

### **Instruction Formats:**

| <br>39 | 38 | 33 | 32 | 27 | 26 | 25 | 24 | 23               | 18 | 17 | 12         | 11 | 6 | 5 | 0               |
|--------|----|----|----|----|----|----|----|------------------|----|----|------------|----|---|---|-----------------|
| В      | 2  | 6  | 2  | 6  | 0  | e  | 2  | Rb∈              | õ  | Ra | <b>a</b> 6 | Rt | 5 |   | Pr <sub>6</sub> |
| В      | 2  | 6  | 2  | 6  | 1  | ω  |    | Imm <sub>7</sub> |    | Ra |            | Rt | 5 |   | Pr <sub>6</sub> |

Exceptions: none

Execution Units: ALU #0 Only

## SRL – Shift Right Logical

### **Description:**

Shift the value in Ra to the right by the number of bits specified in the second source operand. Zeros are shifted into the most significant bits.

#### **Instruction Formats:**

| 39 | 38 | 33 | 32 | 27 | 26 | 25 | 24 | 23  | 18             | 17 | 12                    | 11 | 6 | 5 | 0               |
|----|----|----|----|----|----|----|----|-----|----------------|----|-----------------------|----|---|---|-----------------|
| В  | 2  | 6  | 1  | -6 | 0  | е  | 2  | R   | b <sub>6</sub> | R  | a <sub>6</sub>        | Rt | 6 |   | Pr <sub>6</sub> |
| В  | 2  | 6  | 1  | .6 | 1  | е  |    | lmm | 7              | R  | <b>a</b> <sub>6</sub> | Rt | 6 |   | Pr <sub>6</sub> |

Exceptions: none

Execution Units: ALU #0 Only

### SUBF - Subtract From

### **Description:**

Subtract source operand A from operand B and place the result in the target register.

#### **Instruction Formats:**

| 39               | - <b>∀</b> X - | 33 | 32 | 27         | 26              | 24         | 23 | 18    | 17    | 12    | 11 | 6   | 5      | 0      |
|------------------|----------------|----|----|------------|-----------------|------------|----|-------|-------|-------|----|-----|--------|--------|
| В                | 26             |    | 5  | <b>9</b> 6 | *               | <b>,</b> 3 | R  | $b_6$ | R     | $a_6$ | Rt | 6   | Pre    | $ed_6$ |
| B 5 <sub>6</sub> |                |    |    | Im         | m <sub>15</sub> |            |    | R     | $a_6$ | Rt    | .6 | Pro | $ed_6$ |        |

Exceptions: none

**Execution Units: All ALUs** 

### XOR - Bitwise Exclusive Or

### **Description:**

Bitwise exclusive or two source operands and place the result in the target register. The immediate constant is sign extended to the machine width.

#### **Instruction Formats:**

| 39                | 38 | 33 | 32 | 27 | 26               | 24         | 23 | 18                    | 17    | 12                    | 11 | 6   | 5      | 0      |
|-------------------|----|----|----|----|------------------|------------|----|-----------------------|-------|-----------------------|----|-----|--------|--------|
| В                 | 2  | 6  | 10 | 06 | ,                | <b>,</b> 3 | R  | <b>b</b> <sub>6</sub> | R     | <b>a</b> <sub>6</sub> | Rt | 6   | Pro    | $ed_6$ |
| B 10 <sub>6</sub> |    |    |    | Im | 1m <sub>15</sub> |            |    | R                     | $a_6$ | Rt                    | 6  | Pre | $ed_6$ |        |

Exceptions: none

**Execution Units: All ALUs** 

## **Program Flow Control Operations**

### BMR - Branch to Milli-code Routine

### **Description:**

Branches to the target address if the qualifying predicate is true. The target address is the sum of a displacement specified in the instruction and the current instruction pointer. The address of the next instruction is stored in register R2.

#### **Instruction Format:**

| 39 | 38 | 33 | 34 |                            | 6 | 5 | 0               |
|----|----|----|----|----------------------------|---|---|-----------------|
| В  | 15 | 6  |    | Displacement <sub>27</sub> |   | F | Pr <sub>6</sub> |

### Operation:

if (Pr)
 R2 = next IP
 IP = IP + Displacement

### BRA - Branch

### **Description:**

Branches to the target address if the qualifying predicate is true. The target address is the sum of a displacement specified in the instruction and the current instruction pointer.

### **Instruction Format:**

| 39 | 38 | 33         | 34                         | 6 | 5 | 0               |
|----|----|------------|----------------------------|---|---|-----------------|
| В  | 13 | <b>3</b> 6 | Displacement <sub>27</sub> |   | P | Pr <sub>6</sub> |

### Operation:

### BSR - Branch to Subroutine

### **Description:**

Branches to the target address if the qualifying predicate is true. The target address is the sum of a displacement specified in the instruction and the current instruction pointer. The address of the next instruction is stored in register R1.

#### **Instruction Format:**

| 39 | 38  | 33 | 34          | 6                | 5 | 0               |
|----|-----|----|-------------|------------------|---|-----------------|
| В  | 146 |    | Displacemer | nt <sub>27</sub> |   | Pr <sub>6</sub> |

### Operation:

```
if (Pr)
R1 = next IP
IP = IP + Displacement
```

### JMR – Jump to Register

### **Description:**

This instruction performs a jump to a target address specified in register Ra. The return address is stored in register Rt. This instruction may be used to return from a subroutine.

#### **Instruction Formats:**

| В | 26 | 136 | ~9 | Ra <sub>6</sub> | Rt <sub>6</sub> | Pr <sub>6</sub> |
|---|----|-----|----|-----------------|-----------------|-----------------|
|---|----|-----|----|-----------------|-----------------|-----------------|

Exceptions: none

**Execution Units: Branch** 

## NOP – No Operation

#### **Description:**

No operation is performed by this instruction.

### **Instruction Format:**

| 39 | 38 | 33 | 34  | 6 | 5 |    | 0 |
|----|----|----|-----|---|---|----|---|
| В  |    | 06 | ~27 |   |   | 06 |   |

Operation: none

Exceptions: none

**Execution Units: Branch** 

## **Memory Operations**

### LDB - Load Byte

### **Description:**

Load a byte from memory and sign extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

| 39 | 38  | 33 | 32 | 27 | 26 | 24               | 23 | 18         | 17 | 12                    | 11 | 6 | 5   | 0      |
|----|-----|----|----|----|----|------------------|----|------------|----|-----------------------|----|---|-----|--------|
| В  | 26  | 5  | 32 |    | ŕ  | 3                | R  | <b>0</b> 6 | R  | $a_6$                 | Rt | 6 | Pre | $ed_6$ |
| В  | 326 |    |    |    | Im | 1m <sub>15</sub> |    |            | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pre | $ed_6$ |

Exceptions: none

**Execution Units: All Memory** 

## LDBU - Load Unsigned Byte

#### **Description:**

Load a byte from memory and zero extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

| 39 | 38  | 33 | 32 | 27         | 26 | 24              | 23 | 18         | 17 | 12                    | 11 | 6 | 5   | 0      |
|----|-----|----|----|------------|----|-----------------|----|------------|----|-----------------------|----|---|-----|--------|
| В  | 26  |    | 33 | <b>3</b> 6 | 2  | 3               | R  | <b>0</b> 6 | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pre | $ed_6$ |
| В  | 336 |    |    |            | lm | m <sub>15</sub> |    |            | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pre | $ed_6$ |

Exceptions: none

## LDD – Load Deci

### **Description:**

Load a deci-byte value from memory and sign extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

### **Instruction Formats:**

| _3 | 9 | 38 | 33 | 32 | 27 | 26 | 24               | 23 | 18    | 17 | 12                    | 11 | 6  | 5   | 0      |
|----|---|----|----|----|----|----|------------------|----|-------|----|-----------------------|----|----|-----|--------|
| ı  | В | 2  | 6  | 42 | 26 | ,  | 3                | R  | $b_6$ | R  | $a_6$                 | Rt | -6 | Pro | $ed_6$ |
|    | В | 42 | 26 |    |    | Im | 1m <sub>15</sub> |    |       | R  | <b>a</b> <sub>6</sub> | Rt | 6  | Pro | $ed_6$ |

Exceptions: none

### LDO - Load Octa

### **Description:**

Load a octa from memory and sign extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

| 39 | 38 | 33 | 32 | 27 | 26 | 24               | 23 | 18                    | 17 | 12                    | 11 | 6 | 5   | 0      |
|----|----|----|----|----|----|------------------|----|-----------------------|----|-----------------------|----|---|-----|--------|
| В  | 26 |    | 38 | 86 | ~  | 3                | R  | <b>b</b> <sub>6</sub> | R  | $a_6$                 | Rt | 6 | Pro | $ed_6$ |
| В  |    |    |    |    | Im | 1m <sub>15</sub> | •  | •                     | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pro | $ed_6$ |

Exceptions: none

**Execution Units: All Memory** 

### LDOU - Load Octa Unsigned

### **Description:**

Load an octa from memory and zero extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

|   | 39 | 38 | 33 | 32 | 27 | 26               | 24 | 23 | 18                    | 17                    | 12                    | 11 | 6   | 5      | 0      |
|---|----|----|----|----|----|------------------|----|----|-----------------------|-----------------------|-----------------------|----|-----|--------|--------|
| ſ | В  | 26 | õ  | 39 | 96 | ^                | 3  | R  | <b>b</b> <sub>6</sub> | R                     | <b>a</b> <sub>6</sub> | Rt | 6   | Pre    | $ed_6$ |
| ſ | В  | 39 |    |    | Im | 1m <sub>15</sub> |    |    | R                     | <b>a</b> <sub>6</sub> | Rt                    | 6  | Pre | $ed_6$ |        |

Exceptions: none

**Execution Units: All Memory** 

### LDP - Load Penta

#### **Description:**

Load a penta-byte value from memory and sign extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

| 39 | 38 | 33 | 32 | 27 | 26 | 24               | 23 | 18                    | 17 | 12    | 11 | 6 | 5   | 0      |
|----|----|----|----|----|----|------------------|----|-----------------------|----|-------|----|---|-----|--------|
| В  | 2  | 6  | 40 | 06 | ^  | <b>,</b> 3       | R  | <b>b</b> <sub>6</sub> | R  | $a_6$ | Rt | 6 | Pre | $ed_6$ |
| В  |    |    |    |    | Im | 1m <sub>15</sub> |    |                       | R  | $a_6$ | Rt | 6 | Pre | $ed_6$ |

Exceptions: none

## LDPU - Load Penta Unsigned

### **Description:**

Load a penta-byte value from memory and zero extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

| 39 | 38  | 33 | 32 | 27 | 26 | 24              | 23 | 18                    | 17 | 12    | 11 | 6 | 5   | 0      |
|----|-----|----|----|----|----|-----------------|----|-----------------------|----|-------|----|---|-----|--------|
| В  | 26  | 5  | 4: | 16 | ^  | 3               | R  | <b>b</b> <sub>6</sub> | R  | $a_6$ | Rt | 6 | Pro | $ed_6$ |
| В  | 416 |    |    |    | Im | m <sub>15</sub> |    |                       | R  | $a_6$ | Rt | 6 | Pre | $ed_6$ |

Exceptions: none

**Execution Units:** All Memory

### LDT – Load Tetra

### **Description:**

Load a tetra from memory and sign extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

|   | 39 | 38  | 33 | 32 | 27 | 26 | 24               | 23 | 18                    | 17 | 12                    | 11 | 6 | 5   | 0      |
|---|----|-----|----|----|----|----|------------------|----|-----------------------|----|-----------------------|----|---|-----|--------|
| ſ | В  | 26  | 5  | 30 | 66 | ^  | 3                | R  | <b>b</b> <sub>6</sub> | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pre | $ed_6$ |
| ſ | В  | 366 |    |    |    | Im | 1m <sub>15</sub> |    | •                     | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pro | $ed_6$ |

Exceptions: none

**Execution Units: All Memory** 

## LDTU - Load Unsigned Tetra

#### **Description:**

Load a tetra from memory and zero extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

| 39 | 38  | 33 | 32 | 27 | 26 | 24               | 23 | 18                    | 17 | 12    | 11 | 6 | 5   | 0      |
|----|-----|----|----|----|----|------------------|----|-----------------------|----|-------|----|---|-----|--------|
| В  | 2   | 6  | 3  |    | ^  | <b>,</b> 3       | R  | <b>b</b> <sub>6</sub> | R  | $a_6$ | Rt | 6 | Pre | $ed_6$ |
| В  | 376 |    |    |    | Im | 1m <sub>15</sub> |    |                       | R  | $a_6$ | Rt | 6 | Pre | $ed_6$ |

Exceptions: none

### LDW - Load Wyde

### **Description:**

Load a wyde from memory and sign extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

| 39 | 38  | 33 | 32 | 27 | 26 | 24              | 23 | 18                    | 17 | 12                    | 11 | 6 | 5   | 0      |
|----|-----|----|----|----|----|-----------------|----|-----------------------|----|-----------------------|----|---|-----|--------|
| В  | 26  |    | 34 | 46 | ^  | 3               | R  | <b>b</b> <sub>6</sub> | R  | $a_6$                 | Rt | 6 | Pro | $ed_6$ |
| В  | 346 |    |    |    | Im | m <sub>15</sub> |    | •                     | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pro | $ed_6$ |

Exceptions: none

**Execution Units:** All Memory

### LDWU - Load Unsigned Wyde

### **Description:**

Load a wyde from memory and zero extend the value to the machine width. The address is either the sum of register Ra and Rb, or the sum of Ra and an immediate value.

#### **Instruction Formats:**

| 39 | 38 | 33 | 32 | 27 | 26 | 24               | 23 | 18                    | 17 | 12                    | 11 | 6 | 5   | 0               |
|----|----|----|----|----|----|------------------|----|-----------------------|----|-----------------------|----|---|-----|-----------------|
| В  | 2  | 6  | 3! | 56 | ^  | 3                | R  | <b>b</b> <sub>6</sub> | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pre | $ed_6$          |
| В  | 35 | 6  |    |    | Im | 1M <sub>15</sub> |    |                       | R  | <b>a</b> <sub>6</sub> | Rt | 6 | Pre | ed <sub>6</sub> |

Exceptions: none

**Execution Units: All Memory** 

### STB – Store Byte

#### **Description:**

Store a byte to memory from register Rs. The address is either the sum of register Ra and Rc, or the sum of Ra and an immediate value. Rc must be specified using the REG prefix.

#### **Instruction Formats:**

| _ | 39 | 38  | 33 | 32  | 27         | 26 | 24 | 23 | 18                    | 17 | 12                    | 11  | 6      | 5   | 0      |
|---|----|-----|----|-----|------------|----|----|----|-----------------------|----|-----------------------|-----|--------|-----|--------|
|   | В  | 26  | 5  | 48  | <b>8</b> 6 | 2  | 3  | Rl | <b>0</b> 6            | R  | <b>a</b> <sub>6</sub> | Rs  | 6      | Pro | $ed_6$ |
|   | В  | 486 |    | lmm |            |    |    | R  | <b>a</b> <sub>6</sub> | Rs | 6                     | Pre | $ed_6$ |     |        |

Exceptions: none

**Execution Units: Memory #0** 

## STD – Store Deci

### **Description:**

Store a deci-byte to memory from register Rs. The address is either the sum of register Ra and Rc, or the sum of Ra and an immediate value. Rc must be specified using the REG prefix.

### **Instruction Formats:**

| 39 | 38 | 33 | 32 | 27         | 26 | 24               | 23 | 18    | 17              | 12                    | 11              | 6 | 5                 | 0      |
|----|----|----|----|------------|----|------------------|----|-------|-----------------|-----------------------|-----------------|---|-------------------|--------|
| В  | 26 |    | 53 | <b>خ</b> د | ,  | 3                | R  | $b_6$ | Ra <sub>6</sub> |                       | Rs <sub>6</sub> |   | Pred <sub>6</sub> |        |
| В  | 53 |    |    |            | Im | 1m <sub>15</sub> |    |       | R               | <b>a</b> <sub>6</sub> | Rs              | 6 | Pr                | $ed_6$ |

Exceptions: none

Execution Units: Memory #0

### STO - Store Octa

### **Description:**

Store an octa to memory from register Rs. The address is either the sum of register Ra and Rc, or the sum of Ra and an immediate value. Rc must be specified using the REG prefix.

### **Instruction Formats:**

|   | 39 | 38                     | 33 | 32 | 27 | 26 | 24               | 23 | 18    | 17              | 12                    | 11              | 6 | 5                 | 0      |
|---|----|------------------------|----|----|----|----|------------------|----|-------|-----------------|-----------------------|-----------------|---|-------------------|--------|
| ſ | В  | 26                     |    | 5: | 16 | ^  | 3                | R  | $b_6$ | Ra <sub>6</sub> |                       | Rs <sub>6</sub> |   | Pred <sub>6</sub> |        |
| ſ | В  | <b>51</b> <sub>6</sub> |    |    |    | Im | 1m <sub>15</sub> | •  |       | R               | <b>a</b> <sub>6</sub> | Rs              | 6 | Pr                | $ed_6$ |

Exceptions: none

**Execution Units: Memory #0** 

### STP - Store Penta

### **Description:**

Store a penta-byte to memory from register Rs. The address is either the sum of register Ra and Rc, or the sum of Ra and an immediate value. Rc must be specified using the REG prefix.

#### **Instruction Formats:**

| 39 | 38  | 33 | 32 | 27 | 26 | 24               | 23 | 18    | 17              | 12                    | 11              | 6 | 5                 | 0      |
|----|-----|----|----|----|----|------------------|----|-------|-----------------|-----------------------|-----------------|---|-------------------|--------|
| В  | 26  |    | 57 | 26 | ŕ  | 3                | R  | $b_6$ | Ra <sub>6</sub> |                       | Rs <sub>6</sub> |   | Pred <sub>6</sub> |        |
| В  | 526 |    |    |    | Im | 1M <sub>15</sub> |    |       | R               | <b>a</b> <sub>6</sub> | Rs              | 6 | Pre               | $ed_6$ |

Exceptions: none

Execution Units: Memory #0

### STT - Store Tetra

#### **Description:**

Store a tetra to memory from register Rs. The address is either the sum of register Ra and Rc, or the sum of Ra and an immediate value. Rc must be specified using the REG prefix.

#### **Instruction Formats:**

| 39 | ≺×  | 33 | 32                 | 27 | 26 | 24 | 23         | 18              | 17 | 12              | 11  | 6                 | 5 | 0 |
|----|-----|----|--------------------|----|----|----|------------|-----------------|----|-----------------|-----|-------------------|---|---|
| В  | 26  |    | 50 <sub>6</sub> ~3 |    |    | R  | <b>b</b> 6 | Ra <sub>6</sub> |    | Rs <sub>6</sub> |     | Pred <sub>6</sub> |   |   |
| В  | 506 |    | FO Imm             |    |    |    | R          | $a_6$           | Rs | 6               | Pre | $ed_6$            |   |   |

Exceptions: none

**Execution Units:** Memory #0

## STW – Store Wyde

### **Description:**

Store a wyde to memory from register Rs. The address is either the sum of register Ra and Rc, or the sum of Ra and an immediate value. Rc must be specified using the REG prefix.

### **Instruction Formats:**

|   | 39 | 38  | 33 | 32                 | 27    | 26 | 24 | 23 | 18    | 17              | 12                    | 11              | 6 | 5                 | 0      |
|---|----|-----|----|--------------------|-------|----|----|----|-------|-----------------|-----------------------|-----------------|---|-------------------|--------|
| ſ | В  | 26  |    | 49 <sub>6</sub> ~3 |       |    |    | R  | $b_6$ | Ra <sub>6</sub> |                       | Rs <sub>6</sub> |   | Pred <sub>6</sub> |        |
|   | В  | 496 |    |                    | lmm₁5 |    |    |    |       | R               | <b>a</b> <sub>6</sub> | Rs              | 6 | Pr                | $ed_6$ |

Exceptions: none

**Execution Units:** Memory #0

## **Special Operations**

# CARRY – Carry Modifier

#### **Description:**

This instruction indicates where there are carries into and out of following instructions for up to eight instructions.

#### **Instruction Formats:**

| 25 | <b>30</b> <sub>5</sub> | ~ <sub>3</sub> IO <sub>7</sub> | 106 | 105 | IO <sub>4</sub> | IO <sub>3</sub> | IO <sub>2</sub> | IO <sub>1</sub> | IO <sub>0</sub> | Rt <sub>5</sub> | Pred <sub>6</sub> | 1 |
|----|------------------------|--------------------------------|-----|-----|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------|---|
|----|------------------------|--------------------------------|-----|-----|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------|---|

| 10 |                        |
|----|------------------------|
| 0  | no carries             |
| 1  | input carry            |
| 2  | output carry           |
| 3  | input and output carry |

Exceptions: none

**Execution Units: All ALUs** 

### CON - Constant Prefix

### **Description:**

Add constant bits to the following instruction. Constants are extended from bit six of the constant. There may be multiple constant prefixes present to extend the constant up to 80 bits.

The compare instruction has only a six-bit immediate field. So that the constant prefix may be used with the compare instruction it extends from bit six. The constant prefix is simplified by fixing which bit it extends from. It would be too much hardware for the value to vary which bit is extended according to the instruction.

Since constants are never executed the predicate for them is always zero.

Breaks should not be inserted in the middle of constants for proper operation.

### **Instruction Formats:**

| 39 | 38  | 33 | 34                           | 6 | 5 | 0  |
|----|-----|----|------------------------------|---|---|----|
| В  | 616 |    | Immediate <sub>326</sub>     |   |   | 06 |
| В  | 626 |    | Immediate <sub>5933</sub>    |   |   | 06 |
| В  | 636 |    | ~8 Immediate <sub>7960</sub> |   |   | 06 |

Exceptions: none

**Execution Units:** All Decoders

# REG – Fetch Registers

### **Description:**

This instruction fetches two more operands to be used in the following instruction and provides an additional target register. This instruction is used for indexed stores, multiply and add and fused dot product instructions.

### **Instruction Format:**

| 39 | - <b>≺</b> × - | 33 | 32                 | 27 | 26 | 24 | 23              | 18 | 17                    | 12 | 11              | 6   | 5               | 0 |
|----|----------------|----|--------------------|----|----|----|-----------------|----|-----------------------|----|-----------------|-----|-----------------|---|
| В  | 4 1 /.         |    | 63 <sub>6</sub> ~3 |    |    | R  | Rb <sub>6</sub> |    | Ra <sub>6</sub>       |    | Rt <sub>6</sub> |     | ed <sub>6</sub> |   |
| В  | 636            |    |                    |    |    | •  |                 | R  | <b>a</b> <sub>6</sub> | Rt | 6               | Pro | $ed_6$          |   |