FT64v8c

## Rational

Why yet another architecture? Depending on a single architecture increases the odds that if something goes amiss with it, everyone is affected. Nature does not have a single architecture.

## The Beauty of ISA’s

Some of the best ISA’s aren’t very attractive, they have all kinds of features that the novice user asks: why did they do that? The ISA’s are not very attractive because they are functional and serve a purpose for which they were engineered.

## Separation of Register Sets

One of the things the 68k architecture does right is separate data and address calculations. Address calculations don’t require the same number and variability of operations as data calculations. Many modern processors have explicit address generation units separate from the data calculation ALU. FT64 takes this one step further and separates code and data addresses. Many modern processors contain branch calculation units, or flow control units. It appears to the author that the register set depends on the functional unit although it doesn’t have to. Floating point units often come with their own register set.

The PowerPC has several features that the author likes. One of the things the PowerPC architecture gets right is the provision for multiple condition code registers. A second feature the of PowerPC is indexed addressing.

Separating out sets of registers specific to functional units may make it possible to get away with fewer register ports, in particular register write ports, which tend to be expensive.

## Addressing Modes

The problem with indexed addressing is that when it’s needed it’s needed. Sure, it can be emulated using several simpler instructions and additional registers, but why not just include it directly in the ISA? There are code density benefits to supporting indexed addressing, if not clock cycle benefits. The base addressing mode supported by FT64 is indexed with displacement addressing mode. Other modes can be emulated as a subset of that mode.

## Compressed Instruction Sets

Compressed instruction sets are in the author’s view a kludge to increase code density. What’s really needed are variable instruction lengths. Part of the appeal of a compressed instruction set is that it makes the calculation of the instruction length simple. When active, compressed instructions are usually a fixed length. FT64v8 will have variable instruction lengths and the length of the instruction will be determined by the first byte of the instruction.

# Programming Model

# Registers

One thing that seems to be clear in modern computers is that memory is much slower than the cpu. This means that caching of values becomes extremely important. Machine registers are the level zero cache for values from memory. Having adequate types and numbers of registers is important.

## Data Registers (D0 to D31)

|  |  |  |
| --- | --- | --- |
| Xn6 |  |  |
| 0 | always zero |  |
| 1 | return value |  |
| 2 |  |  |
| 3 |  |  |
| 4 |  |  |
| 5 |  |  |
| 6 |  |  |
| 7 |  |  |
| 8 |  |  |
| 9 |  |  |
| 10 |  |  |
| 11 |  |  |
| 12 |  |  |
| 13 |  |  |
| 14 |  |  |
| 15 |  |  |
| 16 |  |  |
| 17 |  |  |
| 18 |  |  |
| 19 |  |  |
| 20 |  |  |
| 21 |  |  |
| 22 |  |  |
| 23 |  |  |
| 24 |  |  |
| 25 |  |  |
| 26 |  |  |
| 27 |  |  |
| 28 |  |  |
| 29 |  |  |
| 30 |  |  |
| 31 |  |  |

## Address Registers (A0 to A15)

Data address registers are used to locate data as opposed to instructions. The stack pointer is banked with a separate register for each operating level.

|  |  |  |  |
| --- | --- | --- | --- |
| Xn6 | Reg | 63 0 |  |
| 32 | A0 | always zero |  |
| 33 | A1 | return value |  |
| 34 | A2 |  |  |
| 35 | A3 |  |  |
| 36 | A4 |  |  |
| 37 | A5 |  |  |
| 38 | A6 |  |  |
| 39 | A7 |  |  |
| 40 | A8 |  |  |
| 41 | A9 |  |  |
| 42 | A10 |  |  |
| 43 | A11 |  |  |
| 44 | A12 |  |  |
| 45 | A13 |  |  |
| 46 | A14 | Frame Pointer |  |
| 47 | A15 | Stack Pointer |  |

|  |  |  |  |
| --- | --- | --- | --- |
| 48 | RA | leaf return address |  |
| 49 | RA |  |  |
| 50 |  |  |  |
| 51 |  |  |  |
| 52 |  |  |  |
| 53 | CL | catch link |  |
| 54 | XP | exceptioned program counter |  |
| 55 | PC | Program Counter |  |
|  |  |  |  |
| 56 | A15 | Supervisor stack pointer |  |
| 57 | A15 | Hypervisor stack pointer |  |
| 58 | A15 | Machine stack pointer |  |

## Code Address Registers (CA0 to CA7)

The processor contains eight code address registers (CA0-CA7). Several of the registers are reserved for predefined purposes. A code address register is used in the formation and storage of code addresses. Code address registers may hold branch targets.

|  |  |  |  |
| --- | --- | --- | --- |
| Xn6 | Reg |  | Usage |
| 48 | RA |  | Subroutine return address |
| 49 | RA1 |  |  |
| 50 | LC |  |  |
| 51 | LC |  |  |
| 52 |  |  |  |
| 53 | CL | Catch Link Register | Used by the compiler to link to try/catch handlers. |
| 54 | XP | Exceptioned PC | This register is automatically set during a hardware interrupt or exception |
| 55 | PC | Program Counter | Relative address formation. |

Code address registers may be used to point to a block of code from which the JSR instruction can index into with its 24-bit offset. For instance, a register may contain a pointer to a class method jump list; the JSR instruction can then index into this list in order to invoke a method.

The presence of multiple code address registers allows multi-level return addresses to be used for performance. Leaf routines may use CA0 as the return address. Next to leaf routines may use CA1, etc. So that memory operations are avoided when implementing subroutine call and return.

