**Dark Star \* Dragon Nine**

# Programming Model

## General Purpose Register Array

DSD9 has an array of 64, 80 bit general purpose integer registers. The registers may hold either integer or floating point data.

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
|  | Usage |  |  |  |
| r0 | always zero |  | r32 |  |
| r1 | return value / exception code |  | r33 | return value |
| r2 | return value / exception type |  | r34 |  |
| r3 | temporary register |  | r35 | temporary register |
| r4 | temporary register |  | r36 | temporary register |
| r5 | temporary register |  | r37 | temporary register |
| r6 | temporary register |  | r38 | temporary register |
| r7 | temporary register |  | r39 | temporary register |
| r8 | temporary register |  | r40 | temporary register |
| r9 | temporary register |  | r41 | temporary register |
| r10 | temporary register |  | r42 | temporary register |
| r11 | register var |  | r43 |  |
| r12 | register var |  | r44 |  |
| r13 | register var |  | r45 |  |
| r14 | register var |  | r46 |  |
| r15 | register var |  | r47 |  |
| r16 | register var |  | r48 |  |
| r17 | register var |  | r49 |  |
| r18 | register var |  | r50 |  |
| r19 |  |  | r51 |  |
| r20 |  |  | r52 |  |
| r21 |  |  | r53 |  |
| r22 |  |  | r54 |  |
| r23 |  |  | r55 |  |
| r24 |  |  | r56 | thread pointer |
| r25 |  |  | r57 | global pointer |
| r26 |  |  | r58 | exception link register |
| r27 |  |  | r59 | frame pointer |
| r28 |  |  | r60 | banked |
| r29 |  |  | r61 | banked |
| r30 |  |  | r62 | banked |
| r31 |  |  | r63 | stack pointer - banked |

## Register Banking

For purposes of high-speed exception processing a portion of the register file is banked. The last four registers are banked according to the core’s operating level. The supervisor has access to the user level registers which are mapped as CSR’s . At the machine level all registers are accessible.

## Register Usage

Several of the general purpose registers have specific uses.

r0 – always reads as zero. This register may be used where the constant zero is required.

r1 – assigned usage is as a return value register. This register also contains the exception code for a locally handled exception. The core loads r1 with the cause code during exception processing.

r2 – has an assigned usage as a return value register. This register is also set to the exception type (24) during exception processing.

r58 – is assigned to be used as the catch handler address register (or exception linkage register). When an exception is routed to local handlers, the core jumps to the address contained in this register.

r59 – has a dedicated use as the stack frame pointer (BP). When referenced in a memory operation causes the core to check the effective address against stack bounds.

r60,r61,r62, and r63 – are a banked registers. There is a separate physical register for each operating level.

r63 – is dedicated to being used as the stack pointer. When referenced in a memory operation causes the core to check the effective address against stack bounds. This register is also automatically updated by stack operations such as push / pop / call / ret.

# Instruction Alignment

Instructions may by aligned on byte address boundaries.

# Data Alignment

Data may by aligned on byte address boundaries.

# Instruction Cache

The instruction cache line size is 256 bits or about six 40 bit instructions. Instructions may span cache lines. There is no wasted memory space. It may be desirable to align code with the start of the cache line for short loops which will fit entirely in a cache line, to improve performance. Cache lines begin every 16 bytes (address mod 16 = 0).

# Special Purpose Registers

Most special purpose registers are accessible only in kernel mode. A privilege violation will result if attempting to access a special purpose register in user mode that is not available to that mode.

There are no results forwarding on the update of a special purpose register. If the value of the register is required immediately in the following few instructions, then some provision must be made to allow the special purpose register to update. This can be done by following a move to the spr with a couple of NOP instructions. Alternately a branch to a delay subroutine could be performed.

## Program Counter

The program counter identifies which instruction to execute. Normally the program counter increments by the size of the instruction, but the increment may be overridden using one of the flow control instructions. The program counter addresses 40 bit instruction parcels using byte addresses. There are no alignment restrictions on the program counter. It may be set to any byte address.

|  |
| --- |
| 79 0 |
|  |

## Control Register Zero (CSR #000)

This register contains a bit to enable protected mode.

|  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 63 | 62 32 30 9 6 1 | | | | | | | | 0 |
| D | ~ |  |  | bpe | ce |  | ~ |  | Pe |

D: debug mode status. this bit is set during an interrupt routine if the processor was in debug mode when the interrupt occurred.

PE: Protected Mode enable: 1 = enabled, 0 = disabled.

CE: cache enable: 1=enabled, 0 = disabled

bpe: branch predictor enable: 1=enabled, 0=disabled

## Tick Count Register (SPR 04 or TICK)

This register contains a count of the number of clock cycles that have passed since the last time the processor was reset. Tick may be used for high-resolution timing or performance measurement.

### Clock Register (SPR 06)

The clock register controls clock gating to the processor to allow lower power consumption. Gating is controlled with a bit pattern which is fed to a clock enable gate. The pattern is 50 bits long, allowed clock control (or power control) in 2% increments. For example loading the register with h2AAAAAAAAAAAA will cause every other clock to be gated off, reducing the effective operating frequency of the core in half. Loading the register with a zero will stop the clock completely. However, a non-maskable interrupt or reset will reload the clock register with all ones, causing the processor to operate at maximum frequency.

|  |  |
| --- | --- |
| 63 50 | 49 0 |
| ~14 | clock gating pattern49..0 |

## DBPC (SPR07)

This register stores the return address for a debug interrupt processing routine. This register is automatically loaded when a debug interrupt occurs. The program counter is loaded from this register automatically as part of the RTD instruction processing.

|  |
| --- |
| 63 0 |
| Value 63..0 |

## EPC (CSR #040h) Exception Program Counter

This register stack stores the return address for an exception processing routine (OVERFLOW / privilege violation). This register is automatically loaded when an exception occurs. The program counter is loaded from this register automatically as part of the IRET instruction processing. This register stack is five deep. When stack underflow occurs the program counter will be set to the exception stack underflow vector.

|  |
| --- |
| 79 0 |
| Value 79..0 |

## MSTATUS (CSR #041h) Machine Status

This register contains a stack of machine states in bits zero to fifty-five that need to be recovered after an exception occurs. Included in this register are fields for the operating level, privilege level and interrupt mask. This register allows for a five deep stack of machine status bits.

The top of the stack are bits zero to ten. When an interrupt or exception occurs this register is shifted left by eleven bits, and the current interrupt mask, operating level, and privilege level are copied to the top of the stack.

On return from exception or interrupt this register is shifted right by eleven bits and the top of stack copied to the current interrupt mask, operating level and privilege level.

|  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 79 | 7877 | 76 72 | 71 | 7068 | 6766 | 6564 | 63 55 | 54 11 | 10 3 | 2 1 | 0 |
| SD1 | ~2 | VM5 | MPRV1 | ~3 | XS2 | FS2 | ~9 | Stack | PL8 | OL2 | IM1 |

### VM5

These bits control virtual memory options. Note that multiple options may be present at the same time. At reset all the bits are set to zero.

|  |  |  |
| --- | --- | --- |
| Bit |  |  |
| 0 | 1 = single bound |  |
| 1 | 1 = separate program and data bounds |  |
| 2 | 1 = lot protection system |  |
| 3 | 1 = simplified paged unit |  |
| 4 | 1 = paging unit |  |

### MPRV

This bit when true (1) causes memory operations to use the first stack privilege level when evaluating privilege and protection rules.

## Interrupt Vector Table Base Address (SPR 10 or VBR)

This register contains the physical base address of the interrupt vector table in memory. The Table is 256B aligned.

|  |  |
| --- | --- |
| 79 8 | 7 0 |
| Address79..8 | 008 |

## EA (CSR #28h)

This register holds the effective address associated with a memory tag. The tag number is contained in bits 16 to 26. The tag associated with this address will be accessible in the TAGS special purpose register. Note that this register and following tag access should be executed with interrupts disabled to prevent the effective address from changing before the tag is updated or read. Also no memory operation should occur between setting this register and updating or reading the tag. This register also reflects the latest effective address calculated by the processor and will be automatically updated when a memory operation occurs.

|  |  |  |
| --- | --- | --- |
| 63 0 | | |
| ~ | tag number11 | Offset16 |

## TAGS (SPR41)

This register makes the tag value accessible for update or read-back. It is used in association with the EA special purpose register. Writing this register will update the tag identified in the EA register.

|  |  |
| --- | --- |
| 63 0 | |
| ~ | Tag16 |

## LOTGRP (CSR #02Ah)

This register contains a list of memory groups that the process belongs to. The owning group associated with a memory tag is compared to this list during a memory access. If the group is in the list then the memory access is allowed, otherwise a memory fault exception occurs. This comparison takes place only in user mode; in machine mode the machine owns all of memory so the memory access is always allowed.

|  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 79 70 | | 69 60 | | 59 50 | 49 40 | 39 30 | | 29 20 | 19 10 | | 9 0 | |
| Group7 | Group6 | | Group5 | | Group4 | Group3 | Group2 | | | Group1 | | Group0 |

## Compare and Swap (SPR44 or CAS)

This register is to support the compare and swap (CAS) instruction. If the value in the addressed memory location identified by the CAS instruction is equal to the value in the CAS register, then the source register is written to the memory location, and the source register is loaded with the value 1. Otherwise if the value in the addressed memory location doesn’t match the value in this register, then value at the memory location is loaded into the CAS register, and the source register is set to zero. No write to memory occurs if the match fails.

|  |
| --- |
| 63 0 |
| Value 63..0 |

## MYST (SPR45)

This register is to supports the MYST instruction. During execution of the MYST instruction the function code of the operation to be performed is loaded from this register. The MYST register is available to both user and kernel modes.

|  |  |
| --- | --- |
| 63 7 | 6 0 |
| ~57 | Funct7 |

## Debug Address Register (SPR50 to SPR53 or DBAD0 to DBAD3)

These registers contain addresses of instruction or data breakpoints.

|  |
| --- |
| 63 0 |
| Address 63..0 |

## Debug Control Register (SPR54)

These registers contains bits controlling the circumstances under which a debug interrupt will occur.

|  |  |  |  |
| --- | --- | --- | --- |
| bits |  |  |  |
| 3 to 0 | Enables a specific debug address register to do address matching. If the corresponding bit in this register is set and the address (instruction or data) matches the address in the debug address register then a debug interrupt will be taken. |  |  |
| 17, 16 | This pair of bits determine what should match the debug address register zero in order for a debug interrupt to occur.   |  |  |  | | --- | --- | --- | | 17:16 |  |  | | 00 | match the instruction address |  | | 01 | match a data store address |  | | 10 | reserved |  | | 11 | match a data load or store address |  | |  |  |
| 19, 18 | This pair of bits determine how many of the address bits need to match in order to be considered a match to the debug address register. These bits are ignored when matching instruction addresses, which are always half-word aligned.   |  |  |  | | --- | --- | --- | | 19:18 |  | Size | | 00 | all bits must match | byte | | 01 | all but the least significant bit should match | char | | 10 | all but the two LSB’s should match | half | | 11 | all but the three LSB’s should match | word | |  |  |
| 23 to 20 | Same as 16 to 19 except for debug address register one. |  |  |
| 27 to 24 | Same as 16 to 19 except for debug address register two. |  |  |
| 31 to 28 | Same as 16 to 19 except for debug address register three. |  |  |
| 62 | This bit is a history bit for single stepping mode. The debug interrupt records bit 63 into bit 62 when a debug interrupt occurs. Then turns off SSM by writing a zero to bit 63. On return from debug routine (RTD) this bit is restored into bit 63 re-enabling SSM. |  |  |
| 63 | This bit enables SSM (single stepping mode) |  |  |

## Debug Status Register (SPR55)

This register contains bits indicating which addresses matched. These bits are set when an address match occurs, and must be reset by software.

|  |  |
| --- | --- |
| bit |  |
| 0 | matched address register zero |
| 1 | matched address register one |
| 2 | matched address register two |
| 3 | matched address register three |
| 63 to 4 | not used, reserved |

## Floating Point Status and Control Register –SPR20

The floating point status and control register may be read using the MFSPR instruction.

|  |  |  |  |
| --- | --- | --- | --- |
| Bit |  | Symbol | Description |
| 31:29 | **RM** | rm | rounding mode (unimplemented) |
| 28 | **E5** | inexe | - inexact exception enable |
| 27 | **E4** | dbzxe | - divide by zero exception enable |
| 26 | **E3** | underxe | - underflow exception enable |
| 25 | **E2** | overxe | - overflow exception enable |
| 24 | **E1** | invopxe | - invalid operation exception enable |
| 23 | **NS** | ns | - non standard floating point indicator |
| **Result Status** | | | |
| 22 |  | fractie | - the last instruction (arithmetic or conversion) rounded intermediate result (or caused a disabled overflow exception) |
| 21 | **RA** | rawayz | rounded away from zero (fraction incremented) |
| 20 | **SC** | C | denormalized, negative zero, or quiet NaN |
| 19 | **SL** | neg < | the result is negative (and not zero) |
| 18 | **SG** | pos > | the result is positive (and not zero) |
| 17 | **SE** | zero = | the result is zero (negative or positive) |
| 16 | **SI** | inf ? | the result is infinite or quiet NaN |
| **Exception Occurrence** | | | |
| 15 | **X6** | swt | {reserved} - set this bit using software to trigger an invalid operation |
| 14 | **X5** | inerx | - inexact result exception occurred (sticky) |
| 13 | **X4** | dbzx | - divide by zero exception occurred |
| 12 | **X3** | underx | - underflow exception occurred |
| 11 | **X2** | overx | - overflow exception occurred |
| 10 | **X1** | giopx | - global invalid operation exception – set if any invalid operation exception has occurred |
| 9 | **GX** | gx | - global exception indicator – set if any enabled exception has happened |
| 8 | **SX** | sumx | - summary exception – set if any exception could occur if it was enabled  - can only be cleared by software |
| **Exception Type Resolution** | | | |
| 7 | **X1T** | cvt | - attempt to convert NaN or too large to integer |
| 6 | **X1T** | sqrtx | - square root of non-zero negative |
| 5 | **X1T** | NaNCmp | - comparison of NaN not using unordered comparison instructions |
| 4 | **X1T** | infzero | - multiply infinity by zero |
| 3 | **X1T** | zerozero | - division of zero by zero |
| 2 | **X1T** | infdiv | - division of infinities |
| 1 | **X1T** | subinfx | - subtraction of infinities |
| 0 | **X1T** | snanx | - signaling NaN |

## Floating Point Number Format

The floating point number format used by DSD9 is the extended double precision format:

|  |  |  |  |
| --- | --- | --- | --- |
| 1 | 1 | 14 | 64 + 1 hidden bit |
| Sm | Se | EEEEEEEEEE | .MMMMMMM…..MMMMMMMM |

Sm = sign of mantissa

Se = sign of exponent

The exponent and mantissa are both represented as two’s complement numbers, however the sign bit of the exponent is inverted.

|  |  |
| --- | --- |
| SeEEEEEEEEEE |  |
| 11111111111 | Maximum exponent |
| …. |  |
| 01111111111 | exponent of zero |
| …. |  |
| 00000000000 | Minimum exponent |

The exponent ranges from -16382 to +16382

# Memory Management Unit

## Overview

The memory management unit is a simplified paged memory management unit. Memory management by the MMU includes virtual to physical address mapping. The MMU divides memory into 64kB pages. Processor address bits 16 to 25 are used as a ten bit index into a mapping table to find the physical page. The MMU remaps the ten address bits into a thirteen bit value used as address bits 16 to 28 when accessing a physical address. The lower sixteen bits of the address pass through the MMU unchanged. Also passing through the MMU unchanged are address bits 29 to 31. It is assumed that in the system where the MMU would be relevant, that some or all of the high order bits of an address would be left unconnected. The maximum amount of memory that may be mapped in the MMU is 64MiB per map out of a pool of 512MiB. Addresses with the most significant six bits set are not mapped.

## Map Tables