The program counter register is read-only. The program counter cannot be modified by moving a value to this register.

## Program Counter (CA7)

|  |  |
| --- | --- |
| 63 40 | 39 0 |
| Program Bank | Program Counter |

The program counter is special in that it is always incrementing by the size of the instructions fetched as a program runs. Program code is byte aligned. To improve performance only the low order 40 bits of the program counter increment. The entire program counter may be loaded with a jump instruction. If the upper six bits of the program counter/ bank are all ones, then segmentation with the code segment is ignored.

## Condition Code (CC0 to CC7)

There are eight condition code registers. Each condition code register contains eight flags.

|  |  |
| --- | --- |
| Reg |  |
| CC0 |  |
| CC1 |  |
| CC2 |  |
| CC3 |  |
| CC4 |  |
| CC5 |  |
| CC6 |  |
| CC7 |  |

Each condition code register has the following organization:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| U | ~ | P | O | C | V | N | Z |

|  |  |  |
| --- | --- | --- |
| Bit | Flag | Meaning |
| 0 | Z | zero |
| 1 | N | negative |
| 2 | V | overflow |
| 3 | C | carry |
| 4 | O | odd |
| 5 | P | parity |
| 6 |  | reserved |
| 7 | U | unordered |

## Segment Registers (ZS, DS, ES, FS, GS, HS, SS, CS)

Segment selector registers are 24-selectors into either the global or local segment descriptor tables. Loading a selector register triggers a load of the segment descriptor information into a hidden descriptor cache.

|  |  |  |
| --- | --- | --- |
| Sn4 | Mne. | Description |
| 0 | ZS |  |
| 1 | DS | data selector |
| 2 | ES |  |
| 3 | FS |  |
| 4 | GS |  |
| 5 | HS |  |
| 6 | SS | stack selector |
| 7 | CS | code selector |
| 8 | XS | exception selector |
| 9 | RS | return code selector |
| 10 | TR | thread selector (thread register) |
| 11 | LDT | local descriptor table selector |

|  |  |  |
| --- | --- | --- |
|  | GDT | global descriptor table pointer |
|  | IDT | interrupt descriptor table pointer |

## Control and Status Registers

### CORENUM (0x001)

This register contains a number that is externally supplied on the corenum\_i input bus to represent the hardware thread id or the core number. No core should have the value zero as the corenum.

### TICK (0x002)

This register contains a tick count of the number of clock cycles that have passed since the last reset. Note that this register should not be used for precise timing as the processor’s clock frequency may vary for performance and power reasons. The TIME CSR may be used for wall-clock timing as it has its own timing source.

### BADADDR (CSR 0x007)

This register contains the effective address for a load / store operation that caused a memory management exception or a bus error. Note that the address of the instruction causing the exception is available in the XP register.

### OL\_STACK (0x041)

This register contains the operating, data level stack and interrupt mask stack. When an exception or interrupt occurs, this register is shifted to the left and zeros are inserted in the low order bits, when an RTI instruction is executed this register is shifted to the right restoring the current operating level. On RTI the last stack entry is set to zero which will select the machine operating level on stack underflow. The low order 32 bits of the register implement the operating and data level stack. The low order 16 bits are the code/stack operating level, the next 16 bits are the data operating level. The upper 32 bits implement the interrupt level stack.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABQAAAALQCAMAAAGPpB3yAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAHIUExURf///+/v75+fn3BwcEBAQHh4eM/Pz7+/v39/f9fX1/f395eXl9/f36enp4+Pj0hISFhYWIeHh+fn5wAAADg4OBgYGAgICLe3tzAwMK+vr1BQUCgoKBAQECAgIMfHx2hoaGBgYObm5vX19eLi4m1tbREREQYGBj8/P9DQ0MPDwwsLC+rq6p2dnTo6OmJiYjIyMvv7+01NTcnJyaKiori4uB4eHt7e3i0tLXJycr29vYiIiEdHR9TU1DMzM1lZWWZmZmtra2FhYa2trZKSksHBwYyMjF1dXXl5eezs7Nvb27q6ukxMTFRUVO3y+ejt+LnK6aG44Yun26e843+e15aw3meNz1B7yFyEzNzk9HOW00RyxK3B5dDc8Hma1b7O6mGIzUp2xioqKsjIyLKysuHh4czMzE1soS9SjzRYlOft90x4x+nu+FqDy77O63t7e9PT02mO0PH0++zx+Xyd1kh1xdfh85ix3jJWltPe8bfJ6PDz+vz9/jlblTBTkFpaWouLi3Nzc29vb9Tf8vn7/czZ7+3x+Zu04IKg19/n9XaY1IWj2fX3/FZ/yvP2+5y14JCs3G2R0TliqcrX7rPF59bg8uLp9sTT7AAAAI5t37oAAACYdFJOU/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////8AxWnMuQAAAAlwSFlzAAAOwwAADsMBx2+oZAAAY9ZJREFUeF7tvb2P47iy/y0FigxHjBUq/0UKWjCUG0pmMJgz8EFjI98BLqaBDQwsDnCjxvbu2TsPGmewu/fvfeqNEiXRttptd/vl+5lpSyKLRYoqlSiJIhMAzoHMyaK+Wy9ly9E2/7qFhJ8NXEwum6wkSa4bZ0GlCyvPUgq2PKPygdsiteWALcFvDZ0WfMKUKZen4WLNeUERFHwmZQTgXKFzhc8fubqkc/49M6hkaeLShq+AMwsD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)

### PL\_STACK (0x042)

This register contains the privilege level stack. When an exception or interrupt occurs, this register is shifted to the left and zeros loaded into the low order bits, when an RTI instruction is executed this register is shifted to the right. On RTI the last stack entry will be set to zero which will select privilege level zero on stack underflow.

### XPC (0x048 to 0x4F)

This sets of registers contains the interrupt or exception stack of the program counter register. The top of the stack is register 0x48. When an interrupt or exception occurs register 0x48 to 0x4E are copied to the next register and the program counter is placed into register 0x48. When an RTI instruction is executed the program counter is loaded from register 0x048 and registers 0x048 to 0x047 are loaded with the next register. Register 0x04F is loaded with the address of the break handler so that in the event of an underflow the break handler will be executed.

### XS (0x050 to 0x052)

This set of registers contains the interrupt or exception stack of code segment selectors. The top of stack is register 0x050 bits 0 to 23. This set of registers is treated as a single unit. When an interrupt or exception occurs the registers are shifted left by 24 bits. When an RTI instruction is executed this set of registers is shifted right 24 bits.

# Segmentation

## Overview

Segmentation is a low overhead means of memory protection and virtualization. Providing separate protected address spaces for different applications is the job of the operating system. Ideally segmentation hardware should not be visible to the application. The application should appear as though it has a flat memory model. The core contains eight segment registers. The segmentation system is managed via a combination of hardware and software. Up to 256 privilege levels are available.

## Privilege levels

Memory access is available according to privilege levels. The segmentation system allows up to 256 privilege levels.

## Usage

The segment register to use during address formation is identified by a three-bit field in the address. For code addresses segment register #7 (the CS) is always used.

* If segmentation is not desired then segmentation can effectively be ignored by setting all the segment registers to zero. The processor can also be built without segmentation by commenting out the ‘SEGMENTATION’ definition.

## Software Support

Segmentation is software supported. A software implementation allows a high degree of flexibility when implementing the segmentation model. Loading a value into a selector register causes a software segmentation exception to occur. The exception routine then loads the segment base, limit and access rights from a table in memory. It’s up to the system level software to determine if protection rules are violated.

Segment registers may only be transferred to or from one of the general-purpose registers. The [CSRRW](#_MTSPR_–Register-Special_Register) instruction can be used to perform the move. After loading a segment register the instruction stream should be synchronized with a memory barrier ([MEMSB](#_MEMSB_–_Memory)) to ensure the segment value can be ready for a following memory operation.

There are two cause codes in the cause table reserved for implementing far subroutine call and return instructions.

## Address Formation:

Address bits 0 to 5 pass through unchanged. Address bits 63 to 6 are added to the contents of the segment register to form the final segmented address. Note that there is a shift of six bits for the segment base address.

|  |  |  |
| --- | --- | --- |
| 0 | Address[63:6] | Address[5:0] |
| + | + | + |
| Segment register value[95:0] | | 0 |
| = | | |
| Segmented address[101:0] | | |

## Selecting a segment register

A specific segment register for a memory operation may be selected using a segment prefix in assembler code. Segment prefixes apply to data addresses only. Code addresses always use segment register #7 – the code segment. The segment prefix indicator is encoded by a three-bit field in the instruction.

## Selectors

The core uses selectors as a more compact way to represent segment registers. Rather than pass the entire segment descriptor to routines (256 bits) and have each routine check for privilege violations, the core uses 24-bit selectors. Privilege violations are checked for at the time the segment register components (base, limit and access rights) are loaded. The selector includes a field identifying the privilege level, and a second field identifying which segment descriptor the selector is associated with. The selector format is shown below.

### Selector Format

|  |  |  |
| --- | --- | --- |
| 23 16 | 15 | 14 0 |
| PL8 | T | Index15 |

PL8: the privilege level associated with the segment

Index23: the index into the descriptor table

T: 0 = global, 1 = local descriptor table

## Non-Segmented Code Area

The address range defined as 64’hFFxxxxxxxxxxxxxx (the top byte is ‘FF’) is a non-segmented code area. This area allows the operating system to work without paying attention to the code segment. Interrupt and exception vectors should vector into the non-segmented code area. The only way to change the code segment is by transferring to the operating system via a sys call instruction.

## Changing the Code Segment

The only way to change the code segment is by transferring to the operating system via a sys call instruction. The operating system, while operating in the non-segmented code area, can alter the code segment without causing a transfer of control. The operating system establishes the code segment for a thread while running in the non-segmented code area. To support far subroutine calls and returns there are vectors in the vector table that allow implementation of a far call or return.

## The Descriptor Table

The descriptor table is a table that contains information on the location and size for segments in the form of memory descriptors. Each descriptor is 32 bytes in size. Memory descriptor entries in the table have the following format:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
|  | 255 244 | 243 192 | | 191 128 | 127 64 | 63 0 |
| w0 | ACR16 | ~32 | Base16 | Upper bound64 | Lower bound64 | Base64 |
| w1 | ACR16 | ~32 | Base16 | Upper bound64 | Lower bound64 | Base64 |
| … |  |  |  |  |  |  |

The descriptor table may contain other types of descriptors beyond basic memory descriptors, such as call gates.

The base address of, and the number of entries in the descriptor table is contained in the LDT or GDT special purpose registers. The descriptor table may be updated with regular load and store instructions when the processor is at privilege level zero.

24-bit selectors are used to index into the table in order to determine the characteristics of the segment.

#### Memory Descriptors

Memory descriptors describe the location and size of memory segments. They have the following format:

|  |  |  |  |
| --- | --- | --- | --- |
| n+3 | ACR16 | ~32 | Base79..64 |
| n+2 | Upper Bound63..0 | | |
| n+1 | Lower Bound63..0 | | |
| n | Base63..0 | | |

#### The Access Rights Field (ACR16) – Memory Descriptor

|  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 15 |  |  | 12 | 11 | 10 | 9 | 8 | 7 |  |  | 0 |
| P | ~ | ~ | 1/S | Ex | C/Stk | W/R | A | DPL8 | | | |

P: 1 = segment present, 0 = segment not present

S: 0 = system descriptor, 1 = memory descriptor

EX: 1 = executable, 0 = data

Code Segment Data Segment

C: 1= conforming Stk: 1=stack segment

R: 1 = readable W: 1=writeable

A: 1= accessed

DPL8 = descriptor privilege level

#### Typical Values for ACR

9A00 – executable, readable code segment, privilege level zero

9200 – read/writeable data segment, privilege level zero

9600 – read / writeable stack segment, privilege level zero

### System Segment Descriptors

System descriptors are identified by having bit 12 of the access rights character set to zero. There are potentially sixteen different system descriptor types.

#### The Access Rights Field (ACR16) – System Descriptor

|  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 15 |  |  | 12 | 11 | 10 | 9 | 8 | 7 |  |  | 0 |
| P | ~ | ~ | 0 | Type4 | | | | DPL8 | | | |

|  |  |  |
| --- | --- | --- |
| Type4 | Gate |  |
| 0 | unused |  |
| 2 | LDT descriptor |  |
| 4 | Call gate |  |
| 5 | Thread Gate |  |
| 6 | Interrupt Gate |  |
| 7 | Trap gate |  |

#### LDT Descriptor

The LDT descriptor establishes the location and size of the local descriptor table in memory.

|  |  |  |  |
| --- | --- | --- | --- |
| n+3 | ACR16 | ~48 | |
| n+2 | ~64 | | |
| n+1 | ~57 | | Pages6..0 |
| n | Base76..13 | | |

#### Call Gate Descriptor

|  |  |  |  |
| --- | --- | --- | --- |
| ACR16 | ~48 | | |
| ~64 | | | |
| ~35 | | N5 | Selector23..0 |
| Base63..0 | | | |

## Segment Load Exception

Moving a value to a selector register triggers a segment load exception in order to allow the segment descriptor to be loaded from one of the descriptor tables. This exception is triggered for a CSRRW instruction. There is a separate exception vector (vectors #232 to 239) to handle each segment register. The selector value being loaded into the segment register is reflected in the ARG1 special purpose register.

## Segment Bounds Exception

If an address is greater than the bound specified in the segment upper bound register or less than the address specified in the segment lower bound register then a segment bounds exception occurs. This applies for all segments including code and data segments.

## Segment Usage Conventions

Segment register #7 is the code segment (CS) register. All program counter addresses are formed with the code segment register unless the upper byte of the address is ‘FF’ in which case the code segment is ignored.

Segment register #6 is the stack segment (SS) register by convention. Future versions of the core may use this register implicitly for stack accesses. The assembler automatically selects the stack segment when one of the stack pointer registers is specified in the instruction. Segment register #1 is the data segment (DS) by convention. The data segment is selected as the segment register for memory operations when the stack segment is not selected.

## Gateway Table

The gateway table contains call, interrupt, and thread gate descriptors. The descriptors in this table are a different format than the memory descriptor table. The first 512 table entries are reserved for interrupts and exceptions.

#### Call Gate Descriptor

|  |  |  |  |
| --- | --- | --- | --- |
| ACR16 | ~19 | N5 | Selector23..0 |
| Offset63..0 | | | |

## Power-up State

On reset the value in the segment registers are undefined. Note that the processor begins executing instructions out of the non-segmented code area as the reset address is 64’hFFFFFFFFFFFC0100. One of the first tasks of the boot program would be to initialize the segment registers to known values. The segment register must be setup to perform data accesses properly.

### Segment Registers

|  |  |  |  |
| --- | --- | --- | --- |
| Num |  | Long name | Comment |
| 0 | ZS | zero (NULL) segment | by convention contains zero |
| 1 | DS | data segment | by convention – default for loads/stores |
| 2 | ES | extra segment | by convention |
| 3 | FS |  |  |
| 4 | GS |  |  |
| 5 | HS |  |  |
| 6 | SS | Stack segment | default for stack load/stores |
| 7 | CS | Code segment | always used for code addressing |

# Instruction Set Description

## ADD - Add

**Description**:

Add two values and store the result in a data register. The first operand must be in a data register. The second operand may be in a data register or an immediate value supplied in the instruction.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| 0 | Db5 | Da5 | Dt5 | 24h8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 31 18 | 17 13 | 12 8 | 7 0 |
| Immediate14 | Da5 | Dt5 | 04h8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 47 18 | 17 13 | 12 8 | 7 0 |
| Immediate30 | Da5 | Dt5 | 14h8 |

## ADDA – Add to Address

**Description**:

Add to an address register.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| 1 | Db5 | Aa5 | At5 | 24h8 |

**Instruction Format**:

|  |  |  |
| --- | --- | --- |
| 16 13 | 12 8 | 7 0 |
| Immed3 | At5 |  |

|  |  |  |
| --- | --- | --- |
| 23 13 | 12 8 | 7 0 |
| Immediate11 | At5 |  |

|  |  |  |  |
| --- | --- | --- | --- |
| 47 18 | 17 13 | 12 8 | 7 0 |
| Immediate30 | Aa5 | At5 | 44h8 |

## AND – Bitwise And

**Description**:

And two values and store the result in a data register. The first operand must be in a data register. The second operand may be in a data register or an immediate value supplied in the instruction.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| 0 | Db5 | Da5 | Dt5 | 28h8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 31 18 | 17 13 | 12 8 | 7 0 |
| Immediate14 | Da5 | Dt5 | 08h8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 47 18 | 17 13 | 12 8 | 7 0 |
| Immediate30 | Da5 | Dt5 | 18h8 |

## ANDA – Bitwise And to Address

**Description**:

And two values and store the result in a data register. The first operand must be in a data register. The second operand may be in a data register or an immediate value supplied in the instruction.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| 1 | Db5 | Aa5 | At5 | 28h8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 31 18 | 17 13 | 12 8 | 7 0 |
| Immediate14 | Da5 | Dt5 | h8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 47 18 | 17 13 | 12 8 | 7 0 |
| Immediate30 | Aa5 | At5 | 48h8 |

## BEQ – Branch if Equal

**Description**:

Branch if the condition code register indicates equality.

**Target Address Calculation**:

The lower 12 bits of the target address come from the offset field in the instruction. The middle 20 bits of the target address come from the sum of sign extended displacement field of the instruction shifted left by 12 bits and the code address register bits 12 to 31. The upper 32 bits of the target address come from the upper 32 bits of the code address register.

The program counter register may be used in the calculation.

**Instruction Format (DPO)**:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 29 | 28 24 | 23 12 | 11 | 10 8 | 7 0 |
| CA3 | Disp5 | Offset12 | ~ | CC3 | 36h8 |

## BIT – Bit Test

**Description**:

Test if a bit is set and store result in a condition code register. The zero flag of the condition register is updated with the value of the bit (zf = 1 means bit is clear). The negative, parity, and odd flags are set according to the value in the register.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 18 | 17 13 | 1211 | 10 8 | 7 0 |
| Bn6 | Da5 | 02 | CC3 | 07h8 |

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 18 | 17 13 | 1211 | 10 8 | 7 0 |
| Bn6 | Aa5 | 12 | CC3 | 07h8 |

## BNE – Branch if Not Equal

**Description**:

Branch if the condition code register indicates inequality.

**Target Address Calculation**:

The lower 12 bits of the target address come from the offset field in the instruction. The middle 20 bits of the target address come from the sum of sign extended displacement field of the instruction shifted left by 12 bits and the code address register bits 12 to 31. The upper 32 bits of the target address come from the upper 32 bits of the code address register.

**Instruction Format (DPO)**:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 29 | 28 24 | 23 12 | 11 | 10 8 | 7 0 |
| CA3 | Disp5 | Offset12 | ~ | CC3 | 37h8 |

## BOD – Branch if Odd

**Description**:

Branch if the condition code register indicates odd.

**Target Address Calculation**:

The lower 12 bits of the target address come from the offset field in the instruction. The middle 20 bits of the target address come from the sum of sign extended displacement field of the instruction shifted left by 12 bits and the code address register bits 12 to 31. The upper 32 bits of the target address come from the upper 32 bits of the code address register.

The program counter register may be used in the calculation.

**Instruction Format (DPO)**:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 29 | 28 24 | 23 12 | 11 | 10 8 | 7 0 |
| CA3 | Disp5 | Offset12 | ~ | CC3 | 36h8 |

## BRA – Branch Always

**Description**:

Unconditionally branch.

**Target Address Calculation**:

The lower 12 bits of the target address come from the offset field in the instruction. The middle 20 bits of the target address come from the sum of sign extended displacement field of the instruction shifted left by 12 bits and the code address register bits 12 to 31. The upper 32 bits of the target address come from the upper 32 bits of the code address register.

**Instruction Format (DPO)**:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 29 | 28 24 | 23 12 | 11 | 10 8 | 7 0 |
| CA3 | Disp5 | Offset12 | ~ | ~3 | 40h8 |

## CMP - Compare

**Description**:

Compare two values and store the relationship result in a condition code register.

**Instruction Format**:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 1211 | 10 8 | 7 0 |
| ~ | Db5 | Da5 | 02 | CC3 | 23h8 |

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 31 18 | 17 13 | 1211 | 10 8 | 7 0 |
| Immediate14 | Da5 | 0 | CC3 | 03h8 |

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 47 18 | 17 13 | 1211 | 10 8 | 7 0 |
| Immediate30 | Da5 | 0 | CC3 | 13h8 |

## CMPA – Compare Addresses

**Description**:

Compare two address values.

**Instruction Format**:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 1211 | 10 8 | 7 0 |
| ~ | Ab5 | Aa5 | 12 | CC3 | 23h8 |

**Instruction Format**:

This format compares a data and an address register.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 1211 | 10 8 | 7 0 |
| ~ | Db5 | Aa5 | 22 | CC3 | 23h8 |

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 31 18 | 17 13 | 1211 | 10 8 | 7 0 |
| Immediate14 | Aa5 | 12 | CC3 | 03h8 |

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 47 18 | 17 13 | 1211 | 10 8 | 7 0 |
| Immediate30 | Aa5 | 12 | CC3 | 13h8 |

LW – Load word

Description:

Instruction Format:

|  |  |  |  |
| --- | --- | --- | --- |
| 15 13 | 12 8 | 7 0 |  |
| Disp3 | Dt5 |  | LDW Dt,d[SP] |

|  |  |  |  |
| --- | --- | --- | --- |
| 15 13 | 12 8 | 7 0 |  |
| Disp3 | Dt5 |  | LDW Dt,d[FP] |

|  |  |  |  |
| --- | --- | --- | --- |
| 15 12 | 11 8 | 7 0 |  |
| Disp4 | At4 |  | LA At,d[SP] |

|  |  |  |  |
| --- | --- | --- | --- |
| 15 12 | 11 8 | 7 0 |  |
| Disp4 | At4 |  | LA At,d[FP] |

|  |  |  |  |
| --- | --- | --- | --- |
| 23 13 | 12 8 | 7 0 |  |
| Disp11 | Dt5 |  | LDW Dt,d[SP] |

|  |  |  |  |
| --- | --- | --- | --- |
| 23 13 | 12 8 | 7 0 |  |
| Disp11 | Dt5 |  | LDW Dt,d[FP] |

|  |  |  |  |
| --- | --- | --- | --- |
| 23 12 | 11 8 | 7 0 |  |
| Disp12 | At4 |  | LA At,d[SP] |

|  |  |  |  |
| --- | --- | --- | --- |
| 23 12 | 11 8 | 7 0 |  |
| Disp12 | At4 |  | LA At,d[FP] |

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 20 | 19 17 | 16 13 | 12 8 | 7 0 |  |
| Disp12 | Seg3 | Aa4 | Dt5 |  | LDW Dt,d[An] |

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 31 20 | 19 17 | 16 13 | 12 | 11 8 | 7 0 |  |
| Disp12 | Seg3 | Aa4 | ~ | At4 |  | LW At,d[An] |

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 31 26 | 25 | 24 20 | 19 17 | 16 13 | 12 8 | 7 0 |  |
| Offset6 | AD | Xn5 | Seg3 | Aa4 | Dt5 |  | LW Dt,o[An+Xn] |

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 31 26 | 25 | 24 20 | 19 17 | 16 13 | 12 | 11 8 | 7 0 |  |
| Offset6 | AD | Xn5 | Seg3 | Aa4 | ~ | At4 |  | LW At,o[An+Xn] |

## JMP – Jump to Address

**Description**:

The program counter is loaded with the target address specified in the instruction. The code segment is set to the specified segment.

**Instruction Format**:

|  |  |  |
| --- | --- | --- |
| 47 32 | 11 8 | 7 0 |
| Address36 | Sn4 | 11h8 |

**Operation**:

PC[35..0] = Address

CS = Sn

## JSR – Jump to Subroutine

**Description**:

The current program counter and code segment are copied to the return address and return code segment registers. The program counter is loaded with the target address specified in the instruction. The code segment is set to the segment specified in the instruction.

**Instruction Format**:

|  |  |  |
| --- | --- | --- |
| 47 12 | 11 8 | 7 0 |
| Address36 | Sn4 | 20h8 |

**Operation**:

RS:RA = CS:PC

PC[35..0] = Address

CS = Sn

## LB – Load Byte (8 bits)

**Description**:

Loads a byte (8-bit) value into a data register using indexed addressing. The primary instruction format is one of indexed addressing plus displacement. Four registers are summed in order to calculate the linear address. An address register, an index register, a displacement from the instruction and a segment base register.

Bytes may be loaded only into data registers.

**Instruction Format**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 47 32 | 31 29 | 2826 | 25 20 | 19 14 | 13 8 | 7 0 |
| Displacement16 | Sn3 | Sc3 | Xb6 | Xa6 | Xt6 | 80h8 |

## LGDT – Load Global Descriptor Table

**Description**:

Loads the global descriptor table pointer from a record in memory.

**Instruction Format**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 47 32 | 31 29 | 28 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| Displacement16 | Sn3 | Sc3 | Xb6 | Xa6 | 06 |  |

**Memory Layout**:

|  |  |  |  |
| --- | --- | --- | --- |
| n | Table Address63..0 | | |
| n+8 | Table Length19..0 | ~12 | Table Address95..64 |

## LH – Load Half-word (16 bits)

**Description**:

Loads a half-word (16-bit) value into a data register using indexed addressing. The primary instruction format is one of indexed addressing plus displacement. Four registers are summed in order to calculate the linear address. An address register, an index register, an offset from the instruction and a segment base register.

Half-words may be loaded only into data registers.

**Instruction Format**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 47 30 | 29 27 | 26 24 | 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| Displacement18 | Sn3 | Sc3 | AD | Xn5 | Aa5 | Dt5 | 82h8 |

## LIDT – Load Interrupt Descriptor Table

**Description**:

Loads the interrupt descriptor table pointer from a record in memory.

**Instruction Format**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 47 32 | 31 29 | 28 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| Displacement16 | Sn3 | Sc3 | Xb6 | Xa6 | 16 |  |

**Memory Layout**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| n | Table Address63..0 | | | |
| n+8 | 06 | Length13..0 | ~12 | Table Address95..64 |

## LD – Load Double Word (64 bits)

**Description**:

Loads a double-word (64-bit) value into a data register using indexed addressing. The primary instruction format is one of indexed addressing plus displacement. Four registers are summed in order to calculate the linear address. An address register, an index register, an offset from the instruction and a segment base register.

There are few additional forms of this instruction that make assumptions about the registers in use in order to shorten the instruction.

**Instruction Format**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 47 32 | 31 29 | 28 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| Displacement16 | Sn3 | Sc3 | Xb6 | Xa6 | Xt6 | 86h8 |

**Instruction Format**:

This instruction format is the same as the previous one except without a displacement field.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 3129 | 2826 | 25 20 | 19 14 | 13 8 | 7 0 |
| Sn3 | Sc3 | Xn6 | Xa6 | Xt6 | 96h8 |

**Instruction Format LD Dt,d[SP]**:

This instruction formats assumes the stack pointer is used in the address calculation and assumes the stack segment is also used. The displacement is shifted left three times.

|  |  |  |
| --- | --- | --- |
| 23 14 | 13 8 | 7 0 |
| Disp10 | Xt6 | A6h8 |

**Instruction Format LD Dt,d[FP]**:

This instruction formats assumes the frame pointer is used in the address calculation and assumes the stack segment is also used. The displacement is shifted left three times.

|  |  |  |
| --- | --- | --- |
| 23 14 | 13 8 | 7 0 |
| Disp10 | Xt6 | B6h8 |

**Instruction Format**:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 23 | 22 20 | 19 14 | 13 8 | 7 0 |  |
| Disp9 | Seg3 | Xa6 | Xt6 |  | LD Dt,d[An] |

## LDIS – Load Immediate into Selector

**Description**:

Loads a 24-bit selector value into one of the selector registers. Also causes a load of the descriptor information from the descriptor table.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 39 36 | 35 12 | 11 | 10 8 | 7 0 |
| ~ | Immediate24 | ~ | Sg3 |  |

## LUI – Load Upper Immediate

**Description**:

**Instruction Format**:

Loads bits 29 to 63 with a sign extended immediate constant and zeros out the lower 29 bits of the target register. A subsequent ADD or OR instruction may be used to build a 48-bit sign extended constant in a register.

|  |  |  |
| --- | --- | --- |
| 31 13 | 12 8 | 7 0 |
| Immediate19 | Dt5 | 05h8 |

**Instruction Format**:

Loads the upper 35 bits of a register with an immediate constant and zeros out the lower 29 bits of the target register. A subsequent ADD or OR instruction may be used to build a 64-bit constant in a register.

|  |  |  |
| --- | --- | --- |
| 47 13 | 12 8 | 7 0 |
| Immediate35 | Dt5 | 15h8 |

## LUIA – Load Upper Immediate Address

**Description**:

**Instruction Format**:

Loads the upper 35 bits of an address register with an immediate constant and zeros out the lower 29 bits of the target address register. A subsequent ADDA instruction may be used to build a 64-bit constant in a register.

|  |  |  |
| --- | --- | --- |
| 47 13 | 12 8 | 7 0 |
| Immediate35 | At5 | 16h8 |

MOV – Move Register

Description:

Moves values between registers.

Instruction Format:

This format moves from one data register to another. It is an alternate mnemonic for the ADD instruction.

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| 0 | 05 | Da5 | Dt5 | 24h8 |

Instruction Format:

This format moves from a data register to an address register. It is an alternate mnemonic for the ADD instruction.

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| 1 | Db5 | 05 | At5 | 24h8 |

## NOP – No Operation

**Description**:

NOP is just a placeholder byte that may be used to align code.

**Instruction Format**:

|  |
| --- |
| 7 0 |
| EAh8 |

## OR – Bitwise Or

**Description**:

Or two values and store the result in a data register. The first operand must be in a data register. The second operand may be in a data register or an immediate value supplied in the instruction.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| ~ | Db5 | Da5 | Dt5 | 29h8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 31 18 | 17 13 | 12 8 | 7 0 |
| Immediate14 | Da5 | Dt5 | 09h8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 47 18 | 17 13 | 12 8 | 7 0 |
| Immediate30 | Da5 | Dt5 | 19h8 |

## ORA – Bitwise ‘Or’ to Address

**Description**:

Or two values and store the result in a data register. The first operand must be in a data register. The second operand may be in a data register or an immediate value supplied in the instruction.

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 47 18 | 17 13 | 12 8 | 7 0 |
| Immediate30 | Aa5 | At5 | 49h8 |

## PUSH – Push Register

**Description**:

Pushes a register onto the stack.

**Instruction Format**:

|  |  |  |
| --- | --- | --- |
| 1514 | 13 8 | 7 0 |
| 02 | Xn6 | C6h8 |

**Operation**:

SP = SP – 8

Memory[SP] = Xn

## RTS – Return from Leaf Subroutine

**Description**:

Return from a subroutine by restoring the program counter from the return address (RA) code address register and restoring the CS register from RS.

**Instruction Format**:

|  |
| --- |
| 7 0 |
| E2h8 |

**Operation**:

CS:PC = RS:RA

## RTI – Return from Interrupt

**Description**:

Perform a far return operation by restoring the previous code segment and program counter from the exception segment (XS) and exception return address (XP) registers. The internal interrupt stack is popped and the operating level, privilege level, and interrupt mask level are reset to values before the exception occurred. Also clears the least significant bit of the semaphore register (the reservation status bit).

**Instruction Format**:

|  |
| --- |
| 7 0 |
| E3h8 |

**Operation**:

CS:PC = XS:XP

## SB – Store Byte (8 bits)

**Description**:

Stores a byte (8-bit) value from a data register using indexed addressing. The primary instruction format is one of indexed addressing plus displacement. Four registers are summed in order to calculate the linear address. An address register, an index register, a displacement from the instruction and a segment base register.

Bytes may be stored only from data registers.

**Instruction Format**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 47 32 | 31 29 | 2826 | 25 20 | 19 14 | 13 8 | 7 0 |
| Displacement16 | Sn3 | Sc3 | Xb6 | Xa6 | Xs6 | C0h8 |

## SH – Store Half-word (16 bits)

**Description**:

Stores a half-word (16-bit) value from a data register using indexed addressing. The primary instruction format is one of indexed addressing plus displacement. Four registers are summed in order to calculate the linear address. An address register, an index register, a displacement from the instruction and a segment base register.

Half-words may be stored only from data registers.

**Instruction Format**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 47 32 | 31 29 | 2826 | 25 20 | 19 14 | 13 8 | 7 0 |
| Displacement16 | Sn3 | Sc3 | Xb6 | Xa6 | Xs6 | C1h8 |

## SD – Store Double Word (64 bits)

**Description**:

Stores a double-word (64-bit) value from a data register using indexed addressing. The primary instruction format is one of indexed addressing plus displacement. Four registers are summed in order to calculate the linear address. An address register, an index register, an offset from the instruction and a segment base register.

There are few additional forms of this instruction that make assumptions about the registers in use in order to shorten the instruction.

**Instruction Format**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 47 32 | 31 29 | 28 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| Displacement16 | Sn3 | Sc3 | Xb6 | Xa6 | Xs6 | C3h8 |

**Instruction Format SD Ds,d[SP]**:

This instruction formats assumes the stack pointer is used in the address calculation and assumes the stack segment is also used. The displacement is shifted left three times.

|  |  |  |
| --- | --- | --- |
| 23 14 | 13 8 | 7 0 |
| Disp10 | Xs6 | D0h8 |

**Instruction Format SD Ds,d[FP]**:

This instruction formats assumes the frame pointer is used in the address calculation and assumes the stack segment is also used. The displacement is shifted left three times.

|  |  |  |
| --- | --- | --- |
| 23 14 | 13 8 | 7 0 |
| Disp10 | Xs6 | D1h8 |

**Instruction Format**:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 20 | 19 17 | 16 13 | 12 8 | 7 0 |  |
| Disp12 | Seg3 | Aa4 | Dt5 |  | LD Dt,d[An] |

## SUB - Subtract

**Description**:

Subtract two values and store the result in a data register. Both operands must be in a data register.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| ~ | Db5 | Da5 | Dt5 | 25h8 |

**Operation**:

Dt = Da - Db

## SUBA

**Description**:

This instruction converts a difference between two pointers into an index.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| ~ | Ab5 | Aa5 | Dt5 |  |

## XOR – Bitwise Exclusive Or

**Description**:

Exclusive Or two values and store the result in a data register. The first operand must be in a data register. The second operand may be in a data register or an immediate value supplied in the instruction.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| ~ | Db5 | Da5 | Dt5 | 2Ah8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 31 18 | 17 13 | 12 8 | 7 0 |
| Immediate14 | Da5 | Dt5 | 0Ah8 |

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 47 18 | 17 13 | 12 8 | 7 0 |
| Immediate30 | Da5 | Dt5 | 1Ah8 |

## XORA – Bitwise Exclusive ‘Or’ to Address

**Description**:

Exclusive or two values and store the result in a data register. The first operand must be in a data register. The second operand may be in a data register or an immediate value supplied in the instruction.

**Instruction Format**:

|  |  |  |  |
| --- | --- | --- | --- |
| 47 18 | 17 13 | 12 8 | 7 0 |
| Immediate30 | Aa5 | At5 | 4Ah8 |

MOV2SEGDESC

Description:

Instruction Format:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 18 | 17 13 | 12 8 | 7 0 |
| 0 | Dst5 | Aa5 | St5 | 24h8 |

|  |  |  |
| --- | --- | --- |
| Dst |  |  |
| 0 | Base low |  |
| 1 | Lower bound |  |
| 2 | Upper bound |  |
| 3 | Base high and access rights |  |

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x32 | BRK |  |  | CMP #14 | ADD #14 | LUI #19 |  | BIT # | AND #14 | OR #14 | XOR #14 |  |  |  | XNOR #14 |  |
| 1x48 | JMP | JMF |  | CMP #30 | ADD #30 | LUI #35 | LUIA #35 |  | AND #30 | OR #30 | XOR #30 |  |  |  | XNOR #30 |  |
| 2x24 | JSR | JSF |  | CMP | ADD | SUB | MUL | DIV | AND | OR | XOR |  | NAND | NOR | XNOR |  |
| 3x | BOD | BNO | BPA | BNP | BVS | BVC | BEQ | BNE | BLT | BGE | BLE | BGT | BLTU | BGEU | BLEU | BGTU |
| 4x | BRA |  |  |  | ADDA #30 |  |  |  | ANDA #30 | ORA #30 | XORA #30 |  |  |  |  |  |
| 5x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8x | LB | LBU | LH | LHU | LW | LWU | LD48 Xn | LDU | LQ | LQU | LO |  |  |  |  |  |
| 9x |  |  |  |  |  |  | LD32 Xn |  |  |  |  |  |  |  |  |  |
| Ax |  |  |  |  |  |  | LD24 dSP |  |  |  |  |  |  |  |  |  |
| Bx |  |  |  |  |  |  | LD24 dFP |  |  |  |  |  |  |  |  |  |
| Cx | SB | SH | SW | SD | SQ | SO | PUSH |  |  |  |  |  | DBG |  |  |  |
| Dx | SD24 dSP | SD24 dFP |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Ex8 |  | RTF | RTS | RTI |  |  |  |  |  |  | NOP |  |  |  |  |  |
| Fx |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

# Opcode Map