The mapping tables for memory management are stored directly in the MMU rather than being stored in main memory as is commonly done. The MMU supports up to 32 independent mapping tables. Only a single mapping table may be active at one time. The active mapping table is set in the paging control register (CSR #3) bits 0 to 4 – called the operate key. Mapping tables may be shared between tasks.

## Map Caching / TLB

There isn’t a need for a TLB or ATC as the entire mapping table is contained in the MMU. A TLB isn’t required. Address mapping is still only single cycle.

## Operate Key

The operate key controls which mapping table is actively mapping the memory space. The operate key is located in CSR #3 bits 0 to 4.

## Access Key

The MMU mapping tables are present at I/O address $FFDC4000 to $FFDC43FF. All the mapping tables share the same I/O space. Only one mapping table is visible in the address space at one time. Which table is visible is controlled by an access key. The access key is located in the paging control register (CSR #3) bits 8 to 12.

## Address Pass-through

Addresses pass through the MMU unaltered until the mapping enable bit is set. Until mapping is enabled, the physical address will match the virtual address. Additionally address bits 0 to 15 pass through the MMU unaltered. Address bits 28 to 31 pass through the MMU unaltered as well.

## Mapping Table Layout

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |
| 000 |  |  |  | WP | PA27 | PA26 | PA25 | PA24 | PA23 | PA22 | PA21 | PA20 | PA19 | PA18 | PA17 | PA16 |  |
| 001 |  |  |  | WP | PA27 | PA26 | PA25 | PA24 | PA23 | PA22 | PA21 | PA20 | PA19 | PA18 | PA17 | PA16 |  |
| 002 |  |  |  | WP | PA27 | PA26 | PA25 | PA24 | PA23 | PA22 | PA21 | PA20 | PA19 | PA18 | PA17 | PA16 |  |
|  | … | | | | | | | | | | | | | | | |  |
| 1FF |  |  |  | WP | PA27 | PA26 | PA25 | PA24 | PA23 | PA22 | PA21 | PA20 | PA19 | PA18 | PA17 | PA16 |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

WP = write protect

PAxx = Physical address bit

## Paging Control Register Layout

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 31 | 30 13 | 12 8 | 7 5 | 4 0 |
| PE | ~18 | AKey5 | ~ | OKey5 |

PE = Paging Enable (1=enabled, 0 = disabled)

AKey = Access Key

OKey = Operate Key

# Latency

# The address map operation when enabled has a single cycle of latency. The ready line to the core is brought low for a cycle by the MMU. The MMU delays the (wr, vda, and vpa) control signals to memoryMemory Operations

## Memory Bus Size

The core uses a 128 bit data-bus to interface to external devices. This size was chosen to match the typical size of the dynamic RAM interface. It also allows loading the caches with a minimal number of bus cycles to improve performance. For un-cached data most data is available with just a single bus cycle. When un-cached data is not suitably aligned the core will perform a second memory operation to fetch or store the data.

## Bus Organization

The byte, wyde, and tetra-byte store operations fill the data-bus with contiguous multiple copies of the data in the inactive portions of the data-bus. The penta-byte and deci-byte store operations pad the data-bus with zeros for the inactive portions. For instance a byte store operation places the same byte of data on every byte lane during the store. There are then 15 copies + 1 valid byte on the data-bus. A wyde operation would place eight copies of the sixteen bit data on the data-bus. This was done to facilitate the use of the bus by input / output devices. The I/O device has to look only at the low order portion of the data-bus that’s relevant to it during a store operation. Otherwise it would be necessary to externally shift the data onto the low order bits for the I/O device. While there are tons of 8, 16, or 32 bit peripheral cores there are not many 40 or 80 bit cores so output to storage for those sizes was simplified.

For input the I/O subsystem should reflect the data from the I/O device across the width of the data-bus. For instance eight copies of wyde data should be placed on the 128 bit data bus by the I/O subsystem. This is required because the core looks only at the portion of the data-bus that is active according to the address and data size.

# Memory Protection System

A key feature required to increase system reliability and robustness is memory protection. Memory should be protected against inadvertent access by the process that doesn’t own a particular piece of memory. The system used here provides memory protection, but not address virtualization.

Memory is organized into lots which are 64kB in size. Memory is protected using a system of tags associated with each lot of memory. The tag associated with a memory lot contains the lot owner’s group, and read / write / execute indicators.

![](data:image/gif;base64,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18UfBOW+/NW/Is5fd9f//Wmi/UMY/ukfTqY/n8m//k1d/nlQ//1fJQBigkARBAsaPIgwocKFDBs6fAgxosSDAidwuogxo8aNHDt6/AgypMiRJP9LmjyJMqXKlSxbunwJM6bMmTRr2ryJM6fOnTxtVpwINKjQoUSLiqjYM6nSpUybOn0KNarUqVSrWr1a9afRrVy7emWIFKvYsWTLmj2LNq3atWzbbtT6Na7cuRPDur2LN6/evXz7+v3bFy7dwYQL2wWMOLHixYwbO36MVnDhyZS5HoaMObPmzZw7e/YrubLo0RIvfz6NOrXq1axbhwxNOrZshKZd276NO7fu3WNhz/4duzbv4cSLGz+OvKNv4MwpC08OPbr06dQVL2+One7z6ty7e/8Ovun17OS9bg+PPr369eyVDywPX7vA9vTr279PfXz8/UHP4/8PYIACPqYffwb/QuTfgAouyGCDZhV4YIQLJehghRZeiCFOEErIoUEUZghiiCKO6NGGHXb4IYkqrsjigiaeKGGKLc5IY43ovQjjgTLayGOPPhaHY4787fhjkUYeeVqQQsZHJJJOPgklYkouWV6TUV6JZZaRvUdll1ZqCWaYYjo1ZZfYfTlmmmquKVOZZjKHJptyzknna1y+mWOcde7J55xu4jmbnn0OSqiWfwIa3HyFLspon4ciOpqgjU5K6YyPQlqZpJVuymmGl2I6maadjkrqgJ+CSpiopa7KanunoiqfRa3OSiuGr8Iql6q17sorcrfi+pWuvQ5LLG6/AtuVsMUuy2ySdyILn7LN/05LLYHPQkuetNVuyy1o12J7pqLdjkuuaseCS5S25a7Lbm/fogucuu3OSy9U58Lbn7j17stvXvfiW5e+/Q5M8Fn/AhyRvAUvzHBKByP8kMINT0zxRw9D3JDEFW/M8cUYTygwxyKPHJPHHyekMckq92vyyRSFvHLMMts5gcuBwjxzzjpfVFHPPv8MdNBCD0100UYfjXTSR+/MdNMWKA111FJPTXXVPzeNdc5YWM11115/jXQRWY9Ndtlmn4122mqvzXbbbr8Nd9xyz0133XbfjXfeeu/Nd99+/w144IIPTnjhhh+OeOKKL854444/Dnnkkk9OeeWWX4555ppvznnnnv9/Dnrooo9Oeummn4566qqvznrrrr8Oe+yyz0577bbfjnvuuu/Oe+++/w588MIPT3zxxh+PfPLKL898884/D3300k9PffXWX4999tpvz3333n8Pfvjij09++eafj3766q/Pfvvuvw9//PLPT3/99t+Pf/76789///7/D8AACnCABCygAQ+IwAQqcIEMbKADHwjBCEpwghSsoAUviMEManCDHOygBz8IwhCKcIQkLKEJT4jCFKpwhSxsoQtfCMMYynCGNKyhDW+IwxzqcIc87KEPfwjEIApxiEQsohGPiMQkKnGJTGyiE58IxShKcYpUrKIVr4jFLGpxi1zsohe/CMYJMIpxjGQkXUAAADs=)

The lot owner field in the memory tag represents a group of processes which may access the memory lot. Each process in the system may be associated with up to six memory groups. Which memory groups the process is a part of is stored in the LOTGRP special purpose register.

### Interrupts

FISA64 uses a vectored interrupt system with support for 512 interrupt vectors.

### Interrupt Vector Table Usage

The following table outlines which vector is used for a given purpose. These vectors are specific to FISA64. Under the HW column an ‘x’ indicates that the interrupt is internally generated by the processor; the vector is hard-wired to that use. An ‘e’ indicates an externally generated interrupt, the usage may vary depending on the system.

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Vecno |  | HW | Description |  |
| 0 |  |  |  |  |
| 1 |  |  |  |  |
| 2 |  |  | FMTK Scheduler |  |
| 3 |  |  | debug interrupt |  |
| 4 |  |  | OS API call |  |
| 449 | KRST | e | Keyboard reset interrupt |  |
| 450 | MSI | e | Millisecond Interrupt |  |
| 451 | TICK | e | FMTK Tick Interrupt |  |
| 463 | KBD | e | Keyboard interrupt |  |
| 487 | BND | x | Bounds check exception |  |
| 488 | DBZ | x | divide by zero |  |
| 489 | OFL | x | overflow |  |
| 493 | FLT | x | floating point exception |  |
| 494 | TAP | x | debug tap interrupt |  |
| 495 | SSM | x | single-step interrupt |  |
| 496 | BPT | x | breakpoint |  |
| 497 | EXF | x | Executable fault |  |
| 498 | DWF | x | Data write fault |  |
| 499 | DRF | x | data read fault |  |
|  |  |  |  |  |
| 501 | PRIV | x | privilege level violation |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
| 508 | DBE | x | data bus error |  |
| 509 | IBE | x | instruction bus error |  |
| 510 | NMI | x | Non-maskable interrupt |  |
|  |  |  |  |  |

# Instruction Set Description

A description of the instruction set follows.

## Instruction Size

Instructions are 40 bits in size.

|  |
| --- |
| 39 0 |
| Inst |

## Constant Extensions

Constants may be extended up to 80 bits using constant post-words.

Shown below are the instruction formats for the ‘ADD’ immediate instruction with 20, 56, and 92 bits.

20 bit constant

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 39 20 | 19 14 | 13 8 | 7 0 |  |
| Immediate20 | Rt6 | Ra6 | 048 | ADD Rt,Ra,#imm |

56 bit constant

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Immediate19..0 | Rt6 | Ra6 | 048 | | ADD Rt, #imm |
| Immediate55..24 | | | Ch4 | I4 |

92 bit constant

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Immediate19..0 | Rt6 | Ra6 | 048 | | ADD Rt, #imm |
| Immediate55..24 | | | Ch4 | I4 |
| Immediate91..60 | | | Ch4 | I4 |

If a constant is encountered in the instruction stream it will be treated as a NOP operation. Normally the processor advances past constants as they are encountered.

## Branch Targets

## ADD - Addition

ADD Rt, Ra, #i19

ADD Rt, Ra, Rb

**Instruction Formats**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 32 | 31 26 | 25 20 | | 19 14 | 13 8 | 7 0 |  |
| 04h8 | ~6 | Rt6 | | Rb6 | Ra6 | 028 | ADD Rt,Ra,Rb |
| Immediate20 | | | | Rt6 | Ra6 | 048 | ADD Rt,Ra,#imm |
|  | | | Immed10 | | Rt6 | 31h8 | ADD Rt,#imm10 |

Operation:

Register Immediate Form

Rt = Ra + immediate20

Register-Register Form

Rt = Ra + Rb

Notes***:***

The immediate constant may be extended up to 64 bits.

|  |  |
| --- | --- |
| S2 | Operation |
| 0 | Wyde parallel |
| 1 | Tetra parallel |
| 2 | Octa parallel |
| 3 | (reserved) Hexi |

## AND – Bitwise ‘and’

AND Rt, Ra, #i20

AND Rt, Ra, Rb

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |  |
| 08h8 | ~6 | Rt6 | Rb6 | Ra6 | 028 | AND Rt,Ra,Rb |
| Immediate20 | | | Rt6 | Ra6 | 088 | AND Rt,Ra,#imm |

Operation:

**Register Immediate Form**

Rt = Ra & immediate

**Register-Register Form**

Rt = Ra & Rb

Notes***:***

The immediate constant may be extended up to 64 bits with immediate postfix instructions.

## ASL – Arithmetic Shift Left Register

Description:

Shift register to the left by an amount specified in either a second register or a constant in the instruction and place the result in the target register. A Zero is shifted into bit 0.

**Instruction Format**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 32 | 31 26 | | 25 20 | 19 14 | 13 8 | 7 0 |  |
| 32h8 | ~6 | | Rt6 | Rb6 | Ra6 | 028 | ASL Rt,Ra,Rb |
| 42h8 | ~5 | I1 | Rt6 | Immed6 | Ra6 | 028 | ASL Rt,Ra,#i6 |

**Operation:**

Rt = Ra << Rb

Clock Cycles: 1

Exceptions: overflow if the sign bit changes

Notes:

This instruction performs the same operation as the SHL instruction except that it may cause an overflow exception.

## ASR – Arithmetic Shift Right

ASR Rt, Ra, #i7

ASR Rt, Ra, Rb

**Description:**

Shift register to the right preserving the sign bit, by an amount specified in either a second register or a constant in the instruction and place the result in the target register. The value of the most significant bit is unchanged.

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 32 | 31 26 | | 25 20 | 19 14 | 13 8 | 7 0 |  |
| 33h8 | ~6 | | Rt6 | Rb6 | Ra6 | 028 | ASR Rt,Ra,Rb |
| 43h8 | ~3 | I1 | Rt6 | Immed6 | Ra6 | 028 | ASR Rt,Ra,#i6 |

Operation:

**Register Immediate Form**

Rt = Ra >> immediate7

**Register-Register Form**

Rt = Ra >> Rb

Notes:

Performs an arithmetic shift right, preserving the sign bit of the value.

## BFCHG – Bitfield Change

**Description:**

Inverts the bitfield in Ra located between the mask begin (mb) and mask end (me) bits and stores the result in the target register.

**Instruction Format**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 | 34 28 | 27 | 26 20 | 19 14 | 13 8 | 7 0 |
| 24 | ~1 | me7 | ~ | mb7 | Rt6 | Ra6 | 13h8 |

## BFCLR – Bitfield Clear

**Description:**

Sets the bits to zero of the bitfield in Ra located between the mask begin (mb) and mask end (me) bits and stores the result in the target register.

**Instruction Format**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 | 34 28 | 27 | 26 20 | 19 14 | 13 8 | 7 0 |
| 14 | ~1 | me7 | ~ | mb7 | Rt6 | Ra6 | 13h8 |

## BFEXT – Bitfield Extract

**Description:**

Extracts a bitfield from register Ra located between the mask begin (mb) and mask end (me) bits and places the sign extended result into the target register. This instruction may be used to sign extend a value beginning at any bit.

**Instruction Format**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 | 34 28 | 27 | 26 20 | 19 14 | 13 8 | 7 0 |
| 54 | ~1 | me7 | ~ | mb7 | Rt6 | Ra6 | 13h8 |

## BFEXTU – Bitfield Extract Unsigned

**Description:**

Extracts a bit-field from register Ra located between the mask begin (mb) and mask end (me) bits and places the zero extended result into the target register. This instruction may be used to zero extend a value beginning at any bit.

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 | 34 28 | 27 | 26 20 | 19 14 | 13 8 | 7 0 |
| 64 | ~1 | me7 | ~ | mb7 | Rt6 | Ra6 | 13h8 |

## BFINS – Bitfield Insert

**Description:**

Inserts a bitfield into the target register located between the mask begin (mb) and mask end (me) bits from the low order bits of Ra or an immediate value.

**Instruction Format**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 | 34 28 | 27 | 26 20 | 19 14 | 13 8 | 7 0 |
| 34 | ~1 | me7 | ~ | mb7 | Rt6 | Ra6 | 13h8 |
| 44 | ~1 | me7 | ~ | mb7 | Rt6 | Imm6 | 13h8 |

## BFSET – Bitfield Set

**Description:**

Sets the bits to one of the bitfield in Ra located between the mask begin (mb) and mask end (me) bits and stores the result in the target register.

**Instruction Format**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 | 34 28 | 27 | 26 20 | 19 14 | 13 8 | 7 0 |
| 04 | ~1 | me7 | ~ | mb7 | Rt6 | Ra6 | 13h8 |

## BBC – Branch on Bit Clear

Description:

Branch if a bit in a register is false. The branch range is approximately +/- 128k bytes.

Instruction Formats:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Target17..0 | ~1 | Bitno7 | Ra6 | 54h8 |

Operation:

if (~Ra[bitno])

pc <= pc + sign extended Target;

Clock Cycles: 1 if prediction is true, 3 otherwise

## BBS – Branch on Bit Set

Description:

Branch if a bit in a register is true. The branch range is approximately +/- 128k bytes.

Instruction Formats:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Target17..0 | ~1 | Bitno7 | Ra6 | 55h8 |

Operation:

if (~Ra[bitno])

pc <= pc + sign extended Target;

Clock Cycles: 1 if prediction is true, 3 otherwise

## Bcc – Branch on Compare to Register

Description:

Branch if a comparison condition between a register and another register value is true. The branch range is approximately +/- 128k bytes.

These instructions allow a static branch prediction to be specified. If the branch prediction is statically specified then the branch does not consume room in the branch history table. This may improve the accuracy of predicted branches.

Instruction Formats:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Target17..0 | P2 | Rb6 | Ra6 | Opcode8 |

Operation:

if (Ra cond Rb)

pc <= pc + sign extended Target;

Clock Cycles: 1 if prediction is true, 3 otherwise

Conditions:

|  |  |  |
| --- | --- | --- |
| Opcode8 | Mne. | Description |
| 46 | BEQ | branch if equal |
| 47 | BNE | not equal |
| 48 | BLT | signed less than |
| 49 | BGE | signed greater than or equal |
| 4A | BLE | signed less than or equal |
| 4B | BGT | signed greater than |
| 4C | BLTU | unsigned less than |
| 4D | BGEU | unsigned greater than or equal |
| 4E | BLEU | unsigned less than or equal |
| 4F | BGTU | unsigned greater than |

## BccI – Branch on Compare to Immediate

Description:

Branch if a comparison condition between a register and an eight bit immediate value is true. The branch range is approximately +/- 128k bytes. The immediate value is sign extended before use. Constant postfix words may be used to extend the immediate to 64 bits.

Instruction Formats:

|  |  |  |  |
| --- | --- | --- | --- |
| Target17..0 | Imm7..0 | Ra6 | Opcode8 |

Operation:

if (Ra cond #imm)

pc <= pc + displacement

Clock Cycles: 1 if prediction is true, 3 otherwise

Conditions:

|  |  |  |
| --- | --- | --- |
| Opcode8 | Mne. | Description |
| 56 | BEQ # | branch if equal |
| 57 | BNE # | not equal |
| 58 | BLT # | signed less than |
| 59 | BGE # | signed greater than or equal |
| 5A | BLE # | signed less than or equal |
| 5B | BGT # | signed greater than |
| 5C | BLTU # | unsigned less than |
| 5D | BGEU # | unsigned greater than or equal |
| 5E | BLEU # | unsigned less than or equal |
| 5F | BGTU # | unsigned greater than |

## BRA – Branch Unconditionally

BRA target\_address

Instruction Formats:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Target17..0 | 32 | 06 | 06 | 46h8 |

Operation:

Notes:

## BRK – Breakpoint Exception

BRK address

Instruction Formats:

|  |  |  |  |
| --- | --- | --- | --- |
| 31 18 | 17 | 16 8 | 7 0 |
| ~ | N | Cause9 | 008 |

Operation:

if (h = 0)

epc = pc

else if (h = 1)

dbpc = pc

else if (h = 2)

ipc = pc

PC = memory[vbr + vector \* 8]

Notes:

Perform an interrupt, exception or debug handler. The handler type is indicated by the ‘H’ field of the instruction. The BRK instruction is used by hardware interrupts to call a hardware interrupt processing routine. The appropriate return instruction (RTE, RTD, or RTI) should be used to return from the BRK handler. The BRK instruction causes the processor to switch to kernel mode.

## CALL – Call Subroutine

CALL (abs,Rn)

CALL d(Rn)

Description:

This instruction performs a subroutine call operation. First the return address is pushed onto the stack (the address of the next instruction). Next the program counter is loaded from the specified operand.

If register 63 is specified for Ra, then the address of the instruction is substituted for use in calculating the target address. This allows program counter relative addressing to be used.

Instruction Formats:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Immed10 | ~2 | 06 | Ra6 | 50h8 | CALL |
| Immed10 | S2 | 06 | Ra6 | 51h8 | CALLI |

Operation:

Memory Indexed Indirect Form

SP = SP – 8

memory[SP] = return address

PC = memory[address + Rn]

Register Indirect with Displacement Form

SP = SP – 8

memory[SP] = return address

PC = displacement + Rn

Notes:

The address constant may be extended up to 64 bits with immediate postfix instructions.

## CAS – Compare and Swap

CAS R1,R2,d[R4]

**Instruction Format:**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Disp15 | Rst5 | Ra5 | 6C7h | CAS |

**Operation:**

if memory[Ra+displacement] = casreg

memory[Ra + displacement] = Rst

Rst = 1

else

casreg = memory [Ra + displacement]

Rst = 0

**Description:**

If the contents of the addressed memory cell is equal to the contents of CAS special purpose register then a sixty-four bit value is stored to memory from the source register Rst and Rst is set equal to one. Otherwise Rst is set to zero and the contents of the memory cell is loaded into CAS. The memory address is the sum of the sign extended displacement and register Ra. The compare and swap operation is an atomic operation; the bus is locked during the load and potential store operation. This operation assumes that the addressed memory location is part of the volatile region of memory and bypasses the data cache. Note that the memory system must support bus locks in order for this instruction to work as expected.

This instruction is typically used to implement semaphores. The LWAR and SWCR may also be used to perform a similar function where the memory system does not support bus locks, but support address reservations instead.

**Assembler:**

CAS Rt,Rt,displacement[Ra]

## CHK – Check and Exception

CHK Rt, Ra, Bn

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 40 33 | 32 28 | 27 22 | 2120 | 19 14 | 13 8 | 7 0 |  |
| 0Bh8 | ~5 | Rc6 | S2 | Rb6 | Ra6 | 028 | CHK Ra,Rb,Rc |
| Immediate19 | | | S2 | Rb6 | Ra6 | 0B8 | CHK Ra,Rb,#imm |

Operation:

if not (Ra >= Rb and Ra < Rc or immediate)

take bounds exception

Notes:

This instruction may be used to validate a pointer or array index.

A register is checked against the upper and lower bounds contained in a register identified by the instruction. If the register is not between the upper and lower bounds then a bounds check exception is taken.

The immediate constant may be extended up to 64 bits with immediate prefix instructions.

This exception may be routed to either a local or global exception handler depending on the setting in the EXROUT CSR.

## CMP - Comparison

CMP Rt, Ra, #i16

CMP Rt, Ra, Rb

**Description**

CMP performs a signed comparison of operands and sets the target register to -1, 0, or +1 if the first operand is less than, equal to, or greater than the second respectively.

The immediate constant may be extended up to 64 bits with immediate prefix instructions.

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 40 33 | 32 28 | 27 22 | 2120 | 19 14 | 13 8 | 7 0 |  |
| 06h8 | ~5 | Rt6 | S2 | Rb6 | Ra6 | 028 | CMP Rt,Ra,Rb |
| Immediate19 | | | S2 | Rb6 | Ra6 | 068 | CMP Rt,Ra,#imm |

Operation:

**Register Immediate Form**

if (Ra < immediate)

Rt = -1

else if (Ra = immediate)

Rt = 0

else

Rt = 1

**Register-Register Form**

if (Ra < Rb)

Rt = -1

else if (Ra = Rb)

Rt = 0

else

Rt = 1

## CMPU – Unsigned Comparison

CMPU Rt, Ra, #i19

CMPU Rt, Ra, Rb

**Description**

CMPU performs a unsigned comparison of operands and sets the target register to -1, 0, or +1 if the first operand is less than, equal to, or greater than the second respectively.

The immediate constant may be extended up to 64 bits with immediate prefix instructions.

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 40 33 | 32 28 | 27 22 | 2120 | 19 14 | 13 8 | 7 0 |  |
| 06h8 | ~5 | Rt6 | S2 | Rb6 | Ra6 | 028 | CMP Rt,Ra,Rb |
| Immediate19 | | | S2 | Rb6 | Ra6 | 068 | CMP Rt,Ra,#imm |

Operation:

**Register Immediate Form**

if (Ra < immediate)

Rt = -1

else if (Ra = immediate)

Rt = 0

else

Rt = 1

**Register-Register Form**

if (Ra < Rb)

Rt = -1

else if (Ra = Rb)

Rt = 0

else

Rt = 1

## COM – Bitwise Ones Complement

COM Rt, Ra

**Description**

All the bits in Ra are inverted and placed into the target register Rt. This is an alternate mnemonic for the XOR instruction.

**Instruction Formats**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 40 33 | 32 28 | 27 22 | 2120 | 19 14 | 13 8 | 7 0 |  |
| 7FFFFh19 | | | ~2 | Rt6 | Ra6 | 0A8 | XOR Rt,Ra,#imm |

Operation:

Register Immediate Form

Rt = Ra ^ -1

Notes***:***

## CPUID – Processor Identification

CPUID Rt, Ra, #n

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 367 |  | ~ | I4 | Rt5 | Ra5 | 027 | CPUID |

Operation:

#### Register-Register Form

Rt = Processor Info Table[Ra|#n]

Notes:

The CPUID instruction returns information about the processor. The contents of register Ra and a four bit immediate value are OR’d together to form an index into the information table. One or the other of register Ra or the immediate value should be zero.

|  |  |  |
| --- | --- | --- |
| Index | bits | Information Returned |
| 0 | 15 to 0 | The processor core number. This field is determined from an external input. It would be hard wired to the number of the core in a multi-core system. |
|  | 23 to 16 | Processor chip number. On a motherboard with multiple chips this identifies the chip the core is located in. It is typically hardwired to zero. |
|  | 31 to 24 | Board number. The number of the processor board in a system with more than one board. |
|  | 39 to 32 | Box number, which box on a rack contains the processor. |
| 2 | 63 to 0 | Manufacturer name first eight chars |
| 3 | 63 to 0 | Manufacturer name |
| 4 | 63 to 0 | CPU class |
| 5 | 63 to 0 | CPU class |
| 6 | 63 to 0 | CPU Name |
| 7 | 63 to 0 | CPU Name |
| 8 | 63 to 0 | Model Number |
| 9 | 63 to 0 | Serial Number |
| 10 | 63 to 0 | Features bitmap |

## CSNZ – Conditional Set if Non-Zero

CSNZ Rt, Ra, #i20

CSNZ Rt, Ra, Rb

**Instruction Formats**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |  |
| 618 | ~6 | Rt6 | Rb6 | Ra6 | 028 | CSZ Rt,Ra,Rb |
| Immediate20 | | | Rt6 | Ra6 | 618 | CSZ Rt,Ra,#imm |

Operation:

Register Immediate Form

If Ra<>0

Rt = immediate

Register-Register Form

If Ra<>0

Rt = Rb

Notes***:***

The immediate constant may be extended up to 64 bits.

## CSR – Control and Status Register Update

Description:

This instruction atomically reads the CSR into a target register then sets it to either an immediate value supplied by the instruction or a value supplied by a register. Individual bits in the CSR may be set or cleared by the CSRRSI and CSRRCI instructions. Which CSR register to access may be specified by an immediate constant in the instruction, or by the contents of a register.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 3938 | 3736 | 35 22 | 21 14 | 13 8 | 7 0 |  |
| Op2 | 02 | CSR14 | Imm7..0 | Rt6 | 0Fh8 | CSRI8 |

Immediate to CSR #

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| Op2 | 12 | ~8 | Rt6 | Imm7..0 | Ra6 | 0Fh6 |  |

Immediate to CSR Ra

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Op2 | 22 | ~8 | Rt6 | ~2 | Rb6 | Ra6 | 0Fh6 |  |

Register to CSR Ra

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| Op2 | 32 | CSR14 | ~2 | Rt6 | Ra6 | 0Fh6 |  |

Register to CSR #

|  |  |  |
| --- | --- | --- |
| Op2 | Mne. | Description |
| 0 | CSRRWI | Write the entire value of immediate to the CSR |
| 1 | CSRRSI | Set the bits in the CSR according to the bits set in the immediate |
| 2 | CSRRCI | Clear the bits in the CSR according to the bits set in the immediate |
| 3 |  | not used |

Note that not all CSR’s support the CSRRS and CSRRC instructions.

CSR’s are determined by the lower 12 bits of the CSR field in the instruction. The upper two bits of the CSR field are reserved, and may be used in the future to resolve the core’s operating level.

## CSZ – Conditional Set if Zero

CSZ Rt, Ra, #i20

CSZ Rt, Ra, Rb

**Instruction Formats**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |  |
| 608 | ~6 | Rt6 | Rb6 | Ra6 | 028 | CSZ Rt,Ra,Rb |
| Immediate20 | | | Rt6 | Ra6 | 608 | CSZ Rt,Ra,#imm |

Operation:

Register Immediate Form

If Ra=0

Rt = immediate

Register-Register Form

If Ra=0

Rt = Rb

Notes***:***

The immediate constant may be extended up to 64 bits.

## DIV – Signed Division

DIV.T Rt, Ra, #i19

DIV.H Rt, Ra, Rb

Description:

**Instruction Formats**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 40 33 | 32 28 | 27 22 | 2120 | 19 14 | 13 8 | 7 0 |  |
| 18h8 | ~5 | Rt6 | S2 | Rb6 | Ra6 | 028 | DIV Rt,Ra,Rb |
| Immediate19 | | | S2 | Rt6 | Ra6 | 188 | DIV Rt,Ra,#imm |

Operation:

Register Immediate Form

Rt = Ra / immediate

Register-Register Form

Rt = Ra / Rb

Notes***:***

The immediate constant may be extended up to 64 bits.

The signed registered form of the instruction may generate a divide by zero exception if the divisor is zero. All other forms of the instruction including signed division by a constant never generate any exceptions.

|  |  |
| --- | --- |
| S2 | Operation |
| 0 | Wyde parallel |
| 1 | Tetra parallel |
| 2 | Octa parallel |
| 3 | Hexi |

## FBcc – Float Branch on Compare to Register

Description:

Branch if the floating point comparison condition between a register and another register value is true. The branch range is approximately +/- 256k bytes.

Instruction Formats:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Target18..0 | P2 | Rb6 | Ra6 | Opcode8 |

Operation:

if (Ra cond #imm)

pc <= pc + displacement

Clock Cycles: 3 if branch is taken, otherwise 1

Conditions:

|  |  |  |
| --- | --- | --- |
| Opcode8 | Mne. | Description |
| 36 | FBEQ | branch if equal |
| 37 | FBNE | not equal |
| 38 | FBLT | less than |
| 39 | FBGE | greater than or equal |
| 3A | FBLE | less than or equal |
| 3B | FBGT | greater than |
| 3C | FBOR | ordered |
| 3D | FBUN | unordered |

|  |  |
| --- | --- |
| P2 | Precision |
| 0 | single |
| 1 | double |
| 2 | reserved |
| 3 | quad |

## IMM – Immediate Postfix

IMM #i37

Instruction Formats:

|  |  |  |  |
| --- | --- | --- | --- |
| Constant36..4 | Ch4 | C4 | IMM |

Operation:

Notes:

The IMM prefix appends 37 bits onto the 19 bit constant field of the previous instruction then sign extends the resulting 56 bit constant out to 64 bits. Two immediate prefix instructions may be used in succession in order to append up to 64 bits onto the constant field of the following instruction. Thus a full 64 bit constant may be used by most instructions.

The immediate postfix may not be used to extend the range of a branch instruction. If there is an immediate postfix applied to an instruction that doesn’t use a constant, then the postfix will be ignored.

## INC – Increment memory word

INC d(Rn),#n

Instruction Formats:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Displacement15 | Imm5 | Ra5 | 647h | INC d15(Rn),#n |

Operation:

**Register Indirect with Displacement Form**

memory[displacement + Ra] = memory[displacement + Ra] + n

Notes:

Increments the memory word by a signed five bit immediate constant. The displacement constant may be extended up to 64 bits with immediate prefix instructions.

## JAL – Jump and Link

JAL Rd,(abs,Rn)

JAL Rd,d(Rn)

Instruction Formats:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Immed19 | ~2 | Rt6 | Ra6 | 40h8 | JAL |
| Immed19 | S2 | Rt6 | Ra6 | 41h8 | JALI |

Operation:

Memory Indexed Indirect Form

PC = memory[address + Rn]

Register Indirect with Displacement Form

PC = displacement + Rn

Notes:

The address constant may be extended up to 64 bits with immediate postfix instructions.

For the indirect form the S2 bits identify the size of the address value stored in memory. After loading the value from memory it is zero extended and combined with the upper bits of the program counter to form the final address.

|  |  |
| --- | --- |
| S2 | Meaning |
| 0 | wyde |
| 1 | tetra |
| 2 | octa |
| 3 | hexi |

## JMP – Jump

JMP (abs,Rn)

JMP d(Rn)

Instruction Formats:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Immed19 | ~2 | 06 | Ra6 | 40h8 | JMP |
| Immed19 | S2 | 06 | Ra6 | 41h8 | JMPI |

Operation:

Memory Indexed Indirect Form

PC = memory[address + Rn]

Register Indirect with Displacement Form

PC = displacement + Rn

Notes:

The address constant may be extended up to 64 bits with immediate postfix instructions.

This instruction is an alternate mnemonic for the JAL / JALI instruction, where the target register is specified as zero.

If Ra is specified as 63 then the current instruction address is used in forming the target address. This allows program counter relative addresses to be formed.

## LDB – Load Byte with Sign Extend

## LDBX – Load Byte with Sign Extend

LDB Rt, d(Rn)

LDB Rt, d(Ra + Rb \* scale)

**Description:**

This instruction loads an eight bit quantity into a register then sign extends the value to the width of the machine.

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| Displacement18 | | | ~2 | Rt6 | Ra6 | 80h8 | LDB Rt,d18(Rn) |
| Displacement8 | Sc3 | Rt7 | ~2 | Rb6 | Ra6 | A0h8 | LDB Rt,d(Ra+Rb\*sc) |

Operation:

Register Indirect with Displacement Form

Rt = sign extend(memory[displacement + Ra])

Register-Register Form

Rt = sign extend(memory[offset + Ra + Rb \* scale])

Notes:

The displacement constant may be extended up to 80. The offset constant for indexed mode may not be extended.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## LDBU – Load Byte with Zero Extend

## LDBUX – Load Byte with Zero Extend

LDBU Rt, d(Rn)

LDBU Rt, d(Ra + Rb \* scale)

**Description:**

This instruction loads an eight bit quantity into a register then zero extends the value to the width of the machine.

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| Displacement19 | | | ~2 | Rt6 | Ra6 | 81h8 | LDBU Rt,d20(Rn) |
| Displacement9 | Sc3 | Rt7 | ~2 | Rb6 | Ra6 | A1h8 | LDBU Rt,d(Ra+Rb\*sc) |

Operation:

Register Indirect with Displacement Form

Rt = sign extend(memory[displacement + Ra])

Register-Register Form

Rt = sign extend(memory[offset + Ra + Rb \* scale])

Notes:

The displacement constant may be extended up to 80. The offset constant for indexed mode may not be extended.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## LDD – Load Deci-byte with Sign Extend

## LDDX – Load Deci-byte with Sign Extend

LDD Rt, d(Rn)

LDD Rt, d(Ra + Rb \* scale)

Description:

This instruction loads an 80 bit value into a register and sign extends it to the register width.

Instruction Formats:

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | | | Rt6 | Ra6 | 86h8 | LDD Rt,d20(Rn) |
| Displacement11 | | Sc3 | Rt7 | | Rb6 | Ra6 | A6h8 | LDD Rt,d(Ra+Rb\*sc) |
|  | | | | Disp10 | | Rt6 | 72h8 |  |
|  | Displacement12 | | | | Rt6 | Ra6 | 73h8 |  |

Operation:

Register Indirect with Displacement Form

Rt = sign extend(memory[displacement + Ra])

Register-Register Form

Rt = sign extend(memory[offset + Ra + Rb \* scale])

Notes:

The displacement constant may be extended up to 80 bits with immediate prefix instructions. The offset constant for indexed mode may not be extended.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## LDP – Load Pentabyte with Sign Extend

## LDPX – Load Pentabyte with Sign Extend

LDP Rt, d(Rn)

LDP Rt, d(Ra + Rb \* scale)

Description:

This instruction loads a 40 bit value into a register and sign extends it to the register width.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rt6 | Ra6 | 84h8 | LDT Rt,d20(Rn) |
| Displacement11 | Sc3 | Rt7 | Rb6 | Ra6 | A4h8 | LDT Rt,d(Ra+Rb\*sc) |

Operation:

Register Indirect with Displacement Form

Rt = sign extend(memory[displacement + Ra])

Register-Register Form

Rt = sign extend(memory[offset + Ra + Rb \* scale])

Notes:

The displacement constant may be extended up to 80 bits with immediate prefix instructions. The offset constant for indexed mode may not be extended.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## LDPU – Load Pentabyte with Zero Extend

## LDPUX – Load Pentabyte with Zero Extend

LDPU Rt, d(Rn)

LDPU Rt, d(Ra + Rb \* scale)

Description:

This instruction loads a 40 bit value into a register and zero extends it to the register width.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rt6 | Ra6 | 85h8 | LDTU Rt,d19(Rn) |
| Displacement11 | Sc3 | Rt7 | Rb6 | Ra6 | A5h8 | LDTU Rt,d(Ra+Rb\*sc) |

Operation:

Register Indirect with Displacement Form

Rt = sign extend(memory[displacement + Ra])

Register-Register Form

Rt = sign extend(memory[offset + Ra + Rb \* scale])

Notes:

The displacement constant may be extended up to 80 bits with immediate prefix instructions. The offset constant for indexed mode may not be extended.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## LDVDAR – Load Volatile Deci-byte with Sign Extend and Reserve

## LDVDARX – Load Volatile Deci-byte with Sign Extend and Reserve

LDVDAR Rt, d(Rn)

LDVDAR Rt, d(Ra + Rb \* scale)

Description:

This instruction loads an 80 bit value into a register and sign extends it to the register width. In addition the memory reservation signal is activated.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rt6 | Ra6 | 8Eh8 | LDD Rt,d20(Rn) |
| Displacement11 | Sc3 | Rt7 | Rb6 | Ra6 | AEh8 | LDD Rt,d(Ra+Rb\*sc) |

Operation:

Register Indirect with Displacement Form

Rt = sign extend(memory[displacement + Ra])

Register-Register Form

Rt = sign extend(memory[offset + Ra + Rb \* scale])

Notes:

The displacement constant may be extended up to 80 bits with immediate prefix instructions. The offset constant for indexed mode may not be extended.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## LDW – Load Wyde with Sign Extend

## LDWX – Load Wyde with Sign Extend

LDW Rt, d(Rn)

LDW Rt, d(Ra + Rb \* scale)

**Description:**

This instruction loads a sixteen bit quantity into a register then sign extends it to the width of the register.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rt6 | Ra6 | 82h8 | LDW Rt,d20(Rn) |
| Displacement11 | Sc3 | Rt7 | Rb6 | Ra6 | A2h8 | LDW Rt,d(Ra+Rb\*sc) |

Operation:

Register Indirect with Displacement Form

Rt = sign extend(memory[displacement + Ra])

Register-Register Form

Rt = sign extend(memory[offset + Ra + Rb \* scale])

Notes:

The displacement constant may be extended up to 80. The offset constant for indexed mode may not be extended.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## LDWU – Load Wyde with Zero Extend

## LDWUX – Load Wyde with Zero Extend

LDWU Rt, d(Rn)

LDWU Rt, d(Ra + Rb \* scale)

**Description:**

This instruction loads a sixteen bit quantity into a register then zero extends it to the width of the register.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rt6 | Ra6 | 83h8 | LDWU Rt,d20(Rn) |
| Displacement11 | Sc3 | Rt7 | Rb6 | Ra6 | A3h8 | LDWU Rt,d(Ra+Rb\*sc) |

Operation:

Register Indirect with Displacement Form

Rt = sign extend(memory[displacement + Ra])

Register-Register Form

Rt = sign extend(memory[offset + Ra + Rb \* scale])

Notes:

The displacement constant may be extended up to 80. The offset constant for indexed mode may not be extended.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## LEA – Load Effective Address

LEA Rt,d(Ra)

LEA Rt, d(Ra + Rb \* scale)

**Description**

This instruction loads the effective address of a memory operand into a register.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rt6 | Ra6 | 26h8 | LEA Rt,d19(Rn) |
| Displacement11 | Sc3 | Rt6 | Rb6 | Ra6 | 27h8 | LEA Rt,d(Ra+Rb\*sc) |

Operation:

**Indexed Form**

Rt = address of (memory32[offset + Ra + Rb \* scale])

**Notes**:

This instruction loads the target register with the address of the memory determined by the indexing operation.

The displacement constant may be extended up to 80 bits with immediate postfix instructions.

|  |  |
| --- | --- |
| Sc3 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## MOV – Move Register to Register

Description:

The contents of the source register Ra are moved to the target register Rt.

Instruction Format:

|  |  |  |  |
| --- | --- | --- | --- |
| 23 20 | 19 14 | 13 8 | 7 0 |
| ~4 | Rt6 | Ra6 | 30h8 |

Clock Cycles: 1

Exceptions: none

## MUL - Multiplication

## MULU - Multiplication

MUL Rt, Ra, #i15

MUL Rt, Ra, Rb

MULU Rt, Ra, #i15

MULU Rt, Ra, Rb

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 077h | ~3 | Rb5 | Rt5 | Ra5 | 027 | MUL Rt,Ra,Rb |
| Immediate15 | | | Rt5 | Ra5 | 077 | MUL Rt,Ra,#imm |
| 177h | ~3 | Rb5 | Rt5 | Ra5 | 027 | MULU Rt,Ra,Rb |
| Immediate15 | | | Rt5 | Ra5 | 177 | MULU Rt,Ra,#imm |

Operation:

#### Register Immediate Form

Rt = Ra \* immediate15

#### Register-Register Form

Rt = Ra \* Rb

Notes:

The immediate constant may be extended up to 64 bits with immediate prefix instructions.

## MUX – Bitwise Multiplex

MUX Rt, Ra, Rb, Rc

**Desription:**

This instruction copies bits to the target register from either register Rb or Rc depending on the setting of the corresponding bit in register Ra. If a bit in Ra is set then the corresponding bit from Rb is copied to Rt, otherwise the corresponding bit from Rc is copied to Rt.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |  |
| 5Fh8 | Rt6 | Rc6 | Rb6 | Ra6 | 028 | MUX Rt,Ra,Rb,Rc |

Operation:

**Register-Register Form**

for bit = 0 to 79

Rt[bit] = Ra[bit] ? Rb[bit] : Rc[bit]

## POP – Pop Register from Stack

Instruction Format:

|  |  |  |
| --- | --- | --- |
| 1514 | 13 8 | 7 0 |
| ~2 | Rt6 | 71h8 |

Example:

POP r1

## PUSH – Push Register on Stack

Instruction Format:

|  |  |  |
| --- | --- | --- |
| 1514 | 13 8 | 7 0 |
| ~2 | Ra6 | 70h8 |

Example:

PUSH r1

## ROL – Rotate Left Register

Description:

Rotates the register to the left by an amount specified in either a second register or a constant in the instruction and place the result in the target register. Bit 63 is shifted into bit 0.

**Instruction Format**:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 32 | 31 28 | 27 22 | 2120 | 19 14 | 13 8 | 7 0 |  |
| 34h8 | ~4 | Rt6 | S2 | Rb6 | Ra6 | 028 | ROL Rt,Ra,Rb |
| 44h8 | ~4 | Rt6 | S2 | Immed6 | Ra6 | 028 | ROL Rt,Ra,#i6 |

**Operation:**

Rt = Ra << Rb

Clock Cycles: 1

Exceptions: none

Notes:

## ROR – Rotate Right

ROR Rt, Ra, #i6

ROR Rt, Ra, Rb

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 337 |  | | Rb5 | Rt5 | Ra5 | 027 | ROR |
| 3B7 |  | Imm6 | | Rt5 | Ra5 | 027 | ROR # |

Operation:

#### Register Immediate Form

Rt = Ra >> immediate6

#### Register-Register Form

Rt = Ra >> Rb

Notes:

Least significant bits are rotated into the most significant bits.

## RTD – Return from Debug

This instruction returns the processor from debug mode into the mode prior. The program counter is loaded with the value in the DBPC register.

## RTI – Return from Interrupt

This instruction returns the processor from kernel mode into the mode prior. The program counter is loaded with the value in the IPC register.

## RET – Return From Subroutine

RET #i16

**Description**

This instruction performs a return from subroutine operation. The program counter is loaded from the stack, then the stack pointer incremented by the amount specified in the instruction.

Instruction Formats:

|  |  |  |
| --- | --- | --- |
| Immediate16 | EFh8 | RET #i16 |

Operation:

PC = memory[SP]

SP = SP + Immediate

**Notes**:

The stack pointer may be adjusted in order to remove parameters from the stack. In assembler code if an immediate value is specified it must include ten bytes for popping the return address. By default the immediate value is set to ten.

## REX – Redirect Exception

Description:

This instruction redirects an exception from an operating level to a lower operating level and privilege level. If the target operating level is hypervisor then the hypervisor privilege level (1) is set. If the target operating level is supervisor then one of the supervisor privilege levels must be chosen (2 to 7). This instruction if successful jumps to the target exception handler and does not return. If this instruction fails execution will continue with the next instruction.

This instruction may fail if exceptions are not enabled at the target level.

When redirecting to the supervisor level, the target privilege level is set to the bitwise ‘or’ of an immediate constant specified in the instruction and register Ra. One of these two values should be zero. The result should be a value in the range 2 to 7.

The location of the target exception handler is found in the trap vector register for that operating level (stvec, htvec).

The cause (cause) and bad address (badaddr) registers of the originating level are copied to the corresponding registers in the target level.

The REX instruction automatically enables exceptions for operating levels higher (numerically lower than) than the target level.

Instruction Format:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 16 | 1514 | 13 8 | 7 0 |  |
| PL8 | Tgt2 | Ra6 | E2h8 | R2 |

|  |  |
| --- | --- |
| Tgt2 |  |
| 0 | not used |
| 1 | redirect to hypervisor level |
| 2 | redirect to supervisor level |
| 3 | not used |

Clock Cycles: 3

Example:

|  |
| --- |
| REX super,2,r0 ; redirect to supervisor handler, privilege level two  ; If the redirection failed, exceptions were likely disabled at the target level.  ; Continue processing so the target level may complete it’s operation.  IRET ; redirection failed (exceptions disabled ?) |

Notes:

Since all exceptions are initially handled at the machine level the machine level handler must check for disabled lower level exceptions.

## STB – Store Byte

## STBX – Store Byte

STB Rt, d(Rn)

STB Rt, d(Ra + Rb \* scale)

**Description**

This instruction stores a byte from a register to memory using either register indirect with displacement or scaled indexed addressing.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rs6 | Ra6 | 908h | STB Rs,d15(Rn) |
| Displacement11 | Sc3 | Rb6 | Rs6 | Ra6 | B08h | STB Rs,d(Ra+Rb\*sc) |

Operation:

**Register Indirect with Displacement Form**

memory[displacement + Ra] = Rs

**Register-Register Form**

memory[offset + Ra + Rb \* scale] = Rs

**Notes:**

The displacement constant may be extended up to 64 bits with immediate prefix instructions.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## STD – Store Deci-byte

## STDX – Store Deci-byte

STD Rt, d(Rn)

STD Rt, d(Ra + Rb \* scale)

**Description**

This instruction stores a deci-byte (80 bits) from a register to memory using either register indirect with displacement or scaled indexed addressing.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rs6 | Ra6 | 938h | STD Rs,d15(Rn) |
| Displacement11 | Sc3 | Rb6 | Rs6 | Ra6 | B38h | STD Rs,d(Ra+Rb\*sc) |

Operation:

**Register Indirect with Displacement Form**

memory[displacement + Ra] = Rs

**Register-Register Form**

memory[offset + Ra + Rb \* scale] = Rs

**Notes:**

The displacement constant may be extended up to 64 bits with immediate prefix instructions.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## STP – Store Penta

## STPX – Store Penta

STP Rt, d(Rn)

STP Rt, d(Ra + Rb \* scale)

**Description**

This instruction stores a penta-byte (40 bits) from a register to memory using either register indirect with displacement or scaled indexed addressing.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rs6 | Ra6 | 928h | STP Rs,d15(Rn) |
| Displacement11 | Sc3 | Rb6 | Rs6 | Ra6 | B28h | STP Rs,d(Ra+Rb\*sc) |

Operation:

**Register Indirect with Displacement Form**

memory[displacement + Ra] = Rs

**Register-Register Form**

memory[offset + Ra + Rb \* scale] = Rs

**Notes:**

The displacement constant may be extended up to 64 bits with immediate prefix instructions.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## STW – Store Wyde

## STWX – Store Wyde

STW Rt, d(Rn)

STW Rt, d(Ra + Rb \* scale)

**Description**

This instruction stores a wyde from a register to memory using either register indirect with displacement or scaled indexed addressing.

Instruction Formats:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement20 | | | Rs6 | Ra6 | 918h | STW Rs,d15(Rn) |
| Displacement11 | Sc3 | Rb6 | Rs6 | Ra6 | B18h | STW Rs,d(Ra+Rb\*sc) |

Operation:

**Register Indirect with Displacement Form**

memory[displacement + Ra] = Rs

**Register-Register Form**

memory[offset + Ra + Rb \* scale] = Rs

**Notes:**

The displacement constant may be extended up to 64 bits with immediate prefix instructions.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |
| 4 | 16 |

## SHL – Shift Left Register

Description:

Shift register to the left by an amount specified in either a second register or a constant in the instruction and place the result in the target register. A Zero is shifted into bit 0.

Instruction Format:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 40 33 | 32 28 | 27 22 | 2120 | 19 14 | 13 8 | 7 0 |  |
| 30h8 | ~5 | Rt6 | S2 | Rb6 | Ra6 | 028 | SHL Rt,Ra,Rb |
| 40h8 | ~5 | Rt6 | S2 | Immed6 | Ra6 | 028 | SHL Rt,Ra,#i6 |

Operation:

Rt = Ra << Rb

Clock Cycles: 1

Exceptions: none

## STOP – Stop Processor

STOP

This instruction stops the processor placing it in low power mode by stopping the processor clock. The clock rate register is loaded with zero. The processor may begin processing again once a non-maskable interrupt occurs or a reset occurs. The processor may be slowed down without stopping the clock by adjusting the value in the clock rate register.

## SWCR – Store Word and Clear Reservation

SWCR Rt, d(Rn)

Instruction Formats:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Displacement15 | Rs5 | Ra5 | 6E8h | SWCR Rs,d15(Rn) |

Operation:

#### Register Indirect with Displacement Form

if (address reserved)

memory[displacement + Ra] = Rs

cr0[36] = 1

else

cr0[36] = 0

Notes:

Conditionally store a word to memory if an address reservation is present. If successful bit 36 of cr0 will be set, otherwise bit 36 of cr0 will be cleared. This instruction sets the cr\_o signal during execution. The memory system must be capable of aborting the store if there is no reservation present.

The memory access does not need to be aligned, but unaligned accesses will take longer to complete.

The displacement constant may be extended up to 64 bits with immediate prefix instructions.

|  |  |
| --- | --- |
| Sc2 Code | Multiply By |
| 0 | 1 |
| 1 | 2 |
| 2 | 4 |
| 3 | 8 |

## SXB – Sign Extend Byte

SXB Rt, Ra

**Description**

This instruction sign extends a byte in a register to the width of the register. This instruction is an alternate mnemonic for the BFEXT instruction.

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 | 34 28 | 27 | 26 20 | 19 14 | 13 8 | 7 0 |
| 54 | ~1 | 77 | ~ | 07 | Rt6 | Ra6 | 13h8 |

Operation:

**Register Form**

Rt = sign extend (Ra)

Notes:

The most significant bits (8 to 63) are loaded with the sign extension of bit 7.

## SXW – Sign Extend Wyde

SXW Rt, Ra

**Description**

This instruction sign extends a wyde in a register to the width of the register. This instruction is an alternate mnemonic for the BFEXT instruction.

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 | 34 28 | 27 | 26 20 | 19 14 | 13 8 | 7 0 |
| 54 | ~1 | 157 | ~ | 07 | Rt6 | Ra6 | 13h8 |

Operation:

**Register Form**

Rt = sign extend (Ra)

Notes:

The most significant bits (16 to 63) are loaded with the sign extension of bit 15.

## SXT – Sign Extend Tetra

SXT Rt, Ra

**Description**

This instruction sign extends a tetra in a register to the width of the register. This instruction is an alternate mnemonic for the BFEXT instruction.

Instruction Formats:

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 | 34 28 | 27 | 26 20 | 19 14 | 13 8 | 7 0 |
| 54 | ~1 | 317 | ~ | 07 | Rt6 | Ra6 | 13h8 |

Operation:

**Register Form**

Rt = sign extend (Ra)

Notes:

The most significant bits (16 to 63) are loaded with the sign extension of bit 15.

## WAIT – Wait For Interrupt

WAIT

Instruction Formats:

|  |  |
| --- | --- |
| E38 | WAI |

Operation:

if (no interrupt)

PC = PC

else

PC = PC + 1

Notes:

This instruction waits for an interrupt to occur before proceeding..

## XOR – Bitwise Exclusive ‘Or’

XOR Rt, Ra, #i20

XOR Rt, Ra, Rb

**Instruction Formats**:

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 33 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |  |
| 0Ah8 | ~6 | Rt6 | Rb6 | Ra6 | 028 | XOR Rt,Ra,Rb |
| Immediate20 | | | Rt6 | Ra6 | 0A8 | XOR Rt,Ra,#imm |

Operation:

Register Immediate Form

Rt = Ra ^ immediate

Register-Register Form

Rt = Ra ^ Rb

Notes***:***

The immediate constant may be extended up to 64 bits.

## Floating Point Instruction Set

### FABS – Absolute Value

**Description:**

This instruction takes the absolute value of a double precision floating point number contained in a general purpose register. The sign bit of the number is cleared. The precision of the number is not affected and the number is not rounded.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 38 | 37 35 | 34 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| ~2 | Prec2 | Rm3 | Rt6 | 156 | ~6 | Ra6 | F1h8 |

**Clock Cycles:** 3

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FADD – Floating point addition

**Description:**

Add two floating point numbers in registers Ra and Rb and place the result into target register Rt.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 38 | 37 35 | 34 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| ~2 | Prec3 | Rm3 | Rt6 | 046 | Rb6 | Ra6 | F1h8 |

**Clock Cycles: 10**

**Execution Units:** All Floating Point

### FCMP - Float Compare

**Description:**

The register compare instruction compares two registers as floating point values and sets the flags in the target integer register as a result.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 38 | 37 35 | 34 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| ~2 | Prec3 | Rm3 | Rt6 | 066 | Rb6 | Ra6 | F1h8 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

if Ra < Rb

Rt[1]= true

else

Rt[1] = false

if mag Ra < mag Rb

Rt[2] = true

else

Rt[2] = false

if Ra = Rb

Rt[0] = true

else

Rt[0] = false

if Ra <= Rb

Rt[3] = true

else

Rt[3] = false

if unordered

Rt[4] = true

else

Rt[4] = false

### FCX – Clear Floating Point Exceptions

**Description:**

This instruction clears floating point exceptions. The Exceptions to clear are identified as the bits set in the union of register Ra and an immediate field in the instruction. Either the immediate or Ra should be zero.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 38 | 37 35 | 34 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| ~2 | Prec2 | Rm3 | ~6 | 216 | Immed6 | Ra6 | F1h8 |

**Execution Units:** All Floating Point

**Operation:**

**Exceptions:**

|  |  |
| --- | --- |
| Bit | Exception Enabled |
| 0 | global invalid operation clears the following:   * division of infinities * zero divided by zero * subtraction of infinities * infinity times zero * NaN comparison * division by zero |
| 1 | overflow |
| 2 | underflow |
| 3 | divide by zero |
| 4 | inexact operation |
| 5 | summary exception |

### FDIV – Floating point division

**Description:**

Divide two floating point numbers in registers Ra and Rb and place the result into target register Rt.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 38 | 37 35 | 34 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| ~2 | Prec3 | Rm3 | Rt6 | 096 | Rb6 | Ra6 | F1h8 |

**Clock Cycles: 56**

**Execution Units:** All Floating Point

### FSUB – Floating point subtraction

**Description:**

Subtract two floating point numbers in registers Ra and Rb and place the result into target register Rt.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 38 | 37 35 | 34 32 | 31 26 | 25 20 | 19 14 | 13 8 | 7 0 |
| ~2 | Prec3 | Rm3 | Rt6 | 056 | Rb6 | Ra6 | F1h8 |

**Clock Cycles: 5**

**Execution Units:** All Floating Point

### FTX – Trigger Floating Point Exceptions

**Description:**

This instruction triggers floating point exceptions. The Exceptions to trigger are identified as the bits set in the union of register Ra and an immediate field in the instruction. Either the immediate or Ra should be zero.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 3938 | 37 35 | 34 32 | 31 26 | 25 20 | 19 14 | 13 6 | 5 0 |
| ~2 | Prec3 | Rm3 | ~6 | 206 | Imm6 | Ra6 | F1h8 |

**Execution Units:** All Floating Point

**Operation:**

**Exceptions:**

|  |  |
| --- | --- |
| Bit | Exception Enabled |
| 0 | global invalid operation |
| 1 | overflow |
| 2 | underflow |
| 3 | divide by zero |
| 4 | inexact operation |
| 5 | reserved |

# Sample Code

## Register – Register Format Instructions

FISA64 includes a standard set of arithmetic and logical instructions including add / subtract / multiply/ divide / modulus / logical and / or / and exclusive or. Also present are shift instructions for both signed and unsigned operations.

The CMP instruction performs a signed comparison of two registers, or a register and immediate value and stores a -1, 0, or +1 in the target register if the first operand is less than, equal to or greater than the second operand respectively. The comparison result may be used by a following branch instruction. The CMPU instruction works the same way as CMP except that it performs an unsigned comparison. CMPU performs an unsigned comparison but produces a signed result.

Executing an RTI instruction enables interrupts. Interrupts may also be enabled and disabled with the CLI and SEI instructions. The RTI instruction also restored the processor mode (user or kernel) that was present before the interrupt. The processor does not support nested interrupts. However an interrupt may be processed during a software exception handler.

|  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Func7 | ~3 | | Rb5 | | | | Rt5 | Ra5 | 027 | {RR} |
| 007 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | NAND |
| 017 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | NOR |
| 027 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | ENOR |
| 047 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | ADD |
| 057 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | SUB |
| 067 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | CMP |
| 077 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | MUL |
| 087 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | DIV |
| 097 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | MOD |
| 0A7 |  | | ~5 | | | | Rt5 | Ra5 | 027 | NOT |
| 0C7 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | AND |
| 0D7 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | OR |
| 0E7 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | EOR |
| 107 |  | | ~ | | | | Rt6 | Ra6 | 027 | SXB |
| 117 |  | | ~ | | | | Rt6 | Ra6 | 027 | SXC |
| 127 |  | | ~ | | | | Rt6 | Ra6 | 027 | SXH |
| 147 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | ADDU |
| 157 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | SUBU |
| 167 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | CMPU |
| 177 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | MULU |
| 187 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | DIVU |
| 197 |  | | Rb5 | | | | Rt5 | Ra5 | 027 | MODU |
| 1A7 |  | | Rb6 | | | | Rc5 | Ra5 | 027 | CHK |
| 1E7 | Spr8 | | | | | | Rc5 | Ra5 | 027 | MTSPR |
| 1F7 | Spr8 | | | | | | Rt5 | Ra5 | 027 | MFSPR |
| 307 |  | | | Rb5 | | | Rt5 | Ra5 | 027 | SLL |
| 317 |  | | | Rb5 | | | Rt5 | Ra5 | 027 | SRL |
| 327 |  | | | Rb5 | | | Rt5 | Ra5 | 027 | ROL |
| 337 |  | | | Rb5 | | | Rt5 | Ra5 | 027 | ROR |
| 347 |  | | | Rb5 | | | Rt5 | Ra5 | 027 | SRA |
| 367 |  | | | ~ | | I4 | Rt5 | Ra5 | 027 | CPUID |
| 377 |  | | | 005 | | | 005 | ~5 | 027 | CLI |
| 377 |  | | | 015 | | | 005 | ~5 | 027 | SEI |
| 377 |  | | | 025 | | | 005 | ~5 | 027 | STP |
| 377 |  | | | 035 | | | 005 | ~5 | 027 | WAI |
| 377 |  | | | 1D5 | | | 1E5 | ~5 | 027 | RTD |
| 377 |  | | | 1E5 | | | 1E5 | ~5 | 027 | RTE |
| 377 |  | | | 1F5 | | | 1E5 | ~5 | 027 | RTI |
| Func7 |  | Imm6 | | | | | Rt5 | Ra5 | 027 | Shifts # |
| 387 |  | Imm6 | | | | | Rt5 | Ra5 | 027 | SLL # |
| 397 |  | Imm6 | | | | | Rt5 | Ra5 | 027 | SRL # |
| 3A7 |  | Imm6 | | | | | Rt5 | Ra5 | 027 | ROL # |
| 3B7 |  | Imm6 | | | | | Rt5 | Ra5 | 027 | ROR # |
| 3C7 |  | Imm6 | | | | | Rt5 | Ra5 | 027 | SRA # |
| 407 | Pred4 | | | | Succ4 | | 05 | ~5 | 027 | FENCE |

Floating Point

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| ~5 | Sz2 | rm3 | FPb5 | | FPt5 | FPa5 | 287 | FADD |
| ~5 | Sz2 | rm3 | FPb5 | | FPt5 | FPa5 | 297 | FSUB |
| ~5 | Sz2 | rm3 | FPb5 | | **Rt5** | FPa5 | 2A7 | FCMP |
| ~5 | Sz2 | rm3 | FPb5 | | FPt5 | FPa5 | 2B7 | FMUL |
| ~5 | Sz2 | rm3 | FPb5 | | FPt5 | FPa5 | 2C7 | FDIV |
| 607 | | ~3 | Sz2 | rm3 | FPt5 | FPa5 | 027 | FIX2FLT |
| 617 | | ~3 | Sz2 | rm3 | FPt5 | FPa5 | 027 | FLT2FIX |
| 627 | | ~3 | Sz2 | ~3 | FPt5 | FPa5 | 027 | FMOV |
| 637 | | ~3 | Sz2 | ~3 | FPt5 | FPa5 | 027 | FNEG |
| 647 | | ~3 | Sz2 | ~3 | FPt5 | FPa5 | 027 | FABS |
| 657 | | ~3 | ~2 | ~3 | **Rt5** | FPa5 | 027 | MFFP |
| 667 | | ~3 | Sz2 | ~3 | **Rt5** | FPa5 | 027 | MV2FIX |
| 1C7 | | ~3 | ~2 | ~3 | FPt5 | **Ra5** | 027 | MTFP |
| 1D7 | | ~3 | Sz2 | rm3 | FPt5 | **Ra5** | 027 | MV2FLT |

## Register – Immediate Format Instructions

There are signed and unsigned versions of instructions. The mnemonics of the unsigned instructions are post-fixed with a ‘U’.

ADD / SUB may generate an overflow exception when overflow occurs. ADDU / SUBU do not generate any exceptions.

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Immed15 | Rt5 | Ra5 | 047 | ADD # |
| Immed15 | Rt5 | Ra5 | 057 | SUB # |
| Immed15 | Rt5 | Ra5 | 067 | CMP # |
| Immed15 | Rt5 | Ra5 | 077 | MUL # |
| Immed15 | Rt5 | Ra5 | 087 | DIV # |
| Immed15 | Rt5 | Ra5 | 097 | MOD # |
| Immed15 | Rt5 | ~5 | 0A7 | LDI # |
| Immed15 | Rc5 | Ra5 | 0B7 | CHK # |
| Immed15 | Rt5 | Ra5 | 0C7 | AND # |
| Immed15 | Rt5 | Ra5 | 0D7 | OR # |
| Immed15 | Rt5 | Ra5 | 0E7 | EOR # |
| Immed15 | Rt5 | Ra5 | 147 | ADDU # |
| Immed15 | Rt5 | Ra5 | 157 | SUBU # |
| Immed15 | Rt5 | Ra5 | 167 | CMPU # |
| Immed15 | Rt5 | Ra5 | 177 | MULU # |
| Immed15 | Rt5 | Ra5 | 187 | DIVU # |
| Immed15 | Rt5 | Ra5 | 197 | MODU # |

### Bitfield Instruction Formats

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Bitfield | | | | | | |
| Op3 | me6 | mb6 | Rt5 | Ra5 | 037 | BtFld |
| 03 | me6 | mb6 | Rt5 | Ra5 | 037 | BFSET |
| 13 | me6 | mb6 | Rt5 | Ra5 | 037 | BFCLR |
| 23 | me6 | mb6 | Rt5 | Ra5 | 037 | BFCHG |
| 33 | me6 | mb6 | Rt5 | Ra5 | 037 | BFINS |
| 43 | me6 | mb6 | Rt5 | Imm5 | 037 | BFINSI |
| 53 | me6 | mb6 | Rt5 | Ra5 | 037 | BFEXT |
| 63 | me6 | mb6 | Rt5 | Ra5 | 037 | BFEXTU |
| 73 | me6 | mb6 | Rt5 | Ra5 | 037 |  |

## Flow Control Instructions

There are six relational branches which branch based on the result of a signed comparison of a register to zero. In order to branch based on an unsigned comparison, the CMPU instruction must be used prior to the branch. Since branches inherently compare a register to zero it is often possible to omit a preceding compare (CMP) operation. Branches branch relative to the program counter using a 16 bit signed displacement. This allows branching within +/- 32kB of the current program address.

Two conditional branch instructions (BEQ, BNE) have 16 bit instruction forms.

The subroutine call instruction (BSR) stores the return address in the default link register – R31. The target address is specified as a 26 bit displacement from the current program counter.

In order to jump to a routine whose target address is computed in a register at run time, the JAL instruction is provided.

The BRA instruction works the same way as the BSR instruction, but doesn’t store the return address.

The RTS instruction is used to return from a subroutine and de-allocate a stack frame at the same time. The RTS instruction has a 16 bit instruction format.

The BRK instruction is used to transfer control to a kernel mode BRK handler. This is the means to communicate with the operating system. Hardware interrupts force an appropriate BRK instruction into the instruction stream.

The NOP instruction doesn’t perform any operation.

### Flow Control Instruction Formats

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Flow Control | | | | | | | | |
| Disp15..1 | | | ~2 | | 03 | Ra5 | 3D7 | BEQ |
| Disp15..1 | | | ~2 | | 13 | Ra5 | 3D7 | BNE |
| Disp15..1 | | | ~2 | | 23 | Ra5 | 3D7 | BGT |
| Disp15..1 | | | ~2 | | 33 | Ra5 | 3D7 | BGE / BPL |
| Disp15..1 | | | ~2 | | 43 | Ra5 | 3D7 | BLT / BMI |
| Disp15..1 | | | ~2 | | 53 | Ra5 | 3D7 | BLE |
|  | | | | Dsp5..1 | | Ra5 | 327 | BEQ |
|  | | | | Dsp5..1 | | Ra5 | 337 | BNE |
| T2 | ~4 | Vector9 | ~5 | | | ~5 | 387 | BRK |
|  | | | | Vector9 | | | 357 | SYS |
|  | | | | 39 | | | 367 | INT #3 |
| Offset25..1 | | | | | | | 397 | BSR |
| Offset25..1 | | | | | | | 3A7 | BRA |
| Disp9..1 | | | 237 | BRA |
| Immed15 | | | 1F5 | | | ~5 | 277 | RTL |
|  | | | | Imm9 | | | 377 | RTL |
| Immed15 | | | 1F5 | | | ~5 | 3B7 | RTS |
|  | | | | Imm9 | | | 307 | RTS |
| Immed15 | | | Rt5 | | | Ra5 | 3C7 | JAL |
| Immed15 | | | Rt5 | | | Ra5 | 3E7 | JALI |
| ~25 | | | | | | | 3F7 | NOP |
| 09 | | | 367 | NOP |

Block Move Instruction Formats

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
|  | | | |  |  |  |  |
| 0 | ~8 | D | Sz | Rs 5 | Ra5 | 777 | SBI |
| 2 | ~8 | D | Sz | Rb5 | Ra5 | 777 | MBI |
|  | | | |  |  |  |  |
|  | | | |  |  |  |  |

## Memory Operate Instructions

|  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Memory | | | | | | | | 64 bit | |
| Disp15 | | | | Rt5 | | Ra5 | 407 | | LB |
| Disp15 | | | | Rt5 | | Ra5 | 417 | | LBU |
| Disp15 | | | | Rt5 | | Ra5 | 427 | | LC |
| Disp15 | | | | Rt5 | | Ra5 | 437 | | LCU |
| Disp15 | | | | Rt5 | | Ra5 | 447 | | LH |
| Disp15 | | | | Rt5 | | Ra5 | 457 | | LHU |
| Disp15 | | | | Rt5 | | Ra5 | 467 | | LW |
| Disp15 | | | | Rt5 | | Ra5 | 477 | | LEA |
| Offs8 | Sc2 | | Rb5 | Rt5 | | Ra5 | 487 | | LBX |
| Offs8 | Sc2 | | Rb5 | Rt5 | | Ra5 | 497 | | LBUX |
| Offs8 | Sc2 | | Rb5 | Rt5 | | Ra5 | 4A7 | | LCX |
| Offs8 | Sc2 | | Rb5 | Rt5 | | Ra5 | 4B7 | | LCUX |
| Offs8 | Sc2 | | Rb5 | Rt5 | | Ra5 | 4C7 | | LHX |
| Offs8 | Sc2 | | Rb5 | Rt5 | | Ra5 | 4D7 | | LHUX |
| Offs8 | Sc2 | | Rb5 | Rt5 | | Ra5 | 4E7 | | LWX |
| Offs8 | Sc2 | | Rb5 | Rt5 | | Ra5 | 4F7 | | LEAX |
| Disp15 | | | | Rt5 | | Ra5 | 5C7 | | LWAR |
| Disp4 | Rt5 | 5F7 | | LW |
| Disp15 | | | | Rs5 | | Ra5 | 607 | | SB |
| Disp15 | | | | Rs5 | | Ra5 | 617 | | SC |
| Disp15 | | | | Rs5 | | Ra5 | 627 | | SH |
| Disp15 | | | | Rs5 | | Ra5 | 637 | | SW |
| Disp15 | | | | Imm5 | | Ra5 | 647 | | INC |
| Disp15 | | | | ~5 | | Ra5 | 657 | | PEA |
| Disp15 | | | | ~5 | | Ra5 | 667 | | PUSH m |
| Offs8 | Sc2 | | Rb5 | Rs5 | | Ra5 | 687 | | SBX |
| Offs8 | Sc2 | | Rb5 | Rs5 | | Ra5 | 697 | | SCX |
| Offs8 | Sc2 | | Rb5 | Rs5 | | Ra5 | 6A7 | | SHX |
| Offs8 | Sc2 | | Rb5 | Rs5 | | Ra5 | 6B7 | | SWX |
| Disp15 | | | | Rst5 | | Ra5 | 6C7 | | CAS |
| Disp15 | | | | Rs5 | | Ra5 | 6E7 | | SWCR |
| Offs8 | Sc2 | Rb5 | | Imm5 | | Ra5 | 6F7 | | INCX |

FISA64 is a load / store / push / pop architecture.

There are two different instruction formats for memory operating instructions. These are register indirect with displacement format and scaled indexed addressing format. Operand sizes of byte (8 bit), character (16 bit), half-word (32 bit) and word (64 bits) are supported. Sign and zero extension on load is available.

Loads and stores do not have to be aligned, however unaligned access will require additional clock cycles to complete.

## Caveats

### Branches

Branch instructions can’t make proper use of an immediate prefix because they don’t detect an immediate prefix at the If stage in order to keep the hardware simpler. (There is no requirement for conditional branching more than 15 bits). However a branch instruction just uses the same immediate value that is calculated for other instructions in the EX stage. This could lead to branches branching to two different locations if an immediate prefix is used for a branch.

For example if a prefix is used with a branch, BEQ \*+$100010 for instance. Then the branch will branch to \*+$10 if it is predicted taken, but to \*+100010 if it’s predicted not taken, then taken later in the EX stage.

If the branch is predicted taken, it’ll branch using the 15 displacement field from the instruction. If the branch is predicted not taken, but is taken later in the EX stage, it’ll branch using the full immediate value, which with prefixes could be up to 64 bits. The solution is that the assembler never outputs branches with prefixes. There is no hardware protection against using an immediate prefix with a branch.

In the IF stage ,rather than look at the previous instructions for an immediate prefix, the processor simply ignores the fact a prefix is present, and sign extends the branch displacement in the instruction without taking into account a prefix.

IF stage:

if (iopcode==`Bcc && predict\_taken) begin

pc <= pc + {{47{insn[31]}},insn[31:17],2'b00}; // Ignores potential immediate prefix

dbranch\_taken <= TRUE;

end

However, the EX stage uses a full immediate including any prefix, also to simplify hardware.

EX stage:

`Bcc: if (takb & !xbranch\_taken)

update\_pc(xpc + {imm,2'b00}); // This uses a “full” immediate value

else if (!takb & xbranch\_taken)

update\_pc(xpc + 64'd4);

### Software Exceptions

For software type exceptions (divide by zero, overflow) the address stored in the EPC register is the address of the next instruction, not the current instruction address. The issue is that if a system call is being performed one wants to return the next instruction. Since system calls and other software exceptions share the same exception logic, for the usual usage the next instruction address is stored off. It is difficult to determine what the previous address might be as there could be a prefix instruction present.

### Other Limitations

The task register can be read in user mode. This allows an application program to identify where in memory task control information is located. Ideally a user mode application should not be able to find out where operating system data is located. The task register is disabled from being updated by a user mode application so that the task isn’t inadvertently incorrectly switched.

## Major Opcodes IR[7:0]

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | MFLT | {R1} | {R2} | {R3} | ADD # | SUB # | CMP # |  | AND # | OR # | XOR # | CHK # |  | {SYS} | \_16ADD # | CSR |
| 1x | MUL # | MULU # | MULSU # | {BITFIELD} | ADDU # | SUBU # | CMPU # |  | DIV # | DIVU # | DIVSU # | REM # | REMU # | REMSU # | \_8ADD # | \_10ADD # |
| 2x | MULH # | MULUH # | MULSUH # | {Shift} | SADD # | SSUB # | LEA | LEAX | DIVR # |  |  |  |  |  | \_4ADD # |  |
| 3x | MOV | ADD #i10 |  |  |  |  | FBEQ | FBNE | FBLT | FBGE | FBLE | FBGT | FBOR | FBUN | \_2ADD # |  |
| 4x | JMP | JMP () |  |  |  |  | BEQ | BNE | BLT | BGE | BLE | BGT | BLTU | BGEU | BLEU | BGTU |
| 5x | CALL | CALL () |  |  | BBC # | BBS # | BEQ # | BNE # | BLT # | BGE # | BLE # | BGT # | BLTU # | BGEU # | BLEU # | BGTU # |
| 6x | CSZ # | CSNZ # | CSN # | CSNN # | CSP # | CSNP # | CSOD # | CSEV # | ZSZ # | ZSNZ # | ZSN # | ZSNN # | ZNP # | ZSNP # | ZSOD # | ZSEV # |
| 7x | PUSH | POP | LDD [BP] | LDD12 |  |  | SEQ # | SNE # | SLT # | SGE # | SLE # | SGT # | SLTU # | SGEU # | SLEU # | SGTU # |
| 8x | LDB | LDBU | LDW | LDWU | LDP | LDPU | LDD | LDT | LDTU | LDVB | LDVW | LDVT | LDVD | LDVH | LDVDAR |  |
| 9x | STB | STW | STP | STD | STT | STDCR | INC |  |  |  |  |  | PEA |  |  |  |
| Ax | LDBX | LDBUX | LDWX | LDWUX | LDPX | LDPUX | LDDX | LDTX | LDTUX | LV | LVWS | LVX | LCL | CAS | LDVDARX |  |
| Bx | STBX | STWX | STPX | STDX | STTX | STDCRX | INCX |  |  | SV | SVWS | SVX |  |  | CACHE |  |
| Cx | IMMEDIATE EXTENSION | | | | | | | | | | | | | | | |
| Dx |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Ex |  | BRK | REX | WAI | RTI | MEMSB | MEMDB | SYNC | CLI | SEI | NOP | PUSHF | POPF |  |  | RET |
| Fx |  | {F1} | {F2} |  |  |  |  |  |  |  |  |  |  |  |  | MFLT |

## Major Functs IR[40:33] IR[7:0]=02

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x |  |  |  |  | ADD | SUB | CMP |  | AND | OR | XOR | CHK |  | {SYS} | \_16ADD |  |
| 1x | MUL | MULU | MULSU |  | ADDU | SUBU | CMPU |  | DIV | DIVU | DIVSU | REM | REMU | REMSU | \_8ADD |  |
| 2x | MULH | MULUH | MULSUH | LEAX | SADD | SSUB |  |  | DIVR |  |  |  |  |  | \_4ADD |  |
| 3x | SHL | SHRU | ASL | ASR | ROL | ROR |  |  |  |  |  |  |  |  | \_2ADD | ABS |
| 4x | SHL # | SHRU # | ASL # | ASR # | ROL # | ROR # |  |  | NAND | NOR | XNOR | ANDN | ORN |  | MIN | MAX |
| 5x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | MUX |
| 6x | CSZ | CSNZ | CSN | CSNN | CSP | CSNP | CSOD | CSEV | ZSZ | ZSNZ | ZSN | ZSNN | ZNP | ZSNP | ZSOD | ZSEV |
| 7x |  |  |  |  |  |  | SEQ | SNE | SLT | SGE | SLE | SGT | SLTU | SGEU | SLEU | SGTU |
| 8x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | RET |
| 9x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Ax |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bx |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Cx |  | | | | | | | | | | | | | | | |
| Dx |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Ex |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Fx |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## Float Ops IR[39:32] IR[7:0]=F1h

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x |  |  |  |  | FADD | FSUB | CMP |  | FMUL | FDIV |  | FCHK |  |  |  |  |
| 1x |  |  |  |  |  | FABS |  |  |  |  |  |  |  |  |  |  |
| 2x | FTX | FCX |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |