Thor Guide

This document contains information pertaining to the Thor processor including the instruction set and formats and softcore interfacing.

2016

robfinch@Finitron.ca

Finitron

1/1/2016

Table of Contents

[Overview 13](#_Toc448161133)

[Programming Model 13](#_Toc448161134)

[Design Objectives 13](#_Toc448161135)

[General Registers 14](#_Toc448161136)

[Code Address Registers 16](#_Toc448161137)

[Program Counter 17](#_Toc448161138)

[Predicates 18](#_Toc448161139)

[Predicate Conditions 18](#_Toc448161140)

[Compiler Usage 19](#_Toc448161141)

[Status Register (SR) 20](#_Toc448161142)

[Debug Address Register (61,0 to 61,3) 21](#_Toc448161143)

[Debug Control Register (61,4) 22](#_Toc448161144)

[Debug Status Register (61,5) 22](#_Toc448161145)

[Summary of Special Purpose Registers 23](#_Toc448161146)

[P0,P1,…P15 (PRED) 23](#_Toc448161147)

[C0,C1,…C15 (CREGS) – SPR #16 to 31 23](#_Toc448161148)

[ZS,DS,ES,FS,GS,HS,SS,CS (SREGS) – SPR #32 to 39 23](#_Toc448161149)

[LDT – SPR #40 23](#_Toc448161150)

[GDT – SPR #41 24](#_Toc448161151)

[SEGSW – SPR #43 24](#_Toc448161152)

[SEGBASE – SPR #44 24](#_Toc448161153)

[SEGLMT – SPR #45 24](#_Toc448161154)

[SEGACR – SPR #47 25](#_Toc448161155)

[KEYS – SPR #48 25](#_Toc448161156)

[TICK - SPR #50 25](#_Toc448161157)

[LC – SPR #51 25](#_Toc448161158)

[PREGS – SPR #52 25](#_Toc448161159)

[ASID – SPR #53 25](#_Toc448161160)

[Operating Modes 25](#_Toc448161161)

[Segmentation 27](#_Toc448161162)

[Overview 27](#_Toc448161163)

[Privilege levels 27](#_Toc448161164)

[Usage 27](#_Toc448161165)

[Software Support 27](#_Toc448161166)

[Address Formation: 28](#_Toc448161167)

[Selecting a segment register 28](#_Toc448161168)

[Selectors 28](#_Toc448161169)

[Non-Segmented Code Area 29](#_Toc448161170)

[Changing the Code Segment 29](#_Toc448161171)

[The Descriptor Table 29](#_Toc448161172)

[System Segment Descriptors 31](#_Toc448161173)

[Segment Load Exception 31](#_Toc448161174)

[Segment Bounds Exception 32](#_Toc448161175)

[Segment Usage Conventions 32](#_Toc448161176)

[Power-up State 32](#_Toc448161177)

[Segment Registers 32](#_Toc448161178)

[Memory Lot Protection System 34](#_Toc448161179)

[TLB – The Translation Lookaside Buffer 36](#_Toc448161180)

[Overview 36](#_Toc448161181)

[Size / Organization 36](#_Toc448161182)

[Updating the TLB 36](#_Toc448161183)

[TLB Registers 38](#_Toc448161184)

[TLBWired (#0h) 38](#_Toc448161185)

[TLBIndex (#1h) 38](#_Toc448161186)

[TLBRandom (#2h) 38](#_Toc448161187)

[TLBPageSize (#3h) 38](#_Toc448161188)

[TLBPhysPage (#5h) 38](#_Toc448161189)

[TLBVirtPage (#4h) 39](#_Toc448161190)

[TLBASID (#7h) 39](#_Toc448161191)

[Memory Operations: 40](#_Toc448161192)

[Basic Operations 40](#_Toc448161193)

[Memory Addressing Modes 40](#_Toc448161194)

[Pre-fetching data 41](#_Toc448161195)

[Bypassing the Data Cache 41](#_Toc448161196)

[Push Operations 42](#_Toc448161197)

[Load Speculation 42](#_Toc448161198)

[Store Issuing 42](#_Toc448161199)

[Atomic Operations 42](#_Toc448161200)

[Address Reservation 42](#_Toc448161201)

[Synchronization Operations 42](#_Toc448161202)

[Exceptions 43](#_Toc448161203)

[Precision 43](#_Toc448161204)

[Nesting 43](#_Toc448161205)

[Vectors 43](#_Toc448161206)

[Vector table: 43](#_Toc448161207)

[Hardware Interrupts 45](#_Toc448161208)

[Interrupt Enable Delay 45](#_Toc448161209)

[Hardware Ports 46](#_Toc448161210)

[Reset 46](#_Toc448161211)

[Clock Cycle Counts 47](#_Toc448161212)

[Core Parameters 48](#_Toc448161213)

[Configuration Defines 48](#_Toc448161214)

[Instruction Formats 49](#_Toc448161215)

[RR - Register-Register 49](#_Toc448161216)

[RI - Register-Immediate 49](#_Toc448161217)

[CMP Register-Register Compare 49](#_Toc448161218)

[CMPI Register-Immediate Compare 49](#_Toc448161219)

[TST - Register Test Compare 49](#_Toc448161220)

[CTRL/RTx- Control 49](#_Toc448161221)

[BR - Relative Branch 49](#_Toc448161222)

[BRK/NOP 49](#_Toc448161223)

[JSR - Jump To Subroutine 49](#_Toc448161224)

[Instruction Set Summary 51](#_Toc448161225)

[Illegal Instructions 51](#_Toc448161226)

[Branch Instructions 51](#_Toc448161227)

[Branch Speculation 51](#_Toc448161228)

[Loops 51](#_Toc448161229)

[Subroutine Call / Return 51](#_Toc448161230)

[Comparison Operations 51](#_Toc448161231)

[Arithmetic Operations 52](#_Toc448161232)

[Bitwise Operations 52](#_Toc448161233)

[Logical Operations 52](#_Toc448161234)

[Detailed Instruction Set 53](#_Toc448161235)

[2ADDU - Register-Register 53](#_Toc448161236)

[2ADDUI - Register-Immediate 54](#_Toc448161237)

[4ADDU - Register-Register 55](#_Toc448161238)

[4ADDUI - Register-Immediate 56](#_Toc448161239)

[8ADDU - Register-Register 57](#_Toc448161240)

[8ADDUI - Register-Immediate 58](#_Toc448161241)

[16ADDU - Register-Register 59](#_Toc448161242)

[16ADDUI - Register-Immediate 60](#_Toc448161243)

[ABS – Absolute Value Register 61](#_Toc448161244)

[ADD - Register-Register 62](#_Toc448161245)

[ADDI - Register-Immediate 63](#_Toc448161246)

[ADDU - Register-Register 64](#_Toc448161247)

[ADDUI - Register-Immediate 65](#_Toc448161248)

[AND - Register-Register 66](#_Toc448161249)

[ANDC – And with Compliment 67](#_Toc448161250)

[ANDI - Register-Immediate 68](#_Toc448161251)

[BCDADD - Register-Register 69](#_Toc448161252)

[BCDMUL - Register-Register 70](#_Toc448161253)

[BCDSUB - Register-Register 71](#_Toc448161254)

[BFCHG – Bit-field Change 72](#_Toc448161255)

[BFCLR – Bit-field Clear 73](#_Toc448161256)

[BFEXT – Bit-field Extract 74](#_Toc448161257)

[BFEXTU – Bit-field Extract Unsigned 75](#_Toc448161258)

[BFINS – Bit-field Insert 76](#_Toc448161259)

[BFINSI – Bit-field Insert Immediate 77](#_Toc448161260)

[BFSET – Bit-field Set 78](#_Toc448161261)

[BITI – Test bits Register-Immediate 79](#_Toc448161262)

[BR - Relative Branch 80](#_Toc448161263)

[BRK –Break 81](#_Toc448161264)

[BSR - Branch to Subroutine 82](#_Toc448161265)

[CACHE – Cache Command 83](#_Toc448161266)

[CAS – Compare and Swap 84](#_Toc448161267)

[CHKI - Register-Immediate 85](#_Toc448161268)

[CHKX- Register-Register 86](#_Toc448161269)

[CHKXI - Register-Immediate 87](#_Toc448161270)

[CLI – Clear Interrupt Mask 88](#_Toc448161271)

[CMP Register-Register Compare 89](#_Toc448161272)

[CMPI Register-Immediate Compare 90](#_Toc448161273)

[CNTLO- Count Leading Ones 91](#_Toc448161274)

[CNTLZ- Count Leading Zeros 92](#_Toc448161275)

[CNTPOP- Population Count 93](#_Toc448161276)

[COM – Bitwise Compliment 94](#_Toc448161277)

[CPUID – CPU Identification 95](#_Toc448161278)

[DIV - Register-Register Divide 96](#_Toc448161279)

[DIVI - Register-Immediate Divide 97](#_Toc448161280)

[DIVIU – Unsigned Register-Immediate Divide 99](#_Toc448161281)

[DIVU – Unsigned Register-Register Divide 100](#_Toc448161282)

[ENOR - Register-Register 101](#_Toc448161283)

[EOR - Register-Register 102](#_Toc448161284)

[EORI - Register-Immediate 103](#_Toc448161285)

[INC – Increment Memory 104](#_Toc448161286)

[IMM64,IMM56,IMM48,IMM40,IMM32,IMM24,IMM16 105](#_Toc448161287)

[INT –Interrupt 106](#_Toc448161288)

[JCI, JCIX – Jump Character Indirect 107](#_Toc448161289)

[JHI, JHIX – Jump Half-word Indirect 109](#_Toc448161290)

[JMP - Jump To Address 110](#_Toc448161291)

[JSF – Jump to Far Subroutine 111](#_Toc448161292)

[JSR - Jump To Subroutine 112](#_Toc448161293)

[JWI, JWIX – Jump Word Indirect 113](#_Toc448161294)

[LB – Load Byte 114](#_Toc448161295)

[LBU – Load Byte Unsigned 115](#_Toc448161296)

[LBUX – Load Byte Unsigned Indexed 116](#_Toc448161297)

[LBX – Load Byte Indexed 117](#_Toc448161298)

[LC – Load Character 118](#_Toc448161299)

[LCL – Load Cache Line 119](#_Toc448161300)

[LCU – Load Character Unsigned 120](#_Toc448161301)

[LCUX – Load Character Unsigned Indexed 121](#_Toc448161302)

[LCX – Load Character Indexed 122](#_Toc448161303)

[LDI - Load-Immediate 123](#_Toc448161304)

[LDIS - Load-Immediate Special 124](#_Toc448161305)

[LEA – Load Effective Address 125](#_Toc448161306)

[LEAX – Load Effective Address Indexed 126](#_Toc448161307)

[LH – Load Half-Word 127](#_Toc448161308)

[LHU – Load Half-word Unsigned 129](#_Toc448161309)

[LHUX – Load Half-word Unsigned Indexed 130](#_Toc448161310)

[LHX – Load Half-word Indexed 131](#_Toc448161311)

[LLA – Load Linear Address 132](#_Toc448161312)

[LLAX – Load Linear Address Indexed 133](#_Toc448161313)

[LOOP – Loop Branch 134](#_Toc448161314)

[LVB – Load Volatile Byte 135](#_Toc448161315)

[LVC – Load Volatile Character 136](#_Toc448161316)

[LVH – Load Volatile Half-word 137](#_Toc448161317)

[LVW – Load Volatile Word 138](#_Toc448161318)

[LVWAR – Load Volatile Word and Reserve 139](#_Toc448161319)

[LW – Load Word 140](#_Toc448161320)

[LWS – Load Word Special 141](#_Toc448161321)

[LWX – Load Word Indexed 142](#_Toc448161322)

[MAX - Register-Register 143](#_Toc448161323)

[MEMDB – Memory Data Barrier 144](#_Toc448161324)

[MEMSB – Memory Synchronization Barrier 145](#_Toc448161325)

[MFSPR – Special Register-Register 146](#_Toc448161326)

[MIN - Register-Register 147](#_Toc448161327)

[MLO – Mystery Logical Operation 148](#_Toc448161328)

[MODI –Register-Immediate Modulus 149](#_Toc448161329)

[MODUI – Unsigned Register-Immediate Modulus 150](#_Toc448161330)

[MOV - Register-Register 151](#_Toc448161331)

[MOVS – Move Special Register- Special Register 152](#_Toc448161332)

[MTSPR –Register-Special Register 153](#_Toc448161333)

[MUL - Register-Register Multiply 154](#_Toc448161334)

[MULI - Register-Immediate Multiply 155](#_Toc448161335)

[MULU – Unsigned Register-Register Multiply 156](#_Toc448161336)

[MULUI – Unsigned Register-Immediate Multiply 157](#_Toc448161337)

[MUX – Multiplex 158](#_Toc448161338)

[NAND - Register-Register 159](#_Toc448161339)

[NEG - Negate Register 160](#_Toc448161340)

[NOP – No Operation 161](#_Toc448161341)

[NOR - Register-Register 162](#_Toc448161342)

[NOT – Logical Not 163](#_Toc448161343)

[OR - Register-Register 164](#_Toc448161344)

[ORC – Or with Compliment 165](#_Toc448161345)

[ORI - Register-Immediate 166](#_Toc448161346)

[PAND – Predicate And 167](#_Toc448161347)

[PANDC – Predicate And Compliment 168](#_Toc448161348)

[PEOR – Predicate Exclusive Or 169](#_Toc448161349)

[PENOR – Predicate Exclusive Nor 170](#_Toc448161350)

[PNAND – Predicate Nand 171](#_Toc448161351)

[POR – Predicate Or 172](#_Toc448161352)

[PORC – Predicate Or Compliment 173](#_Toc448161353)

[PNOR – Predicate Nor 174](#_Toc448161354)

[ROL – Rotate Left 175](#_Toc448161355)

[ROLI – Rotate Left by Immediate 176](#_Toc448161356)

[ROR – Rotate Right 177](#_Toc448161357)

[RORI – Rotate Right by Immediate 178](#_Toc448161358)

[RTD – Return from Debug Exception Routine 179](#_Toc448161359)

[RTE – Return from Exception Routine 180](#_Toc448161360)

[RTF – Return from Far Subroutine 181](#_Toc448161361)

[RTI – Return from Interrupt Routine 182](#_Toc448161362)

[RTS – Return from Subroutine 183](#_Toc448161363)

[SB – Store Byte 184](#_Toc448161364)

[SBX – Store Byte Indexed 185](#_Toc448161365)

[SC – Store Character 186](#_Toc448161366)

[SCX – Store Character Indexed 187](#_Toc448161367)

[SEI – Set Interrupt Mask 188](#_Toc448161368)

[SH – Store Half-word 189](#_Toc448161369)

[SHL – Shift Left 190](#_Toc448161370)

[SHLI – Shift Left by Immediate 191](#_Toc448161371)

[SHLU – Shift Left Unsigned 192](#_Toc448161372)

[SHLUI – Shift Left Unsigned by Immediate 193](#_Toc448161373)

[SHR – Shift Right 194](#_Toc448161374)

[SHRI – Shift Right by Immediate 195](#_Toc448161375)

[SHRU – Shift Right Unsigned 196](#_Toc448161376)

[SHRUI – Shift Right Unsigned by Immediate 197](#_Toc448161377)

[SHX – Store Half-word Indexed 198](#_Toc448161378)

[STCMP – String Compare 199](#_Toc448161379)

[STFND – String Find 200](#_Toc448161380)

[STI – Store Immediate 201](#_Toc448161381)

[STIX – Store Immediate Indexed 202](#_Toc448161382)

[STMOV – String Move 203](#_Toc448161383)

[STP – Stop / Slow Down 204](#_Toc448161384)

[STSB – Store String Byte 205](#_Toc448161385)

[STSC – Store String Character 206](#_Toc448161386)

[STSET – String Set 207](#_Toc448161387)

[STSH – Store String Half-word 208](#_Toc448161388)

[STSW – Store String Word 209](#_Toc448161389)

[SUB - Register-Register 210](#_Toc448161390)

[SUBI - Register-Immediate 211](#_Toc448161391)

[SUBU - Register-Register 212](#_Toc448161392)

[SUBUI - Register-Immediate 213](#_Toc448161393)

[SW – Store Word 214](#_Toc448161394)

[SWCR – Store Word and Clear Reservation 215](#_Toc448161395)

[SWS – Store Word Special 216](#_Toc448161396)

[SWX – Store Word Indexed 217](#_Toc448161397)

[SXB – Sign Extend Byte 218](#_Toc448161398)

[SXC – Sign Extend Character 219](#_Toc448161399)

[SXH – Sign Extend Half-word 220](#_Toc448161400)

[SYNC – Synchronization Barrier 221](#_Toc448161401)

[SYS –Call system routine 222](#_Toc448161402)

[TLB – TLB Command 223](#_Toc448161403)

[TST - Register Test Compare 225](#_Toc448161404)

[ZXB – Zero Extend Byte 226](#_Toc448161405)

[ZXC – Zero Extend Character 227](#_Toc448161406)

[ZXH – Zero Extend Half-word 228](#_Toc448161407)

[Stack Operations 229](#_Toc448161408)

[LINK – Link Stack 230](#_Toc448161409)

[PEA – Push Effective Address 231](#_Toc448161410)

[POP – Pop Register 232](#_Toc448161411)

[PUSH – Push Register 233](#_Toc448161412)

[UNLINK – Unlink Stack 234](#_Toc448161413)

[Floating Point 235](#_Toc448161414)

[Operations Supported 235](#_Toc448161415)

[Representation 236](#_Toc448161416)

[Performance 236](#_Toc448161417)

[Floating Point Instruction Set 237](#_Toc448161418)

[FABS – Absolute Value 237](#_Toc448161419)

[FABS.S – Single Precision Absolute Value 238](#_Toc448161420)

[FADD – Floating point addition 239](#_Toc448161421)

[FADD.S – Floating Point Single Precision addition 240](#_Toc448161422)

[FCMP - Float Compare 241](#_Toc448161423)

[FCMP.S - Float Compare Single 242](#_Toc448161424)

[FDIV – Floating point division 243](#_Toc448161425)

[FDIV.S – Single Precision Floating point division 244](#_Toc448161426)

[FCX – Clear Floating Point Exceptions 245](#_Toc448161427)

[FDX – Disable Floating Point Exceptions 246](#_Toc448161428)

[FEX – Enable Floating Point Exceptions 247](#_Toc448161429)

[FTX – Trigger Floating Point Exceptions 248](#_Toc448161430)

[FMAC – Floating Point Multiply Accumulate (planned) 249](#_Toc448161431)

[FMAN – Mantissa of Number 250](#_Toc448161432)

[FMAN.S – Mantissa of Number 251](#_Toc448161433)

[FMOV – Move Double Precision 252](#_Toc448161434)

[FMOV.S – Move Single Precision 253](#_Toc448161435)

[FMUL – Floating point multiplication 254](#_Toc448161436)

[FMUL.S – Single Precision Floating point multiplication 255](#_Toc448161437)

[FNEG – Negate Register 256](#_Toc448161438)

[FNEG.S – Negate Single Precision 257](#_Toc448161439)

[FRM – Set Floating Point Rounding Mode 258](#_Toc448161440)

[FSIGN – Sign of Number 259](#_Toc448161441)

[FSIGN.S – Single Precision Sign of Number 260](#_Toc448161442)

[FSTAT – Get Floating Point Status and Control 261](#_Toc448161443)

[FSUB – Floating point subtraction 263](#_Toc448161444)

[FSUB.S – Single Precision Floating point subtraction 264](#_Toc448161445)

[FTOI – Float to Integer 265](#_Toc448161446)

[FTOI.S – Single Precision Float to Integer 266](#_Toc448161447)

[FTST – Float Register Test Compare 267](#_Toc448161448)

[FTST.S – Float Single Test Compare 268](#_Toc448161449)

[ITOF – Integer to Float 269](#_Toc448161450)

[ITOF.S – Integer to Float Single 270](#_Toc448161451)

[Vector Programming Model 271](#_Toc448161452)

[Vector Length (VL register) 271](#_Toc448161453)

[Vector Predicates 272](#_Toc448161454)

[Predicate Conditions 272](#_Toc448161455)

[Detailed Vector Instruction Set 273](#_Toc448161456)

[VADD 273](#_Toc448161457)

[VADDS 274](#_Toc448161458)

[VAND 275](#_Toc448161459)

[VANDS 276](#_Toc448161460)

[VBITS2V 277](#_Toc448161461)

[VCMP 278](#_Toc448161462)

[VCMPS 279](#_Toc448161463)

[VEINS / VMOVSV 280](#_Toc448161464)

[VEOR 281](#_Toc448161465)

[VEORS 282](#_Toc448161466)

[VDIV 283](#_Toc448161467)

[VDIVS 284](#_Toc448161468)

[VEX / VMOVS 285](#_Toc448161469)

[VFLT2INT 286](#_Toc448161470)

[VINT2FLT 287](#_Toc448161471)

[LV 288](#_Toc448161472)

[LVWS 289](#_Toc448161473)

[LVX 290](#_Toc448161474)

[VMAC 292](#_Toc448161475)

[VMUL 293](#_Toc448161476)

[VMULS 294](#_Toc448161477)

[VOR 295](#_Toc448161478)

[VORS 296](#_Toc448161479)

[VREC 297](#_Toc448161480)

[VSHLV 298](#_Toc448161481)

[VSHRV 299](#_Toc448161482)

[SV 300](#_Toc448161483)

[SVWS 301](#_Toc448161484)

[SVX 302](#_Toc448161485)

[VSUB 303](#_Toc448161486)

[VSUBS 304](#_Toc448161487)

[VSUBRS 305](#_Toc448161488)

[V2BITS 306](#_Toc448161489)

[Opcode Map 308](#_Toc448161490)

# Overview

Thor is a powerful 64 bit superscalar processor that represents a generational refinement of processor architecture. The processor contains 64, 64 bit general purpose integer registers. Thor uses variable length instructions varying between one and eight bytes in length and handles 8, 16, 32, and 64 bit data within a 64 bit address space.

# Programming Model

## Design Objectives

This processor is somewhat pedantic in nature and targeted towards high performance operation as a general purpose processor. Following are some of the criteria that were used on which to base the design.

|  |
| --- |
| * Designed for Superscalar operation - the ability to execute more than one instruction at a time. To achieve high performance it is generally accepted that a processor must be able to execute more than a single instruction in any given clock cycle. |
| * Simplicity - architectural simplicity leads to a design that is easy to implement resulting in reliability and assured correctness along with easy implementation of supporting tools such as compilers. Simplicity also makes it easier to obtain high performance and results in lower overall cost. |
| * Extensibility - the design must be extensible so that features not present in the first release can easily be added at a later date. |
| * Low Cost |

This design meets the above objectives in the following ways. The instruction set has been designed to minimize the interactions between instructions, allowing instructions to be executed as independent units for superscalar operation. There are a sufficient number of registers to allow the compiler to schedule parallel processing of code. A reasonably large general purpose register set is available making the design reasonably compatible with many existing compilers and assemblers. Where needed, additional specialized instructions have been added to the processor to support a sophisticated operating system and interrupt management.

## General Registers

There are 64 general purpose registers. General purpose registers are 64 bits wide. The general registers may hold integer or floating point values.

Register #0 is always zero.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
|  |  |  |  |  |  |
| r0 | always zero |  |  | LC | Loop Counter |
| r1 | return value |  |  |  |  |
| r2 | return value |  |  | C0 | always zero |
| r3 | temporary register caller save |  |  | C1 | return address |
| r4 | temporary register |  |  | C2 |  |
| r5 | temporary register |  |  | C3 |  |
| r6 | temporary register |  |  | C4 |  |
| r7 | temporary register |  |  | C5 |  |
| r8 | temporary register |  |  | C6 |  |
| r9 | temporary register |  |  | C7 |  |
| r10 | temporary register |  |  | C8 |  |
| r11 | register var callee save |  |  | C9 |  |
| r12 | register var |  |  | C10 | catch link address |
| r13 | register var |  |  | C11 | debug return address |
| r14 | register var |  |  | C12 | exception table pointer |
| r15 | register var |  |  | C13 | exceptioned PC |
| r16 | register var |  |  | C14 | interrupted PC |
| r17 | register var |  |  | C15 | program counter, read only |
| r18 | register var |  |  |  |  |
| r19 |  |  |  | ZS | zero segment |
| r20 |  |  |  | DS | data segment |
| r21 |  |  |  | ES | extra segment |
| r22 |  |  |  | FS |  |
| r24 | Type number |  |  | GS |  |
| r25 | Class Pointer |  |  | HS |  |
| r26 | Base Pointer |  |  | SS | stack segment |
| r27 | User Stack Pointer1 |  |  | CS | code segment |
| r28 | Interrupt Stack Pointer |  |  |  |  |
| r29 | Exception Stack Pointer |  |  | DBAD0 | Debug Address #0 |
| r30 | Debug Stack Pointer |  |  | DBAD1 | Debug address #1 |
| r31 | Kernel task register |  |  | DBAD2 | Debug address #2 |
| r32/F0 | Floating point |  |  | DBAD3 | Debug Address #3 |
| … |  |  |  | DBCTRL | Debug Control |
| r63/F31 |  |  |  | DBSTAT | Debug Status |

1 this register is implied in the push and rts instructions, and updated by hardware

r27 is special in that it refers to one of r27, r28, r29, or r30 depending on the operating mode of the core. This allows the same code to be reused in different operating modes. For instance loading r27 while in debug mode will actually load r30 and all references to r27 will be rerouted to r30 in debug mode.

### Register Sets

Thor supports multiple general purpose register sets. There are up to eight sets of registers. It’s no more expensive in the FPGA to support multiple register sets than it is to support a single set. The RAM resources required of the FPGA are the same up to a point. For interrupt processing the register set is automatically switched to register set #7 when a hardware interrupt occurs. The register set is automatically switched back to the prior set on interrupt return (RTI). Which register set is active is controlled by a field in the status register.

Note that this is the only case where the register set is switched automatically. Other software exceptions do not switch the register set (SYS).

If the interrupt routine is simple enough there’s no need to save / restore registers. They can just be used as the following example shows.

|  |
| --- |
| ;----------------------------------------------------------------------------  ; Millisecond (1024 Hz) interrupt routine.  ;----------------------------------------------------------------------------  ;  msi\_rout:  ; reset the edge sense circuit to re-enable interrupts  ldi r1,#1  sh r1,zs:PIC\_ESR  ; update milliseconds  lw r1,zs:Milliseconds  addui r1,r1,#1  sw r1,zs:Milliseconds  rti |

Note that only the general purpose registers have multiple register sets. The remaining registers of the programming model do not. For instance if it’s desirable to call a subroutine the subroutine return address register must be saved and restored.

Note that if the register set is switched a jump instruction (not a branch) should be used to flush the core’s pipeline before the new register set can be used.

## Code Address Registers

The processor contains sixteen code address registers (C0-C15). Several of the registers are reserved for predefined purposes. A code address register is used in the formation and storage of code addresses.

|  |  |  |
| --- | --- | --- |
| Reg # |  | Usage |
| 0 | Always Zero | Absolute address formation |
| 1 |  | Subroutine return address |
| 2 |  | This register is available for general use. |
| 3 |  | This register is available for general use. |
| 4 |  | This register is available for general use. |
| 5 |  |  |
| 6 |  |  |
| 7 |  |  |
| 8 |  |  |
| 9 |  |  |
| 10 | Catch Link Register | Used by the compiler to link to try/catch handlers. |
| 11 | Debug Exception PC | This register is set when a debug exception occurs |
| 12 | Exception Table Pointer | This register points to the exception table in memory. |
| 13 | Exceptioned PC | This register is set when an exception occurs |
| 14 | Interrupted PC | This register is automatically set during a hardware interrupt |
| 15 | Program Counter | Relative address formation. |

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

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

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

Setting of code address register #12 should be followed with a [SYNC](#_SYNC_–_Synchronization) instruction. The core assumes c12 is essentially static and does not provide full bypassing for this register. The register value may be stale until the sync instruction executes.

### Program Counter

|  |  |
| --- | --- |
| 63 32 | 31 0 |
| Program Bank | Program Counter |

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

## Predicates

The processor features predicated execution of all instructions. Whether or not an instruction is executed depends on the contents of a predicate register and the predicate condition specified in the predicate byte. There are 16 predicate registers each of which hold three flags. These flags are set as the result of a compare operation. The flags represent equality (eq) signed less than (lt) and unsigned less than (ltu).

|  |  |  |  |
| --- | --- | --- | --- |
| 3 | 2 | 1 | 0 |
| ~ | ltu | lt | eq |

All instructions are executed conditionally determined by the value of a predicate register. The special predicate 00 executes the break vector.

### Predicate Conditions

|  |  |  |  |
| --- | --- | --- | --- |
| Cond. |  | Test |  |
| 0 | PF | 0 | Always false – Instructions predicated with condition zero never execute regardless of the predicate register contents. This is used for extended immediate values as well. The false predicate byte for instructions is 90h. |
| 1 | PT | 1 | Always True – The instruction predicated with an always true condition always executes regardless of the predicate register contents. The always true predicate byte is 01h. Other true predicates are instruction short-forms. |
| 2 | PEQ | eq | Equal – instruction executes if the predicate register equal flag is set |
| 3 | PNE | !eq | Not Equal – instruction executes if the predicate register equal flag is clear |
| 4 | PLE | lt|eq | Less or Equal – predicate less or equal flag is set |
| 5 | PGT | !(lt|eq) | greater than |
| 6 | PGE | !lt | greater or equal |
| 7 | PLT | lt | less than |
| 8 | PLEU | ltu|eq | unsigned less or equal |
| 9 | PGTU | !(ltu|eq) | unsigned greater than |
| 10 | PGEU  POR | !ltu | unsigned greater or equal  Ordered for floating point |
| 11 | PLTU  PUN | ltu | unsigned less than  Unordered for floating point |
| 12 |  |  |  |
| 13 | PSIG | signal | execute if external signal is true |
| 14 |  |  |  |
| 15 |  |  |  |

### Compiler Usage

The compiler uses predicate register #15 to conditionally move TRUE / FALSE values to a register when evaluating a logical operation.

Predicate registers beginning with P0 and incrementing are applied for use as the control flow nesting level increases. The compiler does not support control flow nesting more than 14 levels in a single subroutine. Predicate registers beginning with P14 and decrementing are used in the evaluation of the hook operator. Care must be taken such that the number of predicate registers in use does not exceed the number available.

|  |  |  |
| --- | --- | --- |
| Pred. | Usage |  |
| P0 | control flow level 0 |  |
| P1 | control flow nesting level 1 |  |
| P2 | control flow nesting level 2 |  |
| … |  |  |
| Pn | control flow nesting level n (n not to exceed 14) |  |
| … |  |  |
| P12 | third hook operator in an expression |  |
| P13 | second hook operator in an expression |  |
| P14 | first hook operator in an expression |  |
| P15 | conditionally moves TRUE/FALSE for logical expressions |  |

## Debug Address Register (61,0 to 61,3)

These registers contain addresses of instruction or data breakpoints.

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

## Debug Control Register (61,4)

This register 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. |  |  |
| 7 | When 1 this bit enables single stepping mode. A debug exception will be generated after the execution of an instruction. |  |  |
| 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 byte 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 |  |  |  |
| 63 |  |  |  |

## Debug Status Register (61,5)

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 |

## ****Summary of Special Purpose Registers****

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Reg # | R/W |  |  | |  |
| 00-15 | RW | PRED | reserved - specific predicate register #0 to 15 | |  |
| 16-31 | RW | CREGS | Code address register array (C0 to C15) | |  |
| 32-39 | RW | SREGS | Segment selector register array (zs,ds,es,fs,gs,hs,ss,cs) | |  |
| 40 | RW | LDT | local descriptor table selector | |  |
| 41 | RW | GDT | global descriptor table pointer | |  |
| 42 |  |  | reserved | |  |
| 43 | W | SEGSW | segment switch register | |  |
| 44 | RW | segbase | segment base address | Segment Descriptor for segment register selected by segsw |  |
| 45 | RW | seglimit | segment limit |  |
| 46 | - |  | reserved (segmentation) |  |
| 47 | RW | segacr | segment access rights |  |
| 48 | RW | keys | memory keys for lot system | |  |
| 49 | RW | USP | user stack pointer | |  |
| 50 | R | TICK | Tick count | |  |
| 51 | RW | LC | Loop Counter | |  |
| 52 | RW | PREGS | Predicate register array | |  |
| 53 | RW | ASID | address space identifier | |  |
| 54 | RW | VL | Vector Length | |  |
| 55 | RW | SR | Status Register | |  |
| 56 | RW | FPSCR | Floating point status and control | |  |
| 58 | R | ARG1 | exception / interrupt argument 1 | |  |
| 59 | RW | EXC | exception cause register | |  |
| 60 | W | BIR | Breakout index register | |  |
| 61 | RW |  | Breakout register - additional spr’s | |  |
| 63 |  |  | reserved | |  |

Additional Spr’s are available by setting the breakout index register to an Sor index value, then accessing the Spr through the breakout register.

### P0,P1,…P15 (PRED)

These registers allow access to the predicate registers. Accessing the predicate registers through the special purpose register array is not normally done. There are other instructions that directly access the predicate registers, such as biti and cmp. For saving / restoring all predicates at once the PREGS register can be used. These registers are four bits wide.

### C0,C1,…C15 (CREGS) – SPR #16 to 31

This set of registers allows access to the code address register array.

### ZS,DS,ES,FS,GS,HS,SS,CS (SREGS) – SPR #32 to 39

These registers reflect the values of the segment selectors currently active in the core. Writing to a selector register triggers a segment load interrupt.

### LDT – SPR #40

The LDT register holds the selector for the local descriptor table.

|  |  |  |
| --- | --- | --- |
| 31 24 | 23 | 22 0 |
| PL8 | T | Index23 |

### GDT – SPR #41

The GDT register holds the location and size of the global descriptor table. The descriptor table must be 32 byte aligned. The low order five bits of the GDT register are used to indicate the table size.

|  |  |
| --- | --- |
| 63 5 | 4 0 |
| Table Address63..5 | Size |

Since the table is software managed the exact meaning of the size field is up to the software implementation. It is suggested that the size field at least be a multiple of the memory page size so that the memory protection capability can be applied to the table.

### SEGSW – SPR #43

The segment switch register controls which segment information is visible in the special purpose register array. Since segments are relatively large objects only one set of registers is visible at one time. This register is a three bit write-only register.

|  |  |
| --- | --- |
| Value | Visible Components |
| 0 | ZS |
| 1 | DS |
| 2 | ES |
| 3 | FS |
| 4 | GS |
| 5 | HS |
| 6 | SS |
| 7 | CS |
| 8 | LDT |

Note that the sync instruction should be used to ensure the correct register set is visible.

### SEGBASE – SPR #44

The segbase register reflects the base component of the segment descriptor for the selected segment register. Which base register is present at SPR#44 is controlled by the segment switch (segsw) special purpose register. For example to access the DS segment register components set the segsw to one then the DS descriptor values will be accessible.

### SEGLMT – SPR #45

This register allows access to the segment limit component of the descriptor for the selected segment register.

### SEGACR – SPR #47

This register allows access to the segment access rights information component of the descriptor for the selected segment register.

### KEYS – SPR #48

This register contains the collection of keys associated with the process for the memory lot system. Each key is ten bits in size. The register contains six keys.

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 63 60 | 59 50 | 49 40 | 39 30 | 29 20 | 19 10 | 9 0 |
| ~4 | key6 | key5 | key4 | key3 | key2 | key1 |

### TICK - SPR #50

The tick count register contains the number of clock cycles that have passed since the last reset.

### LC – SPR #51

The loop count register is a 64 bit register used with the loop instruction to form counted loops.

### PREGS – SPR #52

PREGS is a horizontal combination of all the predicate registers. Each predicate register has a four bit slot within the PREGS register. The PREGS register allows reading or writing of all the predicates in a single operation. This is useful when the predicate register state must be saved and restored across subroutine calls.

### ASID – SPR #53

ASID is an acronym for Address Space Identifier. It is used in conjunction with the TLB unit during virtual address translations. The ASID value in this register must match the ASID in the TLB entry in order for that translation to be considered valid. The ASID is typically associated with a process.

### Status Register (SR) – SPR #55

This register contains bits that control the overall operation of the processor or reflect the processor’s state. Bits are included for interrupt masking, and system / application mode indicator. This register is split into two halves with both halves having the same format. The lower half of the register is what determines how the processor works. The upper half of the register maintains a backup copy of the lower half for interrupt processing. There are instructions provided for manipulating the interrupt mask.

|  |  |  |  |
| --- | --- | --- | --- |
| Bits |  | Description |  |
| 7..0 | ~ | reserved |  |
| 11..8 | RS | register set |  |
| 12 | FXE | Float exception enable |  |
| 13 | KM | Kernel / Application mode indicator |  |
| 14 | ~ | reserved |  |
| 15 | IM | Interrupt mask |  |
| 31..16 |  | Same format as 15..0 |  |

 The Kernel / Application Mode indicator is read-only.

IM = interrupt mask

Maskable interrupts are disabled when this bit is set.

# Operating Modes

The core operates in one of two basic modes: application/user mode or kernel mode. Kernel mode is switched to when an interrupt or exception occurs, or when debugging is triggered. On power-up the core is running in kernel mode. An RTI instruction must be executed in order to leave kernel mode after power-up.

A subset of instructions is limited to kernel mode.

# Segmentation

## Overview

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

## Privilege levels

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

## Usage

The segment register to use during address formation for data addresses is identified by a field in the instruction. This field is set to default values by the assembler. For code addresses segment register #7 (the CS) is always used.

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

## Software Support

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

Segment registers may only be transferred to or from one of the general purpose registers. The [mtspr](#_MTSPR_–Register-Special_Register) and [mfspr](#_MFSPR_–_Special) instructions can be used to perform the move. A segment register may also be loaded using the [LDIS](#_LDIS_-_Load-Immediate) instruction. After loading a segment register the instruction stream should be synchronized with a memory barrier ([MEMSB](#_MEMSB_–_Memory)) to ensure the segment value can be ready for a following memory operation.

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

## Address Formation:

Non-segmented address bits 0 to 11 pass through the segmentation module unchanged. Address bits 63 to 12 are added to the contents of the segment register to form the final segmented address. Note that there is no shift associated with the segment addition. Future implementations of the processor may include additional low order address bits in the segment register in order to allow a finer grain for memory page / paragraph size.

|  |  |
| --- | --- |
| Address[63:12] | Address[11:0] |
| + | + |
| Segment register value[63:12] | 00012 |
| = | |
| Segmented address[63:0] | |

## Selecting a segment register

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

## Selectors

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

#### Selector Format:

|  |  |  |
| --- | --- | --- |
| 31 24 | 23 | 22 0 |
| PL8 | T | Index23 |

PL8: the privilege level associated with the segment

Index23: the index into the descriptor table

T: 0 = global, 1 = local descriptor table

## Non-Segmented Code Area

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

## Changing the Code Segment

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

## The Descriptor Table

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

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
|  | 255 244 | 243 192 | 191 128 | 127 64 | 63 0 |
| w0 | ACR16 | ~48 | ~64 | Limit64 | Base64 |
| w1 | ACR16 | ~48 | ~64 | Limit64 | Base64 |
| … |  |  |  |  |  |

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

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

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

#### Memory Descriptors

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

|  |  |  |
| --- | --- | --- |
| n+3 | ~48 | ACR16 |
| n+2 | ~64 | |
| n+1 | Limit63..0 | |
| n | Base63..0 | |

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

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

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

S: 0 = system descriptor, 1 = memory descriptor

EX: 1 = executable, 0 = data

Code Segment Data Segment

C: 1= conforming Stk: 1=stack segment

R: 1 = readable W: 1=writeable

A: 1= accessed

DPL8 = descriptor privilege level

#### Typical Values for ACR

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

9200 – read/writeable data segment, privilege level zero

9600 – read / writeable stack segment, privilege level zero

#### Stack Segment Descriptors

Stack segment descriptors describe the location and limits of stack segments. They have the following format:

|  |  |  |
| --- | --- | --- |
| ~48 | | ACR16 |
| ~64 | | |
| Upper Limit34..3 | Lower Limit34..3 | |
| Base63..0 | | |

There is no difference between a stack segment descriptor and a memory segment descriptor except in the way that the segment limit field is used. (Bit 10 of the ACR for the data descriptor is set). For a stack segment, when the descriptor is loaded, the limit field is split in two in order to provide both an upper and lower bounds to the stack. If either bounds are exceeded a stack fault occurs rather than a bounds violation. This provides the capacity to expand the stack. One limitation of this mechanism is that the stack is limited to 35 address bits (32GB). Note that the stack is always word aligned so the upper and lower limits represent word boundaries.

### System Segment Descriptors

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

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

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

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

#### LDT Descriptor

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

|  |  |  |  |
| --- | --- | --- | --- |
| n+3 | ~48 | | ACR16 |
| n+2 | ~64 | | |
| n+1 | ~41 | Size22..0 | |
| n | Base63..0 | | |

#### Call Gate Descriptor

|  |  |  |  |
| --- | --- | --- | --- |
| ~48 | | | ACR16 |
| ~64 | | | |
| ~27 | N5 | Selector31..0 | |
| Base63..0 | | | |

## Segment Load Exception

Moving a value to a selector register (a move to SPR #32 to 38,40) triggers a segment load exception in order to allow the segment descriptor to be loaded from one of the descriptor tables. This exception is triggered for a LDIS or MTSPR instruction. There is a separate exception vector (vectors #256 to 264) to handle each segment register. The selector value being loaded into the segment register is reflected in the ARG1 special purpose register.

## Segment Bounds Exception

If an address is greater than or equal to the limit specified in the segment limit register then a segment limit exception occurs. This applies for all segments including code and data segments.

## Segment Usage Conventions

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

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

## Power-up State

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

### Segment Registers

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

# Memory Lot Protection System

The memory lot protection system offers an alternative means to incorporate memory protection into a 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 keys associated with each lot of memory. The key associated with a memory lot contains the lot owner’s group, and read / write / execute indicators.

![](data:image/png;base64,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rnte3gG9aM6Kg8tIS01PgxEYgaGXAg+ruGvuuwrdyLHiNrkfC4ERGHoq8PCcKHfempe2BB7baDKRhcAIDL0VuCMQGIEBgREYAIERGBAYgREYEBiBARAYgQGBERiBAYERGIEBgREYAIERGBAYgREYEBiBARAYgQEQGIEBgREYgQGBERgAgREYEBiBERgQGIERGBAYgQEQGIEBgREYgQGBERgAgREYAIERGBAYgREYEBiBARAYgQGBERiBAYERGIEBgREYAIERGBAYgREYEBiBARAYgQGBERiBAYERGIEBgREYAIERGBAYgREYEBiBERgQGIEBEBiBAYERGIEBgREYAIERGBAYgREYEBiBERgQGIEBEBiBAYERGIEBgREYAIERGACBERgQGIERGBAYgQEQGIEBgREYgQGBERiBAYERGACBERgQGIERGBAYgQEQGIEBEBiBAYERGIEBgREYoB2B04Y3GYEhLT5EYASG/PK71P39J95kBAZAYABAYABAYAAEBgAEBgAEBgAEBkBgAEBgAEBgAAQGAAQGAAQGAAQGQGAAQGAAQGAAQGAABAYABAYABAZAYABAYABAYABAYAAEBgAEBgAEBgAEBkBgAEBgAEBgAAQGAAQGAAQGAAQGQGAAQGAAQGAAQGAABAYABAYABAZAYABAYABAYABAYAAEBgAEBgAEBkBgAEBgAEBgAEBgAAQGAAQGAAQGAAQGQGAAQGAAQGAABAYABAYABAYABAZAYABAYABAYABAYAAEBgAEBgAEBkBgAEBgAEBgAEBgAAQGAAQGAAQGQGAAQGAAQGAAQGAABAYABAYABAYABAZAYABAYABAYAAEBgAEBgAEBgAEBkBgAEBgAEBgAEBgAAQGAAQGAAQGQGAAQGAAQGAAQGAABAYABAYABAYABAZAYABAYABAYAAEBgAEBgAEBoBo/j9d6Wcvea6PAgAAAABJRU5ErkJggg==)

![](data:image/png;base64,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IDAAAgMgMEBgAAQGQGCAwAAIDIDAAAgMEBgAgQEQGACBAQIDIDAAAgMEBkBgAAQGQGCAwAAIDIDAAAgMEBgAgQEQGCAwAAIDIDAAAgMEBkBgAAQGCAyAwAAIDIDAAIEBEBgAgQEQGCAwAAIDIDBAYAAEBkBgAAQGCAyAwAAIDIDAAIEBEBgAgQECAyAwAAIDIDBAYAAEBkBggMAACAyAwAAIDBAYAIEBEBgAgQECAyAwAAIDBAZAYAAEBkBggMAACAyAwAAIDBAYAIEBEBggMAACAyAwAAIDBAZAYAAEBkBggMAACAyAwACBARAYAIEBEBggMAACAyAwQGAABAZAYAAEBggMgMAACAyAwACBARAYAIEBAgMgMAACAyAwQGAABAZAYAAEBggMgMAACAwQGACBARAYAIEBAgMgMAACAyAwQGAABAZAYIDAAAgMgMAACAwQGACBARAYIDAAAgMgMAACAwQGQGAABAZAYIDAAAgMgMAAgQEQGACBARAYIDAAAgMgMAACAwQGQGAABAYIDIDAAAgMgMAAgQEQGACBAQLbBQCBARAYAIEBAgMgMAACAyAwQGAABAZAYIDAAAgMgMAACAwQGACBARAYAIEBAgMgMAACAwQGQGAABAZAYODc8v8BtmtGeWwJqycAAAAASUVORK5CYII=)

# TLB – The Translation Lookaside Buffer

## Overview

The TLB (translation look-aside buffer) offers a second means of address virtualization and memory protection in addition to segmentation. A TLB works by caching address mappings between a real physical address and a virtual address used by software. The TLB is managed by software triggered when a TLB miss occurs. The TLB deals with memory organized as pages. Typically software manages a paging table whose entries are loaded into the TLB as translations are required.

## Size / Organization

The core uses a 64 entry TLB (translation look-aside buffer) in order to support virtual memory. The TLB supports variable page sizes from 4kB to 1MB. The TLB is organized as an eight-way eight-set cache.

## Updating the TLB

The TLB is updated by first placing values into the TLB holding registers using the TLB instruction, then issuing a TLB write command using the TLB command instruction.

Address translations will not take place until the TLB is enabled. An enable TLB command must be issued using the TLB command instruction.

TLB Entries:

C2..0

G

D

V

ASID7...0

Virtual Page51...0

Physical Page51...0

G = Global

The global bit marks the TLB entry as a global address translation where the ASID field is not used to match addresses.

ASID = address space identifier

The ASID field in the TLB entry must match the processor’s current ASID value in order for the translation to be considered valid, unless the G bit is set. If the G bit is set in the TLB entry, then the ASID field is ignored during the address comparison.

C = cachability bits

If the cachability bits are set to 001b then the page is uncached, otherwise the page is cached.

D = dirty bit

The dirty bit is set by hardware when a write occurs to the virtual memory page identified by the TLB entry.

V = valid bit

This bit must be set in order for the address translation to be considered valid. The entire TLB may be invalidated using the invalidate all command.

## TLB Registers

### TLBWired (#0h)

This register limits random updates to the TLB to a subset of the available number of ways. TLB ways below the value specified in the Wired register will not be updated randomly. Setting this register provides a means to create fixed translation settings. For instance if the wired register is set to two, the sixteen fixed entries will be available.

### TLBIndex (#1h)

This register contains the entry number of the TLB entry to be read from or written to.

### TLBRandom (#2h)

This register contains a random three bit value used to update a random TLB entry during a TLB write operation.

### TLBPageSize (#3h)

The TLBPageSize register controls which address bits are significant during a TLB lookup.

|  |  |  |
| --- | --- | --- |
| N | Page Size |  |
| 0 | 4KiB |  |
| 1 | 16kiB |  |
| 2 | 64kiB |  |
| 3 | 256kiB |  |
| 4 | 1MiB |  |
|  |  |  |
|  |  |  |

### TLBPhysPage (#5h)

The TLBPhysPage register is a holding register that contains the page number for an associated virtual address. This register is transferred to or from the TLB by TLB instructions.

|  |
| --- |
| 63 0 |
| Physical Page Number |

### TLBVirtPage (#4h)

The TLBVirtPage register is a holding register that contains the page number for an associated physical address. This register is transferred to or from the TLB by TLB instructions.

|  |
| --- |
| 63 0 |
| Virtual Page Number |

### TLBASID (#7h)

The TLBASID register is a holding register that contains the address space identifier (ASID) , valid, dirty, global, and cachability bits associated with a TLB entry. This register is transferred to or from the TLB by TLB instructions.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 63 16 | 15 8 | 6 4 | 2 | 1 | 0 |
| ----- | ASID | C | G | D | V |

# Memory Operations:

## Basic Operations

Basic memory operations include loads, stores, pushes, pops and string operates. There is also a memory indirect jump instruction. Other than those operations there are no other instructions that access memory. Note that return addresses are not pushed onto the stack automatically.

## Memory Addressing Modes

The core supports both register indirect with displacement and scaled indexed addressing. Indexed addressing is supported only with the general purpose register load store operations.

Register indirect addressing looks up both a register value and a segment register value from the register files and adds a displacement from the instruction to form an address.

![](data:image/png;base64,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)

Scaled Indexed addressing looks up two register file values and a segment register value, multiplies the second register value by a scaling factor, then adds all three values to form an address.

![](data:image/png;base64,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DEATCMAAjE0AdgnAADSBAAzA2ARglwAMQBMIwACMTQB2CcAANIEADMDYBGCXAAxAEwjAAIytGBxcrjZcALSTAAzA2I44eYnQ5BKAAag9ARiAsV23eoPQ5GrNdfHyu7ypAVpKAAYAACAJAjAAAABJEIABAABIggAMAABAEgRgAAAAkiAAAwAAkAQBGAAAgCQIwAAAACRBAAYAACAJAjAAAABJEIABAABIggAMAABAEgRgAAAAkiAAAwAAkAQBGAAAgCQIwAAAACRBAAYAACAJAjAAAABJEIABAABIggAMAABAEgRgAAAAkiAAAwAAkAQBGAAAgCQIwAAAACRBAAYAACAJAjAAAABJEIABAABIggAMAABAEgRgAAAAkiAAAwAAkAQBGAAAgCQIwAAAACRBAAYAACAJAjAAAABJEIABAABIggAMAABAEgRgAAAAkiAAAwAAkAQBGAAAgCQIwAAAACRBAAYAACAJAjAAAABJEIABAABIggAMAABAEgRgAAAAkiAAAwAAkAQBGAAAgCQIwAAAACRBAAYAACAJAjAAAABJEIABAABIggAMAABAEgRgAAAAkiAAAwAAkAQBGAAAgCQIwAAAACRBAAYAACAJAjAAAABJEIABAABIggAMAABAEgRgAAAAkiAAAwAAkAQBGAAAgCQIwAAAACRBAAYAACAJAjAAAABJEIABAABIggAMAABAEv7/p1XaN2QJlaMAAAAASUVORK5CYII=)

## Pre-fetching data

The load instructions may be used to pre-fetch data by specifying a load into register R0. If R0 is used as the load target register then the load operation will not cause any exception.

## Bypassing the Data Cache

There are several load instructions that bypass the data-cache when loading – see the load volatile (LVx) instructions. These instructions are useful for I/O operations or for when it is better if the data cache is not loaded for performance reasons.

The volatile load instructions only offer sign extension and not zero extension. To zero extend data loaded by a volatile load operation follow it with one of the zero extension (ZXx) instructions.

## Push Operations

The core supports a data push to stack and data pop operation. The data push operation both decrements the stack pointer and stores data to the stack. Argument pushing is commonly used in high-level languages. Subroutine arguments pushed to the stack in high-level languages are usually popped off the stack simply by adding to the stack pointer.

An additional push operation includes pushing an effective address to the stack.

## Load Speculation

The core may load data speculatively in advance of its use provided there is no address overlap with a preceding store instruction.

## Store Issuing

Stores will only be issued if there are no instructions that can exception before the store in the instruction queue. Since many instructions do not cause any exceptions this happens fairly often.

## Atomic Operations

The core has a single atomic memory operation which is the CAS (compare-and-swap) instruction.

## Address Reservation

The address reservation instructions rely on the external memory system to support address reservation. There are only two instruction (LVWAR, SWCR) associated with address reservation. The load instruction creates an address reservation and the store instruction clears it. In a multi-core system the reservation may be created or cleared by another processing core.

## Synchronization Operations

The core includes memory data barrier and memory instruction barrier instructions to allow data to be synchronized during program runs.

# Exceptions

## Precision

Thor’s exceptions are precise. They are processed in order at the location of the exception. For instance if a divide by zero exception occurred then the exception return address is the address of the divide by zero instruction. Instructions after the divide by zero are not committed to the machine state (the results are dropped).

## Nesting

Software exceptions are allowed to nest up to 255 levels. The nesting level is tracked by the core and when it is non-zero the core is in kernel mode. When an exception occurs the nesting level increases, when a return from exception is performed (RTE or RTD) the nesting level decreases. From a software standpoint this allows exceptions to occur in an exception handler. For instance it may be desirable for a debug exception to occur in the handler.

Hardware interrupts do not track the nesting level. The core does not allow nested hardware interrupts. When a hardware interrupt occurs the core is switched to kernel mode.

## Vectors

The processor vectors to $FFFFFFFFFFFC0000 on a reset. All other vectoring is done through a vector table. The vector table allows for 256 entries. The vector table base address is established by code address register C12. During an external IRQ the processor looks at a vector number bus to determine the vector to use for the IRQ. This vector number may be hard-coded in which case all IRQ’s will be vectored to the same location. The address vectored to is the sum of C12 and an offset supplied in the instruction multiplied by sixteen. The contents of C12 are undefined at reset; this register must be loaded before interrupts can be processed. Note that segmentation is temporarily disabled during exception processing to allow the vector to be accessed.

### Vector table:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Vector Number | Usage / Description | |  |  |
| 0 | BREAK instruction vector | |  |  |
| 1 | SLEEP vector (branch to self) | |  |  |
| 2 | FMTK Task reschedule | |  |  |
| 3 | FMTK Time slice scheduler | |  |  |
| 4 | FMTK System call | |  |  |
| … |  | |  |  |
| 190 | Save register state | |  |  |
| 191 | Restore register state | |  |  |
| 192 | Spurious interrupt | |  |  |
| 193 | IRQ level 1 | 1000 Hz interrupt |  |  |
| 194 | IRQ level 2 | 100 Hz interrupt |  |  |
| … | Other IRQ levels |  |  |  |
| 207 | IRQ level 15 | keyboard interrupt |  |  |
| … |  | |  |  |
| 239 | check failed | |  |  |
| 240 | overflow (integer) | |  |  |
| 241 | divide by zero (integer) | |  |  |
| 242 | floating point | |  |  |
| 243 | debug | |  |  |
| 244 | segmentation | |  |  |
| 245 | privilege violation | |  |  |
| 246 | segment load | |  |  |
| 247 | segment not present | |  |  |
| 248 | DTLBMiss | |  |  |
| 249 | ITLB Miss | |  |  |
| 250 | Unimplemented instruction | |  |  |
| 251 | Bus error – data load / store | |  |  |
| 252 | Bus error – instruction fetch | |  |  |
| 253 | reserved | |  |  |
| 254 | NMI interrupt vector | |  |  |
| 255 | * reserved | |  |  |
| 256 | Load ZS | |  |  |
| 257 | Load DS | |  |  |
| 258 | Load ES | |  |  |
| 259 | Load FS | |  |  |
| 260 | Load GS | |  |  |
| 261 | Load HS | |  |  |
| 262 | Load SS | |  |  |
| 263 | * reserved | |  |  |
| 264 | Load LDT | |  |  |
| 265 | Far return | |  |  |
| 266 | Far subroutine call | |  |  |

**Mnemonics**

|  |  |
| --- | --- |
|  |  |
| DBG | debug |
| DBE | data bus error |
| TLB | TLB miss |
| LMT | segment limit |
|  |  |

## Hardware Interrupts

### Interrupt Enable Delay

The core features a delay before interrupts are enabled by the CLI instruction or by an RTI instruction restoring the interrupt mask status. The default value for this delay is five clock cycles. See the IMCD core parameter description. The idea behind the delay is that processing may continue on non-interrupt code even if an IRQ line is stuck active due to a hardware problem.

# Hardware Ports

Thor uses a WISHBONE bus to communicate with the outside world.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
|  | I/O | Width | WB |  |  |
| corenum | I | 32 |  | core number – this number is used to identify the core and is reflected in the cpuid register. Meant to be a hardcoded constant. |  |
| rst\_i | I | 1 | WB | reset signal |  |
| clk\_i | I | 1 | WB | clock |  |
| clk2x\_i | I | 1 |  | two times clock input (drives register file) |  |
| clk\_o | O | 1 |  | output (gated) clock |  |
| km | O | 1 |  | kernel mode indicator |  |
| nmi\_i | I | 1 |  | non-maskable interrupt input |  |
| irq\_i | I | 1 |  | maskable interrupt input |  |
| vec\_i | I | 8 |  | interrupt vector |  |
| bte\_o | O | 2 | WB | burst type extension |  |
| cti\_o | O | 3 | WB | cycle type indicator |  |
| bl\_o | O | 5 |  | burst length output |  |
| lock\_o | O | 1 | WB | bus lock |  |
| resv\_o | O | 1 |  | reserve address |  |
| resv\_i | I | 1 |  | address reservation status in |  |
| cres\_o | O | 1 |  | clear address reservation |  |
| cyc\_o | O | 1 | WB | cycle is valid |  |
| stb\_o | O | 1 | WB | data transfer is taking place |  |
| ack\_i | I | 1 | WB | data transfer acknowledge |  |
| err\_i | I | 1 | WB | bus error occurred input |  |
| we\_o | O | 1 | WB | write enable |  |
| sel\_o | O | 8 | WB | byte lane selects |  |
| adr\_o | O | 64 | WB | address output |  |
| dat\_i | I | 64 | WB | data input bus |  |
| dat\_o | O | 64 | WB | data output bus |  |
|  |  |  |  |  |  |

WB = see the WISHBONE spec rev B3

# Reset

On reset the core begins fetching and executing instruction at address $FFFFFFFFFFFC0000. The code segment is set to $0000 and the program counter is set to $FFFFFFFFFFFC0000. Note that the last 4k bytes of memory are unreachable to the processing core due to limitations in the segment boundary checking. The last 4k bytes should not be used to store instructions or data.

On power-up or reset interrupts are disabled automatically, In order to enable interrupts the RTI instruction must be executed. An [RTI](#_RTI_–_Return) automatically enables interrupts. Note that the interrupt mask must also be cleared with the CLI instruction to allow maskable interrupts to occur.

After reset or NMI the core begins processing at a half the maximum clock rate. The [STP](#_STP_–_Stop) instruction must be issued to get the processer running at full speed.

# Clock Cycle Counts

The core has a minimum CPI of 0.5 clocks per instruction running trivial sample code. Many instructions can be done in pairs provided there are no dependencies between the instructions. Due to the out of order execution ability of the core the latency of longer running instructions may be hidden. The core may be busy working on up to four instructions at once: two ALU or an ALU and memory op, a floating point op and a branch instruction.

# Core Parameters

|  |  |  |
| --- | --- | --- |
| DBW | 32 | The parameter controls the width of data processed by the core. Set to 64 for 64 bit processing. This parameter should be either 64 or 32. If the width is set to 32 bit then double precision floating point operations are unavailable. Also only eight predicate registers are available. |
| ABW | 32 | This parameter controls the width of the external address bus. This value should be the same as or less than the data bus width (DBW). |
| ALU1BIG | 0 | This parameter controls whether or not ALU1 supports all instructions or only a subset of instructions. The default is to support only the most common instructions. (0 = limited, 1 = all) in order to reduce the size of the core.  Limiting the number of instructions supported may impact performance of the core because it may not be possible to issue two instructions in the same cycle. |
| IMCD | 3Eh | This parameter controls how many clock cycles interrupts are disabled before an interrupt enable takes effect. It is a shift counter value. Valid values are 3E (5 clocks),3C(four clocks),38,30,and 20 (1 clock). |

# Configuration Defines

|  |  |  |
| --- | --- | --- |
| Definition | Default | Comment |
| SEGMENTATION | 1 | Causes the core to include segmentation. If segmentation is not desired then this can be commented out to produce an unsegmented core. |
| SEGLIMITS | 1 | Causes the core to include logic for segmentation limit checks, but only if SEGMENTATION is defined. Commenting out this definition will remove the segment limit checks and exceptions. |
| STRINGOPS | 1 | Causes the core to include memory string operations. |
| DEBUG\_LOGIC | 1 | Causes the core to include logic to support the debug registers. Once the application is working well it may be desirable to reduce the size of the core by removing the debug registers and associated logic. |
| TRAP\_ILLEGALOPS | 1 | Causes the core to include logic to trap for illegal operations during runtime. Once the target application is working well it may be desirable to remove the illegal instruction trapping. |
| FLOATING\_POINT | 1 | Causes the core to include floating point operations. Comment out to reduce the size of the core. |
| BITFIELDOPS | 1 | Causes the core to include bit-field operations if defined. |
| PRIVCHKS | 1 | Causes the core to include privilege level checking logic. This may be commented out if not needed. |
| PCHIST | 1 | Causes the core to include PC history capture logic. |

# Instruction Formats

Instructions vary in length from one to eight bytes. There are only a few of single byte instructions consisting of only a predicate. Some of the more common formats are shown below.

All instruction sequences begin with a predicate byte that determines the conditions under which the instruction executes. With the exception of special predicate values, the next field in the instruction is always the opcode byte. All instructions may be preceded by an extended constant value.

### RR - Register-Register

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Func | Rt | Rb | Ra | Opcode | Predicate | |
| Func6 | Rt6 | Rb6 | Ra6 | Opcode8 | Pn4 | Pc4 |

### RI - Register-Immediate

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | Opcode8 | Pn4 | Pc4 |

### CMP Register-Register Compare

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 12 | 11 8 | 7 0 | |
| Opc4 | Rb6 | Ra6 | 14 | Pt4 | Pn4 | Pc4 |

### CMPI Register-Immediate Compare

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 31 22 | | | | 21 16 | | | | 15 12 | | | 11 8 | | 7 0 | | | |
| Immed9..0 | | | | Ra6 | | | | 24 | | | Pt4 | | Pn4 | | | Pc4 |
| TST - Register Test Compare | | | | | | | | | | | | |  | | | |  | | CTRL/RTx- Control | | | | | | |
| 2322 21 16 | | | 15 12 | | | 11 8 | | | 7 0 | | | |  | | | |  | | 15 8 | | 7 0 | | | | |
| O2 | Ra6 | | 04 | | | Pt4 | | | Pn4 | | Pc4 | |  | | | |  | | Opcode8 | | Pn4 | | | Pc4 | |
| BR - Relative Branch | | | | | | | | | | | |  | |  | | | | BRK/NOP | | | |  |  | | | |
| 23 16 | | 15 8 | | | | | 7 0 | | | | |  | |  | | | | 7 0 | | | |  |  | | | |
| Disp7..0 | | 34 | | | D11..8 | | Pn4 | | | Pc4 | |  | | |  | | | 0/14 | | 04 | |  |  | |  | |

### JSR - Jump To Subroutine

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 47 24 | 23 16 | | 15 8 | 7 0 | |
| Offset23..0 | Cr4 | Crt4 | Opcode8 | Pn4 | Pc4 |

# Instruction Set Summary

A number of rarely used instructions may only execute on ALU #0. These instructions are identified in the text.

## Illegal Instructions

By default the core traps all illegal instructions through vector #250. The logic to trap illegal instructions may be removed by commenting out the TRAP\_ILLEGALOPS definition.

## Branch Instructions

The core has only a single relative branch instruction which branches relative to the address of the next instruction. This single branch instruction may be used to implement branching on multiple complex conditions when combined with a predicate. The branch instruction supports a 12 bit displacement field.

### Branch Speculation

Branches are performed speculatively in the fetch stage of the core according to branch predictor output. Branches use a (2, 2) co-relating branch predictor with a 256 entry branch history table. Both global and local branch histories are maintained.

## Loops

There is a loop instruction and corresponding loop count register to support counted loops. The loop instruction is predicted as always taken and does not consume room in the branch history table. Like a branch instruction a loop instruction takes place at the fetch stage of the core. The loop instruction supports only and eight bit displacement field which may not be extended.

## Subroutine Call / Return

Program counter relative jumps and calls may be achieved using the program counter as the index register in jump instructions. The jump instruction directly supports up to 24 bit addressing. A shorter jump instruction is available that supports 16 bit addressing. The addressing capabilities of the jump instruction may be increased by applying an immediate prefix to the instruction. It is envisioned that the 16/24 bit jump addressing is sufficient for most cases when combined with usage of the code segment.

## Comparison Operations

Comparison operations include CMP and TST (compare to zero). Comparison operations set a predicate register to the result status of the comparison.

## Arithmetic Operations

|  |  |
| --- | --- |
| Mnemonic |  |
| ADD | addition |
| ADDU | unsigned addition |
| SUB | subtraction |
| SUBU | unsigned subtraction |
| MUL | multiplication |
| MULU |  |
| DIV | division |
| DIVU |  |
| NEG | negative |
| ABS | absolute value |
| MIN | minimum value |
| MAX | maximum value |

## Bitwise Operations

Bitwise operations include ‘and’, ‘or’ and exclusive ‘or’ along with their inverted versions.

|  |  |  |
| --- | --- | --- |
| Mnemonic | Has Immediate Form |  |
| AND | Y |  |
| OR | Y |  |
| EOR | Y |  |
| NAND | N |  |
| NOR | N |  |
| ENOR | N |  |
| ANDC | N |  |
| ORC | N |  |
| COM | N | invert bits |

## Logical Operations

The core includes the logical ‘not’ (NOT) operation. The NOT operation reduces the value to a one or zero result.

# Detailed Instruction Set

### 2ADDU - Register-Register

**Description:**

Multiply Ra by two and add Rb and place the sum in the target register. This instruction will never cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 08h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra \* 2 + Rb

**Exceptions:** none

### 2ADDUI - Register-Immediate

**Description:**

Multiply Ra by two and add immediate and place the sum in the target register. This instruction will never cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 6Bh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra \* 2 + immediate

**Exceptions:** none

### 4ADDU - Register-Register

**Description:**

Multiply Ra by four and add Rb and place the sum in the target register. This instruction will never cause an exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 09h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra \* 4 + Rb

**Exceptions:** none

### 4ADDUI - Register-Immediate

**Description:**

Multiply Ra by four and add immediate and place the sum in the target register. This instruction will never cause an exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immed11..0 | Rt6 | Ra6 | 6Ch8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra \* 4 + immediate

**Exceptions:** none

### 8ADDU - Register-Register

**Description:**

Multiply Ra by eight and add Rb and place the sum in the target register. This instruction will never cause an exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 0Ah6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra \* 8 + Rb

**Exceptions:** none

### 8ADDUI - Register-Immediate

**Description:**

Multiply Ra by eight and add immediate and place the sum in the target register. This instruction will never cause an exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immed11..0 | Rt6 | Ra6 | 6Dh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra \* 8 + immediate

**Exceptions:** none

### 16ADDU - Register-Register

**Description:**

Multiply Ra by sixteen and add Rb and place the sum in the target register. This instruction will never cause an exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 0Bh6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra \* 16 + Rb

**Exceptions:** none

### 16ADDUI - Register-Immediate

**Description:**

Multiply Ra by sixteen and add immediate and place the sum in the target register. This instruction will never cause an exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immed11..0 | Rt6 | Ra6 | 6Eh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra \* 16 + immediate

**Exceptions:** none

### ABS – Absolute Value Register

**Description:**

This instruction takes the absolute value of a register and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 34 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

If Ra < 0

Rt = -Ra

else

Rt = Ra

**Exceptions:** none

### ADD - Register-Register

**Description:**

Add two registers and place the sum in the target register. This instruction may cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 00h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra + Rb

**Exceptions:** integer overflow

### ADDI - Register-Immediate

**Description:**

Add a register and immediate value and place the sum in the target register. This instruction may cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 48h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra + immediate

**Exceptions:** integer overflow

### ADDU - Register-Register

**Description:**

Add registers Ra and Rb and place the result into register Rt. This instruction will never cause any exceptions.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 04h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra + Rb

**Exceptions:** none

### ADDUI - Register-Immediate

**Description:**

Add a register and immediate value and place the sum in the target register. This instruction will never cause an exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 4Ch8 | Pn4 | Pc4 |

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 31 22 | 21 16 | 15 8 | 7 0 | |
| Immediate9..0 | Rt6 | 47h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra + Immediate

**Exceptions:** none

### AND - Register-Register

**Description:**

Bitwise and’s two registers and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 00h6 | Rt6 | Rb6 | Ra6 | 50h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra & Rb

**Exceptions:** none

### ANDC – And with Compliment

**Description:**

Bitwise and’s a register Ra with the compliment of register Rb and places the result in a target register. There is no immediate form for this instruction.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 06h6 | Rt6 | Rb6 | Ra6 | 50h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra & ~Rb

**Exceptions:** none

### ANDI - Register-Immediate

**Description:**

Bitwise and’s register and an immediate value and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 53h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Rt = Ra & immediate

**Exceptions:** none

### BCDADD - Register-Register

**Description:**

Adds two registers using BCD arithmetic and places the result in a target register. Only the low order byte of the register is used. The result is an eight bit BCD number.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 00h6 | Rt6 | Rb6 | Ra6 | F5h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra + Rb

**Exceptions:** none

### BCDMUL - Register-Register

**Description:**

Multiplies two registers using BCD arithmetic and places the result in a target register. Only the low order byte of the register is used. The result is a 16 bit BCD value.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 02h6 | Rt6 | Rb6 | Ra6 | F5h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 Only

**Operation:**

Rt = Ra \* Rb

**Exceptions:** none

### BCDSUB - Register-Register

**Description:**

Subtracts two registers using BCD arithmetic and places the result in a target register. Only the low order byte of the register is used. The result is an eight bit BCD number.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 01h6 | Rt6 | Rb6 | Ra6 | F5h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra - Rb

**Exceptions:** none

### BFCHG – Bit-field Change

**Description:**

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

**Instruction Format:**

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 4744 | 43 40 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | 34 | me6 | mb6 | Rt6 | Ra6 | AAh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Exceptions:** none

### BFCLR – Bit-field Clear

**Description:**

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

**Instruction Format:**

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 4744 | 43 40 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | 24 | me6 | mb6 | Rt6 | Ra6 | AAh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Exceptions:** none

### BFEXT – Bit-field Extract

**Description:**

Extracts a bit-field from register Ra located between the mask begin (mb) and mask end (me) bits and places the sign extended result into the target register.

**Instruction Format:**

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 4744 | 43 40 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | 54 | me6 | mb6 | Rt6 | Ra6 | AAh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Exceptions:** none

### BFEXTU – Bit-field 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.

**Instruction Format:**

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 4744 | 43 40 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | 44 | me6 | mb6 | Rt6 | Ra6 | AAh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Exceptions:** none

### BFINS – Bit-field Insert

**Description:**

Inserts a bit-field into the target register located between the mask begin (mb) and mask end (me) bits from the low order bits of Ra.

**Instruction Format:**

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 4744 | 43 40 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | 04 | me6 | mb6 | Rt6 | Ra6 | AAh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Exceptions:** none

### BFINSI – Bit-field Insert Immediate

**Description:**

Inserts a bit-field into the target register located between the mask begin (mb) and mask end (me) bits from the bits specified in the instruction.

**Instruction Format:**

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 4744 | 43 40 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | 64 | me6 | mb6 | Rt6 | Imm6 | AAh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Exceptions:** none

### BFSET – Bit-field Set

**Description:**

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

**Instruction Format:**

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 4744 | 43 40 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | 14 | me6 | mb6 | Rt6 | Ra6 | AAh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Exceptions:** none

### BITI – Test bits Register-Immediate

**Description:**

Logically and’s register and an immediate value and places the result in a predicate register. If the result of the ‘and’ operation is zero the predicate register’s zero flag is set, otherwise it is cleared. If the result is negative the predicate’s less than flag is set, otherwise it is cleared.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 28 | 26 | 25 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | ~2 | Pt4 | Ra6 | 46h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Pt = flag results( Ra & immediate)

**Predicate Results:**

|  |  |
| --- | --- |
| Predicate flag | Setting |
| eq | set if result is zero |
| lt | set if result is negative |
| ltu | set if result is odd (bit 0 is set) |
|  |  |

**Exceptions:** none

### BR - Relative Branch

**Description:**

A branch is made relative to the address of the next instruction.

* The twelve bit displacement field cannot be extended with an immediate constant prefix. Branches are executed immediately in the instruction fetch stage of the processor before it is known if there is a prefix present.

**Instruction Format:**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 16 | 15 8 | | 7 0 | |
| Disp7..0 | 3h4 | D11..8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s / Branch

**Operation:**

PC <= PC + displacement

**Exceptions:** none

### BRK –Break

**Description:**

This instruction contains only a predicate byte. The Break exception is executed. The core will be switched to kernel mode.

**Instruction Format:**

|  |  |
| --- | --- |
| 7 0 | |
| 04 | 04 |

### BSR - Branch to Subroutine

**Description:**

This is an alternate mnemonic for the JSR instruction. A jump is made to the sum of the sign extended displacement supplied in the displacement field of the instruction and the specified code address register Cr.

The subroutine return address is stored in a code address register specified in the Crt field of the instruction.

Typically code address register #1 is used to store the return address.

**Instruction Formats:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 47 24 | 23 20 | 19 16 | 15 8 | 7 0 | |
| Displacement23..0 | 154 | Crt4 | A2h8 | Pn4 | Pc4 |

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 24 | 23 20 | 1916 | 15 8 | 7 0 | |
| Displacement15..0 | 154 | Crt4 | A1h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Exceptions:** none

### CACHE – Cache Command

**Description:**

This instruction issues a command to the cache.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 31 26 | 2524 | 23 22 | 21 16 | 15 8 | 7 0 | |
| Func6 | ~2 | ~2 | Ra6 | 9Fh8 | Pn4 | Pc4 |

**Operation:**

**Commands:**

|  |  |
| --- | --- |
| Func6 |  |
| 0 | Invalidate entire instruction cache |
| 1 | Invalidate instruction cache line (address in Ra) |
| 32 | Invalidate entire data cache |
| 33 | Invalidate data cache line (address in Ra) |
|  |  |

### CAS – Compare and Swap

**Description:**

If the contents of the addressed memory cell is equal to the contents of Rb then a sixty-four bit value is stored to memory from the source register Rc. The original contents of the memory cell are loaded into register Rt. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be word aligned. If the operation was successful then Rt and Rb will be the same value. 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.

The stack pointer cannot be used as the target register.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 47 40 | 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement7..0 | Rt6 | Rc6 | Rb6 | Ra6 | 97h8 | Pn4 | Pc4 |

**Operation:**

Rt = memory [Ra + displacement]

if memory[Ra + displacement] = Rb

memory[Ra + displacement] = Rc

**Assembler:**

CAS Rt,Rb,Rc,offset[Ra]

### CHKI - Register-Immediate

**Description:**

Check register against bounds. The comparisons are signed comparisons. There is no unsigned form of this instruction. If the register is inside the bounds, the target predicate register equals flag is set, otherwise it is cleared.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 4744 | 4340 | 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Pt4 | Immediate11..0 | Rb6 | Ra6 | 45h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

if (Rb < Ra or Rb >= Immediate)

Pt.eq = 0

else

Pt.eq = 1

**Exceptions:** none

### CHKX- Register-Register

**Description:**

Check register against bounds. The comparisons are signed comparisons. There is no unsigned form of this instruction. This instruction may cause a check exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 14h6 | Rc6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

if (Rc < Ra || Rc >= Rb)

check exception

**Exceptions:** bounds check

### CHKXI - Register-Immediate

**Description:**

Check register against bounds. The comparisons are signed comparisons. There is no unsigned form of this instruction. This instruction may cause a check exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rb6 | Ra6 | 5Dh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

if (Rb < Ra or Rb >= Immediate)

check exception

**Exceptions:** bounds check

### CLI – Clear Interrupt Mask

**Description:**

This instruction is used to enable interrupts. This instruction is available only while operating in kernel mode.

**Instruction Format:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| FAh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Operation:**

im = 0

**Exceptions:** privilege violation

### CMP Register-Register Compare

**Description:**

The register compare instruction compares two registers and sets the flags in the target predict register as a result.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 3128 | 27 22 | 21 16 | 15 12 | 11 8 | 7 0 | |
| 04 | Rb6 | Ra6 | 14 | Pt4 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

if signed Ra < signed Rb

P.lt = true

else

P.lt = false

if unsigned Ra < unsigned Rb

P.ltu = true

else

P.ltu = false

if Ra = Rb

P.eq = true

else

P.eq = false

**Exceptions:** none

### CMPI Register-Immediate Compare

**Description:**

The register immediate compare instruction compares a register to an immediate value and sets the flags in the target predict register as a result. Both a signed and unsigned comparison take place at the same time.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 22 | 21 16 | 15 12 | 11 8 | 7 0 | |
| Immed10 | Ra6 | 24 | Pt4 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

if signed Ra < signed immediate

P.lt = true

else

P.lt = false

if unsigned Ra < unsigned immediate

P.ltu = true

else

P.ltu = false

if Ra = immediate

P.eq = true

else

P.eq = false

### CNTLO- Count Leading Ones

**Description:**

This instruction counts the number of leading ones in a register and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 64 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

**Exceptions:** none

### CNTLZ- Count Leading Zeros

**Description:**

This instruction counts the number of leading zeros in a register and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 54 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

**Exceptions:** none

### CNTPOP- Population Count

**Description:**

This instruction counts the number of one bits in a register and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 74 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

**Exceptions:** none

### COM – Bitwise Compliment

**Description:**

This instruction performs a bitwise compliment on a register and places the result in a target register. If bit is a one then the bit is replaced with is zero otherwise it is replaced with a one.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| B4 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = ~ Ra

**Exceptions:** none

### CPUID – CPU Identification

**Description:**

This instruction returns general information about the core. Register Ra is used as a table index to determine which row of information to return.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 04 | Rt6 | Ra6 | 41h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Info[Ra]

**Exceptions**: none

|  |  |  |
| --- | --- | --- |
| Index | bits | Information Returned |
| 0 | 63 to 0 | The processor core identification 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. |
| 2 | 63 to 0 | Manufacturer name first eight chars “Finitron” |
| 3 | 63 to 0 | Manufacturer name last eight characters |
| 4 | 63 to 0 | CPU class “64BitSS” |
| 5 | 63 to 0 | CPU class |
| 6 | 63 to 0 | CPU Name “Thor” |
| 7 | 63 to 0 | CPU Name |
| 8 | 63 to 0 | Model Number “M1” |
| 9 | 63 to 0 | Serial Number “1234” |
| 10 | 63 to 0 | Features bitmap |
| 11 | 31 to 0 | Instruction Cache Size (32kB) |
| 11 | 63 to 32 | Data cache size (16kB) |

### DIV - Register-Register Divide

**Description:**

Performs a signed division of two registers and places the quotient in the target register. This instruction may cause an overflow or divide by zero exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 03h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 65

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra / Rb

**Exceptions**: divide by zero

### DIVI - Register-Immediate Divide

**Description:**

Performs a signed divide of a register and an immediate value and places the result in a target register. This instruction may cause an overflow or divide by zero exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 4Bh8 | Pn4 | Pc4 |

**Clock Cycles:** 65

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra / immediate

**Exceptions**: divide by zero

### DIVIU – Unsigned Register-Immediate Divide

**Description:**

Performs an unsigned divide of a register and an immediate value and places the result in a target register. This instruction will not cause an overflow or divide by zero exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 4Fh8 | Pn4 | Pc4 |

**Clock Cycles:** 65

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra / immediate

**Exceptions:** none

### DIVU – Unsigned Register-Register Divide

**Description:**

Performs an unsigned division of two registers and places the quotient in the target register. This instruction not cause an overflow or divide by zero exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 07h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 65

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra / Rb

**Exceptions:** none

### ENOR - Register-Register

**Description:**

Bitwise exclusive or register with register and place inverted result in target register.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 05h6 | Rt6 | Rb6 | Ra6 | 50h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = ~(Ra ^ Rb)

**Exceptions:** none

### EOR - Register-Register

**Description:**

Bitwise exclusive or register with register and place result in target register.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 02h6 | Rt6 | Rb6 | Ra6 | 50h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra ^ Rb

**Exceptions:** none

### EORI - Register-Immediate

**Description:**

Bitwise exclusive or register with immediate and place result in target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 55h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra ^ immediate

**Exceptions:** none

### INC – Increment Memory

**Description:**

Memory is incremented by the amount specified in the instruction. The memory address is the sum of the sign extended displacement and register Ra. The amount is between -128 and +127. Note that the increment is not an atomic memory operation. The bus is not locked during the increment to allow cached data to be incremented. For atomic memory operations see the [CAS](#_CAS_–_Compare) instruction.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 47 40 | 39 28 | 27 22 | | 21 16 | 15 8 | 7 0 | |
| Amt8 | Displacement11..0 | O3 | Sz3 | Ra6 | C7h8 | Pn4 | Pc4 |

**Execution Units:** All Memory

**Operation:**

(mem[Ra+offset]) = (mem[Ra+offset]) + amt

### IMM64,IMM56,IMM48,IMM40,IMM32,IMM24,IMM16

**Immediate Extensions**

The immediate extension predicates are used to extend the immediate constant of the following instruction. The extensions may add from one to seven bytes more to the constant. Most, but not all instructions can accept a predicated immediate.

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Immediate | | | | | | | Predicate | |
| Immediate63..8 | | | | | | | 84 | 04 |
| Immediate55..8 | | | | | | 74 | 04 |
| Immediate47..8 | | | | | 64 | 04 |
| Immediate39..8 | | | | 54 | 04 |
| Immediate31..8 | | | 44 | 04 |
| Immediate23..8 | | 34 | 04 |
| Immediate15..8 | 24 | 04 |

**Clock Cycles:** 1

**Execution Units: Enqueue**

**Exceptions:** none

### INT –Interrupt

**Description:**

This instruction calls a system function located as the sum of the zero extended offset times 16 plus code address register 12. The return address is stored in the IPC register (code address register #14).

The offset field of this instruction cannot be extended.

Note that this instruction is automatically invoked for hardware interrupt processing. This instruction would not normally be used by software and is not supported by the assembler. The return address stored is the address of the interrupt instruction, not the address of the next instruction. To call system routines use the [SYS](#_SYS_–Call_system) instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 24 | 23 20 | 19 16 | 15 8 | 7 0 | |
| Offset7..0 | Ch4 | Eh4 | A6h8 | Pn4 | Pc4 |

### JCI, JCIX – Jump Character Indirect

**Description:**

**This instruction performs a memory indirect jump to a target address. The target address is formed from the sixteen bit data located in memory combined with the upper address bits of the program counter. The return address is stored in a code address register specified in the instruction.**

**For the register indirect with displacement form register Ra is scaled by two before use in forming an address. For the scaled indexed form of the instruction register Rb is scaled by two before use in forming an address.**

**This instruction is used when a table of code addresses is present in memory. The code address table may be compressed by eliminating the upper address bits from the table. The table should be entirely located within the same upper address bits as the address of the instruction.**

**Instruction Formats:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 28 | 2726 | 25 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | 12 | Ct4 | Ra6 | 8Dh8 | Pn4 | Pc4 |

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 3332 | 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | ~2 | 12 | Ct4 | Rb6 | Ra6 | B7h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s

**Operation:**

Ct = pc

pc = pc[63:16],mem[Ra\*2 + displacement]16

**Exceptions:** DBG TLB LMT DBE

**Usage:**

The following example replaces about five lines of code with just a single line of code by making use of the JCI instruction. The code is part of a dispatch routine for a BIOS call.

**Using JCI**

|  |
| --- |
| jci c1,cs:VideoBIOS\_FuncTable[r6] |

**Without using JCI**

|  |
| --- |
| ldi r10,#VideoBIOS\_FuncTable  lcu r10,cs:[r10+r6\*2]  ori r10,r10,#VideoBIOSCall & 0xFFFFFFFFFFFF0000 ; recover high order bits  mtspr c2,r10  jsr [c2] |

### JHI, JHIX – Jump Half-word Indirect

**Description:**

**This instruction performs a memory indirect jump to a target address. The target address is formed from the thirty-two bit data located in memory combined with the upper address bits of the program counter. The return address is stored in a code address register specified in the instruction.**

**For the register indirect with displacement form register Ra is scaled by four before use in forming an address. For the scaled indexed form of the instruction register Rb is scaled by four before use in forming an address.**

**This instruction is used when a table of code addresses is present in memory. The code address table may be compressed by eliminating the upper address bits from the table. The table should be entirely located within the same upper address bits as the address of the instruction.**

**Instruction Formats:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 28 | 2726 | 25 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | 22 | Ct4 | Ra6 | 8Dh8 | Pn4 | Pc4 |

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 3332 | 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~6 | 22 | Ct4 | Rb6 | Ra6 | B7h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s

**Operation:**

Ct = pc

pc = pc[63:32],mem[Ra\*4 + displacement]32

**Exceptions:** DBG TLB LMT DBE

### JMP - Jump To Address

**Description:**

This is an alternate mnemonic for the JSR instruction.

A jump is made to the sum of the zero extended offset supplied in the offset field of the instruction and the specified code address register Cr. The JMP instruction may be used with an immediate predicate constant in order to extend the address range of the jump.

**Instruction Formats:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 47 24 | 23 20 | 19 16 | 15 8 | 7 0 | |
| Offset23..0 | Cr4 | 04 | A2h8 | Pn4 | Pc4 |

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 24 | 23 20 | 19 16 | 15 8 | 7 0 | |
| Offset15..0 | Cr4 | 04 | A1h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

pc = Cr[n] + offset

**Exceptions:** none

### JSF – Jump to Far Subroutine

**Description:**

Invoke far subroutine call trap (vector #266). Typically this will cause the current program counter and code segment to be saved on stack. This instruction is typically followed by inline parameters which specify the target segment and offset. The trap routine will typically look up the desired segment from one of the descriptor tables.

Stack Frame:

|  |  |
| --- | --- |
| Stack Offset | Item Stored |
| n+5 | segment acr |
| n+4 | reserved |
| n+3 | segment limit |
| n+2 | segment base |
| n+1 | code segment selector |
| n | program counter (return address) |

**Instruction Formats:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| FEh8 | Pn4 | Pc4 |

**Execution Units:** All ALU’s / Branch

**Operation:**

**Exceptions:** DBE, DBG, TLB, LMT

Example:

jsf

align 8

dw targetOffset

dh targetSelector

### JSR - Jump To Subroutine

**Description:**

A jump is made to the sum of the zero extended offset supplied in the offset field of the instruction and the specified code address register Cr. The JSR instruction may be used with an immediate predicate constant in order to extend the address range of the jump.

The subroutine return address is stored in a code address register specified in the Crt field of the instruction. Typically code address register #1 is used.

An immediate constant prefix applied to this instruction overrides offset bits 8 to 23 and acts like an eight bit immediate constant extension used by other instructions.

**Instruction Formats:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 47 24 | 23 20 | 19 16 | 15 8 | 7 0 | |
| Offset23..0 | Cr4 | Crt4 | A2h8 | Pn4 | Pc4 |

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 | 24 | 23 20 | 19 16 | 15 8 | 7 0 | |
| Offset15..0 | | Cr4 | Crt4 | A1h8 | Pn4 | Pc4 |

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 20 | 19 16 | 15 8 | 7 0 | |
| Cr4 | Crt4 | A0h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Cr[t] = pc

pc = Cr[n] + offset

**Exceptions:** none

### JWI, JWIX – Jump Word Indirect

**Description:**

**This instruction performs a memory indirect jump to a target address. The target address is loaded from data located in memory. The return address is stored in a code address register specified in the instruction.**

**For the register indirect with displacement form register Ra is scaled by eight before use in forming an address. For the scaled indexed form of the instruction register Rb is scaled by eight before use in forming an address.**

**Instruction Formats:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 28 | 2726 | 25 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | 32 | Ct4 | Ra6 | 8Dh8 | Pn4 | Pc4 |

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 3332 | 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~6 | 32 | Ct4 | Rb6 | Ra6 | B7h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s

**Operation:**

Ct = pc

pc = mem[Ra\*8 + displacement]64

**Exceptions:** DBG TLB LMT DBE

### LB – Load Byte

**Description:**

An eight bit value is loaded from memory and sign extended, then placed in the target register. The memory address is the sum of the sign extended offset and register Ra.

This instruction will load data from the cache and cause a cache load operation if the data isn’t in the cache. To bypass the cache use the [LVB](#_LVB_–_Load) instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 80h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = sign extend (mem[Ra+offset])

**Exceptions:** DBE, DBG, LMT, TLB

### LBU – Load Byte Unsigned

**Description:**

An eight bit value is loaded from memory and zero extended, then placed in the target register. The memory address is the sum of the sign extended offset and register Ra.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 81h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = zero extend (mem[Ra+offset])

**Exceptions:** DBE, DBG, LMT, TLB

### LBUX – Load Byte Unsigned Indexed

**Description:**

An eight bit value is loaded from memory zero extended and placed in the target register Rt. The memory address is the sum of register Ra and scaled register Rb.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | B1h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = mem[Ra+Rb]

**Exceptions:** DBE, DBG, LMT, TLB

### LBX – Load Byte Indexed

**Description:**

An eight bit value is loaded from memory and placed in the target register. The memory address is the sum of register Ra and scaled register Rb.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | B0h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = sign extend (mem[Ra+Rb])

**Exceptions:** DBE, DBG, LMT, TLB

### LC – Load Character

**Description:**

A sixteen bit value is loaded from memory and sign extended, then placed in the target register. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be character aligned.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 82h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

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

**Exceptions:** DBE, DBG, LMT, TLB

### LCL – Load Cache Line

**Description:**

The cache line is loaded from memory into the cache (instruction or data). The memory address is the sum of the sign extended offset and register Ra.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Tgt6 | Ra6 | 8Fh8 | Pn4 | Pc4 |

**Execution Units:** Cache / Memory

**Operation:**

Rt = sign extend (mem[Ra+offset])

Target:

|  |  |
| --- | --- |
| Tgt6 | Cache |
| 0 | instruction cache |
| 1 | data cache |

### LCU – Load Character Unsigned

**Description:**

A sixteen bit value is loaded from memory and zero extended, then placed in the target register. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be character aligned.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 83h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = zero extend (mem[Ra + displacement])

**Exceptions:** DBE, DBG, LMT, TLB

### LCUX – Load Character Unsigned Indexed

**Description:**

A sixteen bit value is loaded from memory, zero extended and placed in the target register Rt. The memory address is the sum of register Ra and scaled register Rb. The memory address must be character aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | B3h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = mem[Ra + Rb \* scale]

**Exceptions:** DBE, DBG, LMT, TLB

### LCX – Load Character Indexed

**Description:**

A sixteen bit value is loaded from memory, sign extended and placed in the target register Rt. The memory address is the sum of register Ra and scaled register Rb. The memory address must be character aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | B2h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = mem[Ra + Rb \* scale]

**Exceptions:** DBE, DBG, LMT, TLB

### LDI - Load-Immediate

**Description:**

This instruction loads a sign extended immediate constant into a register. The immediate constant may be extended by using an immediate prefix instruction.

**Instruction Format:**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 31 22 | 21 16 | 15 8 | 7 0 | |
| Immediate9..0 | Rt6 | 6Fh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = immediate

### LDIS - Load-Immediate Special

**Description:**

This instruction loads a sign extended immediate constant into a special purpose register. The immediate constant may be extended by using an immediate prefix instruction. Typical usage is to initialize a code address register with a target address.

**Instruction Format:**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 31 22 | 21 16 | 15 8 | 7 0 | |
| Immediate9..0 | Spr6 | 9Dh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Spr = immediate

### LDISEG - Load-Immediate Segment (proposed)

**Description:**

This instruction loads a sign extended immediate constant into a register. The immediate constant may be extended by using an immediate prefix instruction. The upper three bits of the register are set to the value in the LDISEG instruction.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 31 24 | 2322 | 21 16 | 15 9 | 8 | 7 0 | |
| Immediate7..0 | S2..1 | Rt6 | 01111117 | S0 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = immediate

Rt[63:61] = S

### LEA – Load Effective Address

**Description:**

The virtual memory address is placed in the target register. The memory address is the sum of the sign extended displacement and register Ra.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 | 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Disp11..0 | | Rt6 | Ra6 | 68h8 | Pn4 | Pc4 |

**Operation:**

Rt = Ra + Displacement

**Execution Units:** All ALU’s

### LEAX – Load Effective Address Indexed

**Description:**

A virtual memory address is computed and placed in the target register. The address is the sum of register Ra and scaled register Rb.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rt6 | Rb6 | Ra6 | 69h8 | Pn4 | Pc4 |

**Clock Cycles: 1**

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = Ra + Rb \* scale

**Exceptions:** none

### LH – Load Half-Word

**Description:**

A thirty-two bit value is loaded from memory and sign extended, then placed in the target register Rt. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be half-word aligned.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 84h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

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

**Exceptions:** DBE, DBG, LMT, TLB

### LHU – Load Half-word Unsigned

**Description:**

A thirty-two bit value is loaded from memory and zero extended, then placed in the target register Rt. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be half-word aligned.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 85h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = zero extend (mem[Ra + displacement])

**Exceptions:** DBE, DBG, LMT, TLB

### LHUX – Load Half-word Unsigned Indexed

**Description:**

A thirty-two bit value is loaded from memory, zero extended and placed in the target register. The memory address is the sum of register Ra and register Rb. The memory address must be half-word aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | B5h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = mem[Ra+Rb\*scale]

**Exceptions:** DBE, DBG, LMT, TLB

### LHX – Load Half-word Indexed

**Description:**

A thirty-two bit value is loaded from memory sign extended and placed in the target register Rt. The memory address is the sum of register Ra and scaled register Rb. The memory address must be half-word aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | B4h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

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

**Exceptions:** DBE, DBG, LMT, TLB

### LLA – Load Linear Address

**Description:**

A linear memory address is computed and placed in the target register. The linear address is the sum of the sign extended displacement, register Ra, and the segment register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 6Ah8 | Pn4 | Pc4 |

**Clock Cycles:** 2

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = Ra + displacement + segment

**Exceptions:** none

### LLAX – Load Linear Address Indexed

**Description:**

A linear memory address is computed and placed in the target register. The linear address is the sum of register Ra, scaled register Rb, and the specified segment register.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rt6 | Rb6 | Ra6 | B8h8 | Pn4 | Pc4 |

**Clock Cycles: 2**

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = Ra + Rb + segment

**Exceptions:** none

### LOOP – Loop Branch

**Description:**

A branch is made relative to the address of the next instruction if the loop count register is non-zero. The loop count register is decremented by this instruction. The predicate condition must also be met. The loop branch is predicted as always taken and does not consume room in the branch predication tables. The displacement constant may not be extended as the loop takes place in the instruction fetch stage of the core.

**Instruction Format:**

|  |  |  |  |
| --- | --- | --- | --- |
| 23 16 | 15 8 | 7 0 | |
| Disp7..0 | A4h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s / Branch

**Operation:**

If LC <> 0

PC <= PC + displacement

LC = LC - 1

### LVB – Load Volatile Byte

**Description:**

An eight bit value is loaded from memory and sign extended, then placed in the target register. The memory address is the sum of the sign extended displacement and register Ra. This instruction bypasses the data cache. Use this instruction to load data from volatile memory regions such as I/O devices. This instruction may also be used when it is known that the data is better not cached.

There is no indexed or unsigned form for this instruction. The value loaded may be zero extended rather than sign extended by following it with the [ZXB](#_ZXB_–_Zero) instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | ACh8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = sign extend (mem[Ra+offset])

**Exceptions:** DBE, DBG, LMT, TLB

### LVC – Load Volatile Character

**Description:**

A sixteen bit value is loaded from memory and sign extended, then placed in the target register. The memory address is the sum of the sign extended offset and register Ra. This instruction bypasses the data cache. Use this instruction to load data from volatile memory regions such as I/O devices.

There is no indexed or unsigned form for this instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | ADh8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = sign extend (mem[Ra+offset])

**Exceptions:** DBE, DBG, LMT, TLB

### LVH – Load Volatile Half-word

**Description:**

A thirty-two bit value is loaded from memory and sign extended, then placed in the target register. The memory address is the sum of the sign extended offset and register Ra. This instruction bypasses the data cache. Use this instruction to load data from volatile memory regions such as I/O devices.

There is no indexed or unsigned form for this instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | AEh8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = sign extend (mem[Ra+offset])

**Exceptions:** DBE, DBG, LMT, TLB

### LVW – Load Volatile Word

**Description:**

A sixty-four bit value is loaded from memory and sign extended, then placed in the target register. The memory address is the sum of the sign extended offset and register Ra. This instruction bypasses the data cache. Use this instruction to load data from volatile memory regions such as I/O devices.

There is no indexed or unsigned form for this instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | AFh8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

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

**Exceptions:** DBE, DBG, LMT, TLB

### LVWAR – Load Volatile Word and Reserve

**Description:**

A sixty-four bit value is loaded from memory and sign extended, then placed in the target register. The memory address is the sum of the sign extended offset and register Ra. Additionally the reserve signal is activated on the bus to tell the memory system to place an address reservation. This instruction bypasses the data cache. Use this instruction to load data from volatile memory regions such as I/O devices. The primary purpose of this instruction is to setup semaphores. See also the [SWCR](#_SWCR_–_Store), [CAS](#_CAS_–_Compare) instructions.

There is no indexed form for this instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 8Bh8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = sign extend (mem[Ra + displacement]); reserve = 1

**Exceptions:** DBE, DBG, LMT, TLB

### LW – Load Word

**Description:**

A sixty-four bit value is loaded from memory and placed in the target register. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be word aligned.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 86h8 | Pn4 | Pc4 |

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Rt6 | Ra6 | D6h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Exceptions:**

If the target register is R0 then this instruction will not cause an exception. Otherwise an exception may be caused by a data-bus error signal input or a TLB miss.

**Operation:**

Rt = mem[Ra + displacement]

**Exceptions:** DBE, DBG, LMT, TLB

### LWS – Load Word Special

**Description:**

A sixty-four bit value is loaded from memory and placed in the special purpose register. The memory address is the sum of the sign extended offset and register Ra. The memory address must be word aligned.

There is no indexed form for this instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 8Eh8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Spr = mem[Ra + displacement]

**Exceptions:** DBE, DBG, LMT, TLB

### LWX – Load Word Indexed

**Description:**

A sixty-four bit value is loaded from memory and placed in the target register. The memory address is the sum of register Ra and scaled register Rb. The memory address must be word aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | B6h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = mem[Ra + Rb\*scale]

**Exceptions:** DBE, DBG, LMT, TLB

### MAX - Register-Register

**Description:**

Determines the maximum of two values in registers Ra and Rb and places the result in the target register Rt.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 11h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

IF Ra < Rb

Rt = Rb

else

Rt = Ra

### MEMDB – Memory Data Barrier

**Description:**

All memory accesses before the MEMDB command are completed before any memory accesses after the data barrier are started. Note that this instruction has an effect even if the predicate is false; this does not affect the correct operation of the program, only performance is affected.

**Instruction Format:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| F9h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** Memory

### MEMSB – Memory Synchronization Barrier

**Description:**

All instructions before the MEMSB command are completed before any memory access is started. Note that this instruction has an effect even if the predicate is false; this does not affect the correct operation of the program, only performance is affected.

**Instruction Format:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| F8h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** Memory

### MFSPR – Special Register-Register

**Description:**

This instruction moves from a special purpose register into a general purpose one.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Rt6 | Spr6 | A8h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Spr[n]

**Special Purpose Registers**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Reg # | R/W |  |  |  |
| 00-15 | RW | PRED | specific predicate register #0 to 15 |  |
| 16-31 | RW | CREGS | Code address register array (C0 to C15) |  |
| 32-39 | RW | SREGS | Segment base register array (zs,ds,es,fs,gs,hs,ss,cs) |  |
| 40-47 |  |  | * reserved for segmentation |  |
| 48 | R | MID | Machine ID |  |
| 49 | R | FEAT | Features |  |
| 50 | R | TICK | Tick count |  |
| 51 | RW | LC | Loop Counter |  |
| 52 | RW | PREGS | Predicate register array |  |
| 53 | RW | ASID | address space identifier |  |
| 59 | RW | EXC | exception cause register |  |
| 60 | W | BIR | Breakout index register |  |
| 61 | RW |  | Breakout register - additional spr’s |  |
| 63 |  |  | reserved |  |

Additional Spr’s are available by setting the breakout index register to an Sor index value, then accessing the Spr through the breakout register.

### MIN - Register-Register

**Description:**

Determines the minimum of two values in registers Ra and Rb and places the result in the target register Rt.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 10h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

IF Ra < Rb

Rt = Ra

else

Rt = Rb

### MLO – Mystery Logical Operation

**Description:**

The MLO instruction performs an operation that is determined at run-time as opposed to compile time. The operation to be performed is one of the register-register logical operations. Register Rc contains the function code for the operation. Registers Ra and Rb are the operands to the instruction. The result is placed in register Rt.

The MLO instruction is provided to help avoid writing self-modifying code for performance reasons.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Rt6 | Rc6 | Rb6 | Ra6 | 51h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra op(Rc) Rb

### MODI –Register-Immediate Modulus

**Description:**

Performs a signed divide of a register and an immediate value and places the remainder in a target register. This instruction may cause an overflow or divide by zero exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 5Bh8 | Pn4 | Pc4 |

**Clock Cycles:** 65

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra % immediate

**Exceptions:** DBZ OFL

### MODUI – Unsigned Register-Immediate Modulus

**Description:**

Performs an unsigned divide of a register and an immediate value and places the remainder in a target register. This instruction will not cause an overflow or divide by zero exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 5Fh8 | Pn4 | Pc4 |

**Clock Cycles:** 65

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra % immediate

**Exceptions:** none

### MOV - Register-Register

**Description:**

This instruction moves one general purpose register to another. This instruction is shorter and uses one less register port than using the OR instruction to move between registers.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 04 | Rt6 | Ra6 | A78 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra

### MOVS – Move Special Register- Special Register

**Description:**

This instruction moves one special purpose register to another. The primary purpose of this instruction is to allow transfers directly between code address or segment registers.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sprt6 | Spr6 | AB8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Sprt = Spra

### MTSPR –Register-Special Register

**Description:**

Move a general purpose register into a special purpose register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Spr6 | Ra6 | A9h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Spr[n] = Ra

### MUL - Register-Register Multiply

**Description:**

Performs a signed multiply of two registers and places the product in the target register. This instruction may cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 02h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 5

**Execution Units:** ALU #0 Only

**Operation:**

Rt = Ra \* Rb

### MULI - Register-Immediate Multiply

**Description:**

Performs a signed multiply of a register and an immediate value and places the result in a target register. This instruction may cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 4Ah8 | Pn4 | Pc4 |

**Clock Cycles:** 5

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra \* immediate

### MULU – Unsigned Register-Register Multiply

**Description:**

Performs an unsigned multiply of two registers and places the product in the target register. This instruction will never cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 06h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 5

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra \* Rb

**Exceptions:** none

### MULUI – Unsigned Register-Immediate Multiply

**Description:**

Performs an unsigned multiply of a register and an immediate value and places the result in a target register. This instruction will never cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 4Eh8 | Pn4 | Pc4 |

**Clock Cycles:** 5

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra \* immediate

**Exceptions:** none

### MUX – Multiplex

**Description:**

If a bit in Ra is set then the bit of the target register is set to the corresponding bit in Rb, otherwise the bit in the target register is set to the corresponding bit in Rc.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Rt6 | Rc6 | Rb6 | Ra6 | 72h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

For n = 0 to 63

If Ra[n] is set then

Rt[n] = Rb[n]

else

Rt[n] = Rc[n]

**Exceptions:** none

### NAND - Register-Register

**Description:**

Bitwise and’s two registers inverts the result and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 03h6 | Rt6 | Rb6 | Ra6 | 50h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = ~(Ra & Rb)

**Exceptions:** none

### NEG - Negate Register

**Description:**

This instruction negates a register and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 14 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = - Ra

### NOP – No Operation

**Description:**

This instruction contains only a predicate byte. This is a single byte no-operation code. It can be used to align code addresses or as a fill byte.

The NOP operation is not queued by the processing core and is not present in the pipeline.

**Instruction Format:**

|  |  |
| --- | --- |
| 7 0 | |
| 14 | 04 |

**Two byte Format:**

|  |  |  |  |
| --- | --- | --- | --- |
| 18 8 | | 7 0 | |
| F4 | 14 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** None

**Operation:**

<none>

**Exceptions:** none

### NOR - Register-Register

**Description:**

Bitwise inclusively or two registers and place inverted result in the target register.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 04h6 | Rt6 | Rb6 | Ra6 | 50h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = ~(Ra | Rb)

**Exceptions:** none

### NOT – Logical Not

**Description:**

This instruction performs a logical NOT on a register and places the result in a target register. If the value in a register is non-zero then the result is zero. If the value in the register is zero then the result is one. This instruction results in either a one or zero being placed in the target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 24 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = ! Ra

**Exceptions:** none

### OR - Register-Register

**Description:**

Bitwise inclusively or two registers and place the result in the target register.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 01h6 | Rt6 | Rb6 | Ra6 | 50h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra | Rb

**Exceptions:** none

### ORC – Or with Compliment

**Description:**

Bitwise inclusively or register Ra and the compliment of register Rb and place the result in the target register.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 07h6 | Rt6 | Rb6 | Ra6 | 50h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra | ~Rb

**Exceptions:** none

### ORI - Register-Immediate

**Description:**

Bitwise inclusively or register with immediate and place the result in the target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 54h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra | imm

**Exceptions:** none

### PAND – Predicate And

**Description:**

Bitwise and’s the specified predicate register bits and places the result in a target bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 06 | Bt6 | Bb6 | Ba6 | 42h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Pr[Rt] = Pr[Ra] & Pr[Rb]

**Exceptions:** none

### PANDC – Predicate And Compliment

**Description:**

Bitwise and’s the specified predicate register bits and places the result in a target bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 66 | Bt6 | Bb6 | Ba6 | 42h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Pr[Rt] = Pr[Ra] & ~Pr[Rb]

**Exceptions:** none

### PEOR – Predicate Exclusive Or

**Description:**

Bitwise exclusive or’s the specified predicate register bits and places the result in a target bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 26 | Bt6 | Bb6 | Ba6 | 42h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Pr[Rt] = Pr[Ra] ^ Pr[Rb]

**Exceptions:** none

### PENOR – Predicate Exclusive Nor

**Description:**

Bitwise exclusive or’s the specified predicate register bits and places the inverted result in a target bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 56 | Bt6 | Bb6 | Ba6 | 42h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Pr[Rt] = ~(Pr[Ra] ^ Pr[Rb])

**Exceptions:** none

### PNAND – Predicate Nand

**Description:**

Bitwise and’s the specified predicate register bits and places the inverted result in a target bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 36 | Bt6 | Bb6 | Ba6 | 42h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Pr[Rt] = ~( Pr[Ra] & Pr[Rb])

**Exceptions:** none

### POR – Predicate Or

**Description:**

Bitwise or’s the specified predicate register bits and places the result in a target bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 16 | Bt6 | Bb6 | Ba6 | 42h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Pr[Rt] = Pr[Ra] | Pr[Rb]

**Exceptions:** none

### PORC – Predicate Or Compliment

**Description:**

Bitwise or’s the specified predicate register bits and places the result in a target bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 76 | Bt6 | Bb6 | Ba6 | 42h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Pr[Rt] = Pr[Ra] | ~Pr[Rb]

**Exceptions:** none

### PNOR – Predicate Nor

**Description:**

Bitwise or’s the specified predicate register bits and places the inverted result in a target bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 46 | Bt6 | Bb6 | Ba6 | 42h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** AllALU’s

**Operation:**

Pr[Rt] = ~(Pr[Ra] | Pr[Rb])

**Exceptions:** none

### ROL – Rotate Left

**Description:**

Rotate register Ra left by Rb bits and place the result into register Rt. The most significant bit is shifted into the least significant bit. The rotation takes place modulo 64 of the value in register Rb (only the lower six bits of the register are used).

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 04h6 | Rt6 | Rb6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra << Rb

**Exceptions:** none

### ROLI – Rotate Left by Immediate

**Description:**

Rotate register Ra left by n bits and place the result into register Rt. The most significant bit is shifted into the least significant bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 14h6 | Rt6 | Imm6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra << #n

**Exceptions:** none

### ROR – Rotate Right

**Description:**

Rotate register Ra right by Rb bits and place the result into register Rt. The least significant bit is shifted into the most significant bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 05h6 | Rt6 | Rb6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra >> Rb

**Exceptions:** none

### RORI – Rotate Right by Immediate

**Description:**

Rotate register Ra right by n bits and place the result into register Rt. The least significant bit is shifted into the most significant bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 15h6 | Rt6 | Imm6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra >> #n

**Exceptions:** none

### RTD – Return from Debug Exception Routine

**Description:**

The program counter is loaded with the value contained in code address register #11 which is the DPC register. This instruction may cause the core to transition back to applications mode. It is only available while the core is in kernel mode.

**Instruction Format:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| FCh8 | Pn4 | Pc4 |

**Operation:**

PC = Cr[11]

if (StatusEXL > 0) StatusEXL = StatusEXL - 1

**Exceptions:** PRIV

### RTE – Return from Exception Routine

**Description:**

The program counter is loaded with the value contained in code address register #13 which is the EPC register. This instruction may cause the core to transition back to applications mode. It is only available while the core is in kernel mode.

**Instruction Format:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| F3h8 | Pn4 | Pc4 |

**Operation:**

PC = Cr[13]

if (StatusEXL > 0) StatusEXL = StatusEXL - 1

**Exceptions:** PRIV

### RTF – Return from Far Subroutine

**Description:**

Invoke the return from far subroutine trap (vector #265). This will cause the program counter and code segment to be reloaded with values prior to calling the subroutine. The information for the code segment and program counter is typically stored on the stack by a far subroutine call.

Stack Frame:

|  |  |
| --- | --- |
| Stack Offset | Item Stored |
| n+5 | segment acr |
| n+4 | reserved |
| n+3 | segment limit |
| n+2 | segment base |
| n+1 | code segment selector |
| n | program counter (return address) |

**Instruction Formats:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| FDh8 | Pn4 | Pc4 |

**Execution Units:** All ALU’s / Branch

**Operation:**

The exact operation performed depends on the system software.

CS = stack[n+1]

PC = stack[n]

SP = SP + 48

**Exceptions:** DBE, DBG, TLB, LMT

Software Example

|  |
| --- |
|  |
| ;----------------------------------------------------------------------------  ; Far return exception handler  ;  ; Far returns have their own entry in the vector table so that the address  ; of this routine doesn't have to be hard-coded. It also allows for a short  ; instruction to be used.  ;  ; This routine must be in the non-segmented code area as it modifies the CS.  ; The entire descriptor was saved off by the call so that on return it  ; doesn't need to be fetched from the descriptor table.  ; It may be desirable to validate the segment info fetched from the stack  ; for security reasons. This sample assumes the segment info is valid.  ;  ; Used like:  ; rtf ; invoke far return routine  ;----------------------------------------------------------------------------  \_FarRet:  ; Get back the code segment values  mtspr segsw,#7  sync  lws c1,[sp] ; Get offset  lws cs,8[sp]  lws segbase,16[sp]  lws seglmt,24[sp]  lws segacr,40[sp]  sync  addui sp,sp,#48 ; adjust stack  jmp [c1] ; jump back to the return address |

### RTI – Return from Interrupt Routine

**Description:**

The program counter is loaded with the value contained in code address register #14 which is the IPC register. Additionally the interrupt mask is cleared to enable interrupts. This instruction will cause the core to transition back to applications mode. It is only available while the core is in kernel mode.

**Instruction Format:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| F4h8 | Pn4 | Pc4 |

**Operation:**

pc = Cr[14]

Flags = FlagsBackup

Flags.im = 0

StatusHWI = 0

**Exceptions:** PRIV

### RTS – Return from Subroutine

**Description:**

The program counter is loaded with the value contained in the specified code address register plus a zero extended four bit immediate constant. The constant may not be extended. This allows the return instruction to return a few bytes past the usual return address. This is used to allow static parameters to be passed to the subroutine in inline code.

Note that the JMP instruction may also be used to return from a subroutine. Similarly this instruction may also be used to perform a jump to one of the first sixteen addresses relative to a code address register.

**Instruction Formats:**

**C1 Implied**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| F2h8 | Pn4 | Pc4 |

**Return past calling address**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 20 | 19 16 | 15 8 | 7 0 | |
| Cr4 | Im4 | A3h8 | Pn4 | Pc4 |

**Execution Units:** All ALU’s / Branch

**Operation:**

PC = Cr[N] +Imm4

**C1 Implied Operation:**

PC = Cr[1]

**Exceptions:** none

### SB – Store Byte

**Description:**

An eight bit value is stored to memory from the source register Rb. The memory address is the sum of the sign extended displacement and register Ra.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rt6 | Ra6 | 90h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra+offset] = Rb[7..0]

**Exceptions**: DBE, DBG, TLB, LMT

### SBX – Store Byte Indexed

**Description:**

An eight bit value is stored to memory from the source register Rc. The memory address is the sum of register Ra and Rb.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | C0h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra+Rb] = Rb

**Exceptions**: DBE, DBG, TLB, LMT

### SC – Store Character

**Description:**

A sixteen bit value is stored to memory from the source register Rb. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be character aligned.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rb6 | Ra6 | 91h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra+displacement] = Rb[15..0]

**Exceptions**: DBE, DBG, TLB, LMT

### SCX – Store Character Indexed

**Description:**

A sixteen bit value is stored to memory from the source register Rc. The memory address is the sum of register Ra and scaled register Rb. The memory address must be character aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | C1h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra+Rb\*scale] = Rb

**Exceptions**: DBE, DBG, TLB, LMT

### SEI – Set Interrupt Mask

**Description:**

The interrupt mask is set, disabling maskable interrupts. This instruction is available only in kernel mode.

**Instruction Format:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| FBh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Operation:**

im = 1

**Exceptions:** privilege violation

### SH – Store Half-word

**Description:**

A thirty-two bit value is stored to memory from the source register Rb. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be half-word aligned.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rb6 | Ra6 | 92h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra + displacement] = Rb[31..0]

**Exceptions**: DBE, DBG, TLB, LMT

### SHL – Shift Left

**Description:**

Shift register Ra left by Rb bits and place result into register Rt. A zero is shifted into the least significant bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 00h6 | Rt6 | Rb6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra << Rb

**Exceptions:** none

### SHLI – Shift Left by Immediate

**Description:**

Shift register Ra left by n bits and place result into register Rt. A zero is shifted into the least significant bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 10h6 | Rt6 | Imm6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra << #n

**Exceptions:** none

### SHLU – Shift Left Unsigned

**Description:**

Shift register Ra left by Rb bits and place the result into register Rt. A zero is shifted into the least significant bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 02h6 | Rt6 | Rb6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra << Rb

**Exceptions:** none

### SHLUI – Shift Left Unsigned by Immediate

**Description:**

Shift register Ra left by n bits and place the result into register Rt. A zero is shifted into the least significant bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 12h6 | Rt6 | Imm6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra << #n

**Exceptions:** none

### SHR – Shift Right

**Description:**

Shift register Ra right by Rb bits and place result in register Rt. The sign bit is preserved.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 01h6 | Rt6 | Rb6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra >> Rb

**Exceptions:** none

### SHRI – Shift Right by Immediate

**Description:**

Shift register Ra right by n bits and place result into register Rt. The sign bit is preserved.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 11h6 | Rt6 | Imm6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra >> #n

**Exceptions:** none

### SHRU – Shift Right Unsigned

**Description:**

Shift register Ra right by register Rb bits. A zero is shifted into the sign bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 03h6 | Rt6 | Rb6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra >> Rb

**Exceptions:** none

### SHRUI – Shift Right Unsigned by Immediate

**Description:**

Shift register Ra right by n bits and place result into register Rt. A zero is shifted into the sign bit.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 13h6 | Rt6 | Imm6 | Ra6 | 58h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra >> #n

**Exceptions:** none

### SHX – Store Half-word Indexed

**Description:**

A thirty-two bit value is stored to memory from the source register Rb. The memory address is the sum of register Ra and scaled register Rb. The memory address must be half-word aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | C2h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra+Rb] = Rb

**Exceptions**: DBE, DBG, TLB, LMT

### STCMP – String Compare

**Description:**

This instruction compares data from the memory location addressed by Ra plus Rc to the memory location addressed by Rb plus Rc until the loop counter LC reaches zero or until a mismatch occurs. Rc acts as an index and increments or decrements by the size of the operation as the move takes place. This instruction is interruptible. The data must be in the same segment and appropriately aligned. The loop counter is set to zero when a mismatch occurs. The index of the mismatch is contained in register Rc.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 37 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~3 | O3 | Rc6 | Rb6 | Ra6 | 9Ah8 | Pn4 | Pc4 |

|  |  |  |
| --- | --- | --- |
| O3 | Assembler Mnemonic |  |
| 0 | STCMP.BI | bytes incrementing |
| 1 | STCMP.CI | characters incrementing |
| 2 | STCMP.HI | half-word incrementing |
| 3 | STCMP.WI | words incrementing |
| 4 | STCMP.BD | bytes decrementing |
| 5 | STCMP.CD | characters decrementing |
| 6 | STCMP.HD | half-word decrementing |
| 7 | STCMP.WD | word decrementing |

**Execution Units:** Memory

**Operation:**

temp = 0

while LC <> 0

mem[Rb + Rc] = mem[Ra + Rc]

Rc = Rc +/- amt

LC = LC – 1

### STFND – String Find

**Description:**

This instruction compares data from the memory location addressed by Ra plus Rc to the data in register Rb until the loop counter LC reaches zero or until a match occurs. Rc acts as an index and increments or decrements by the size of the operation as the move takes place. This instruction is interruptible. The data must be appropriately aligned. The loop counter is set to zero when a match occurs. The index of the match is contained in register Rc.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 37 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~3 | O3 | Rc6 | Rb6 | Ra6 | 9Bh8 | Pn4 | Pc4 |

|  |  |  |
| --- | --- | --- |
| O3 | Assembler Mnemonic |  |
| 0 | STFND.BI | bytes incrementing |
| 1 | SFND.CI | characters incrementing |
| 2 | STFND.HI | half-word incrementing |
| 3 | STFND.WI | words incrementing |
| 4 | STFND.BD | bytes decrementing |
| 5 | STFND.CD | characters decrementing |
| 6 | STFND.HD | half-word decrementing |
| 7 | STFND.WD | word decrementing |

**Execution Units:** Memory

**Operation:**

temp = 0

while LC <> 0

if (mem[Ra + Rc] = Rb)

stop

Rc = Rc +/- amt

LC = LC – 1

### STI – Store Immediate

**Description:**

A six bit value is zero extended to sixty-four bits and stored to memory. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be word aligned.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Imm6 | Ra6 | 96h8 | Pn4 | Pc4 |

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra + displacement] = zero extend (Imm[5..0])

### STIX – Store Immediate Indexed

**Description:**

A ten bit value is zero extended to sixty-four bits and stored to memory. The memory address is the sum of register Ra and scaled register Rb. The memory address must be word aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 35 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Imm9..6 | Sc2 | Imm5..0 | Rb6 | Ra6 | C6h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra + Rb \* scale] = zero extend (Imm[9..0])

### STMOV – String Move

**Description:**

This instruction moves a data from the memory location addressed by Ra plus Rc to the memory location addressed by Rb plus Rc until the loop counter LC reaches zero. Rc acts as an index and increments or decrements by the size of the operation as the move takes place. This instruction is interruptible. The data moved must be in the same segment and appropriately aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 37 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~3 | O3 | Rc6 | Rb6 | Ra6 | 99h8 | Pn4 | Pc4 |

|  |  |  |
| --- | --- | --- |
| O3 | Assembler Mnemonic |  |
| 0 | STMOV.BI | move bytes incrementing |
| 1 | STMOV.CI | move characters incrementing |
| 2 | STMOV.HI | move half-word incrementing |
| 3 | STMOV.WI | move words incrementing |
| 4 | STMOV.BD | move bytes decrementing |
| 5 | STMOV.CD | move characters decrementing |
| 6 | STMOV.HD | move half-word decrementing |
| 7 | STMOV.WD | move word decrementing |

**Execution Units:** Memory

**Operation:**

temp = 0

while LC <> 0

mem[Rb + Rc] = mem[Ra + Rc]

Rc = Rc +/- amt

LC = LC – 1

### STP – Stop / Slow Down

**Description:**

This instruction controls the core clock rate which affects power consumption. The immediate constant is loaded into a shift register that controls the frequency of clock pulses seen by the processor. Setting the constant to FFFFh provides the maximum clock rate. Setting the constant to zero stops the clock completely. With the clock stopped completely the core must be reset or an NMI interrupt must occur before the core will continue processing. After reset or NMI the core begins processing at a half the maximum clock rate.

**Instruction Format:**

|  |  |  |  |
| --- | --- | --- | --- |
| 31 16 | 15 8 | 7 0 | |
| Immediate16 | F6h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra[31:0]

**Typical Values For Shift Register**

|  |  |
| --- | --- |
| Value |  |
| 0000 | Stop clock completely |
| 8888 | 25% rate |
| AAAA | 50% rate |
| EEEE | 75% rate |
| FFFF | Full power, max clock rate |
|  |  |

**Exceptions:** none

### STSB – Store String Byte

**Description:**

This instruction stores a byte contained in register Rb to consecutive memory locations beginning at the address in Ra until the loop counter LC reaches zero. Ra is updated with by the number of bytes written. This instruction is interruptible.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~3 | 03 | ~6 | Rb6 | Ra6 | 98h8 | Pn4 | Pc4 |

**Execution Units:** Memory

**Operation:**

temp = 0

while LC <> 0

mem[Ra] = Rb[7:0]

Ra = Ra + 1

LC = LC – 1

### STSC – Store String Character

**Description:**

This instruction stores a character (16 bit value) to consecutive memory locations beginning at the address in Ra until the loop counter reaches zero. The memory address must be character aligned. Ra is updated by the number of bytes written. This instruction is interruptible.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~3 | 13 | ~6 | Rb6 | Ra6 | 98h8 | Pn4 | Pc4 |

**Execution Units:** Memory

**Operation:**

temp = 0

while LC <> 0

mem[Ra] = Rb[15:0]

Ra =Ra+ 2

LC = LC – 1

### STSET – String Set

**Description:**

This instruction stores data contained in register Rb to consecutive memory locations beginning at the address in Ra until the loop counter LC reaches zero. Ra is updated with by the number of bytes written. This instruction is interruptible. The data address must be appropriately aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~3 | 03 | ~6 | Rb6 | Ra6 | 98h8 | Pn4 | Pc4 |

**Execution Units:** Memory

**Operation:**

while LC <> 0

mem[Ra] = Rb

Ra = Ra +/- amt

LC = LC – 1

|  |  |  |
| --- | --- | --- |
| O3 | Assembler Mnemonic |  |
| 0 | STSET.BI | set bytes incrementing |
| 1 | STSET.CI | set characters incrementing |
| 2 | STSET.HI | set half-word incrementing |
| 3 | STSET.WI | set words incrementing |
| 4 | STSET.BD | set bytes decrementing |
| 5 | STSET.CD | set characters decrementing |
| 6 | STSET.HD | set half-word decrementing |
| 7 | STSET.WD | set word decrementing |

### STSH – Store String Half-word

**Description:**

This instruction stores a half-word (32 bit value) to consecutive memory locations beginning at the address in Ra until the loop counter reaches zero. The memory address must be half-word aligned. Ra is updated by the number of bytes written. This instruction is interruptible.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~3 | 23 | ~6 | Rb6 | Ra6 | 98h8 | Pn4 | Pc4 |

**Execution Units:** Memory

**Operation:**

temp = 0

while LC <> 0

mem[Ra] = Rb[31:0]

Ra =Ra + 4

LC = LC – 1

### STSW – Store String Word

**Description:**

This instruction stores a word (64 bit value) to consecutive memory locations beginning at the address in Ra until the loop counter reaches zero. The memory address must be half-word aligned. Ra is updated by the number of bytes written. This instruction is interruptible.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 34 | | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~3 | 33 | ~6 | Rb6 | Ra6 | 98h8 | Pn4 | Pc4 |

**Execution Units:** Memory

**Operation:**

temp = 0

while LC <> 0

mem[Ra] = Rb[63:0]

Ra =Ra + 8

LC = LC – 1

### SUB - Register-Register

**Description:**

This instruction subtracts one register from another and places the result into a third register. This instruction may cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 01h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra - Rb

### SUBI - Register-Immediate

**Description:**

This instruction subtracts an immediate value from a register and places the result into a register. This instruction may cause an overflow exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 49h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra – Imm

### SUBU - Register-Register

**Description:**

This instruction subtracts one register from another and places the result into a third register. This instruction never causes an exception.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 05h6 | Rt6 | Rb6 | Ra6 | 40h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra - Rb

### SUBUI - Register-Immediate

**Description:**

This instruction subtracts an immediate value from a register and places the result into a register. This instruction never causes an exception.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Immediate11..0 | Rt6 | Ra6 | 4Dh8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra – Imm

### SW – Store Word

**Description:**

A sixty-four bit value is stored to memory from the source register Rb. The memory address is the sum of the sign extended offset and register Ra. The memory address must be word aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 39 28 | | 27 22 | | 21 16 | | 15 8 | | 7 0 | | |
| Displacement11..0 | Rt6 | | Ra6 | | 93h8 | | Pn4 | | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra+offset] = Rb

**Exceptions**: DBE, DBG, TLB, LMT

### SWCR – Store Word and Clear Reservation

**Description:**

If there is a reservation present on the memory address then a sixty-four bit value is stored to memory from the source register Rs and the reservation is cleared. If there is no reservation present then memory is not updated. If the update was successful then predicate register zero is set to ‘ne’ status, otherwise the predicate register is set to ‘eq’ status. The memory address is the sum of the sign extended offset and register Ra. The memory address must be word aligned. This instruction relies on the memory system for implementation.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Rs6 | Ra6 | 8Ch8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra+offset] = Rb, reservation cleared

**Exceptions**: DBE, DBG, TLB, LMT

### SWS – Store Word Special

**Description:**

A sixty-four bit value is stored to memory from the source special purpose register Spr. The memory address is the sum of the sign extended displacement and register Ra. The memory address must be word aligned.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | Spr6 | Ra6 | 9Eh8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra + displacement] = Spr

**Exceptions**: DBE, DBG, TLB, LMT

### SWX – Store Word Indexed

**Description:**

A sixty-four bit value is stored to memory from the source register Rc. The memory address is the sum of register Ra and scaled register Rb. The memory address must be word aligned.

**Instruction Format:**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 36 | 3534 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~4 | Sc2 | Rc6 | Rb6 | Ra6 | C3h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[Ra+Rb] = Rc

**Exceptions**: DBE, DBG, TLB, LMT

### SXB – Sign Extend Byte

**Description:**

This instruction sign extends a register from bit 8 to 63 and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 84 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = {56{Ra[7]}},Ra[7:0]

**Exceptions:** none

### SXC – Sign Extend Character

**Description:**

This instruction sign extends a register from bit 16 to 63 and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 94 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = {48{Ra[15]}},Ra[15:0]

**Exceptions:** none

### SXH – Sign Extend Half-word

**Description:**

This instruction sign extends a register from bit 32 to 63 and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| A4 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = {32{Ra[31]}},Ra[31:0]

**Exceptions:** none

### SYNC – Synchronization Barrier

**Description:**

All instructions before the SYNC command are completed before any following instructions are started. Note that this instruction has an effect even if the predicate is false; this does not affect the correct operation of the program, only performance is affected.

**Instruction Format:**

|  |  |  |
| --- | --- | --- |
| 15 8 | 7 0 | |
| F7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Exceptions:** none

### SYS –Call system routine

**Description:**

This instruction calls a system function located as the sum of the offset times 16 plus code address register 12. The return address is stored in the EPC register (code address register #13). This instruction causes the core to switch to kernel mode.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 24 | 23 20 | 19 16 | 15 8 | 7 0 | |
| Offset7..0 | Ch4 | Dh4 | A5h8 | Pn4 | Pc4 |

**Operation**:

PC = offset \* 16 + c12

if (StatusEXL < 255) StatusEXL = StatusEXL + 1

### TLB – TLB Command

**Description:**

The command is executed on the TLB unit. The command results are placed in internal TLB registers which can be read or written using TLB command instruction. If the operation is a read register operation then the register value is placed into Rt. If the operation is a write register operation, then the value for the register comes from Rb. Otherwise the Rb/Rt field in the instruction is ignored.

This instruction is only available in kernel mode.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 3130 | 29 24 | 23 16 | | 15 8 | 7 0 | |
| ~2 | Rb/Rt6 | Tn4 | Cmd4 | F0h8 | Pn4 | Pc4 |

**Clock Cycles:** 3

Tn4 – This field identifies which TLB register is being read or written.

|  |  |  |
| --- | --- | --- |
| Reg no. |  | Assembler |
| 0 | Wired | Wired |
| 1 | Index | Index |
| 2 | Random | Random |
| 3 | Page Size | PageSize |
| 4 | Virtual page | VirtPage |
| 5 | Physical page | PhysPage |
| 7 | ASID | ASID |
| 8 | Data miss address | DMA |
| 9 | Instruction miss address | IMA |
| 10 | Page Table Address | PTA |
| 11 | Page Table Control | PTC |

**TLB Commands**

|  |  |  |
| --- | --- | --- |
| Cmd | Description | Assembler |
| 0 | No operation |  |
| 1 | Probe TLB entry | TLBPB |
| 2 | Read TLB entry | TLBRD |
| 3 | Write TLB entry corresponding to random register | TLBWR |
| 4 | Write TLB entry corresponding to index register | TLBWI |
| 5 | Enable TLB | TLBEN |
| 6 | Disable TLB | TLBDIS |
| 7 | Read register | TLBRDREG |
| 8 | Write register | TLBWRREG |
| 9 | Invalidate all entries | TLBINV |

Probe TLB – The TLB will be tested to see if an address translation is present.

Read TLB – The TLB entry specified in the index register will be copied to TLB holding registers.

Write Random TLB – A random TLB entry will be written into from the TLB holding registers.

Write Indexed TLB – The TLB entry specified by the index register will be written from the TLB holding registers.

Disable TLB – TLB address translation is disabled so that the physical address will match the supplied virtual address.

Enable TLB – TLB address translation is enabled. Virtual address will be translated to physical addresses using the TLB lookup tables.

The TLB will automatically update the miss address registers when a TLB miss occurs only if the registers are zero to begin with. System software must reset the registers to zero after a miss is processed. This mechanism ensures the first miss that occurs is the one that is recorded by the TLB.

PageTableAddr – This is a scratchpad register available for use to store the address of the page table.

PageTableCtrl – This is a scratchpad register available for use to store control information associated with the page table.

### TST - Register Test Compare

**Description:**

The register test compare compares a register against the value zero and sets the predicate flags appropriately.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 2322 | 21 16 | 15 12 | 11 8 | 7 0 | |
| 02 | Ra6 | 04 | Pt4 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Operation:**

if Ra < 0

Pt.lt = 1

else

Pt.lt = 0

if Ra = 0

Pt.eq = 1

else

Pt.eq = 0

Pt.ltu = 0

**Exceptions:** none

### ZXB – Zero Extend Byte

**Description:**

This instruction zero extends a register from bit 8 to 63 and places the result in a target register. This instruction is typically used to perform an unsigned load operation with the LVB instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| C4 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra[7:0]

**Exceptions:** none

### ZXC – Zero Extend Character

**Description:**

This instruction zero extends a register from bit 16 to 63 and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| D4 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra[15:0]

**Exceptions:** none

### ZXH – Zero Extend Half-word

**Description:**

This instruction zero extends a register from bit 32 to 63 and places the result in a target register.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| E4 | Rt6 | Ra6 | A7h8 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** ALU #0 only

**Operation:**

Rt = Ra[31:0]

**Exceptions:** none

## Stack Operations

Stack based operations are currently not supported. This document outlines proposed stack based instructions.

Stack based operations require en-queueing two sub-instructions in place of the stack instruction specified in program code. Logic cell requirements for the additional operations approx. 10,000 LC’s.

### LINK – Link Stack

**Description:**

The specified base pointer register Rt is pushed onto the stack, the stack pointer is loaded into register Rt and then is adjusted by the amount specified. The adjustment field of the instruction is multiplied by eight and sign extended before being applied allowing up to 128k bytes to be allocated. Note the adjustment field may not be extended with an immediate prefix. Also note the adjustment field value should be eight less than the desired value.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Adjustment11..0 | Rt6 | Adj17..12 | CBh8 | Pn4 | Pc4 |

**Clock Cycles:** 4 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

memory[SP-8] = Rt

Rt = SP - 8

SP = SP + adjustment

### PEA – Push Effective Address

**Description:**

An address value is calculated as the sum of the sign extended displacement and register Ra then pushed onto the stack.

Push and pop operations are unique as they enque as two instructions. This has a tendency to serialize the operation of the processor. It may improve performance in some applications to manually adjust the stack pointer, and use load / store operations instead.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 39 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Displacement11..0 | ~6 | Ra6 | C9h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

SP = SP - 8

memory[SP] = Ra + displacement

### POP – Pop Register

**Description:**

The register is popped from the stack then the stack pointer is incremented.

Push and pop operations are unique as they enque as two instructions. This has a tendency to serialize the operation of the processor. It may improve performance in some applications to manually adjust the stack pointer, and use load / store operations instead.

**Instruction Format:**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 16 | 15 8 | 7 0 | |
| ~1 | Rt7 | CAh8 | Pn4 | Pc4 |

**Clock Cycles:** 4 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

Rt = mem[r27]

r27 = r27 + 8

**Registers Popped:**

|  |  |
| --- | --- |
| Regno (Rt7) | Register Pushed |
| 00 to 63 | general register file |
| 64 to 79 | predicate registers #0 to #15 |
| 80 to 95 | code address registers |
| 96 to 111 | segment registers |
| 112 | predicate register array |
| 115 | loop counter |

### PUSH – Push Register

**Description:**

The stack pointer is decremented then the register is pushed onto the stack.

Push and pop operations are unique as they enque as two instructions. This has a tendency to serialize the operation of the processor. It may improve performance in some applications to manually adjust the stack pointer, and use load / store operations instead.

**Instruction Format:**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 23 | 22 16 | 15 8 | 7 0 | |
| ~1 | Ra7 | C8h8 | Pn4 | Pc4 |

**Clock Cycles:** 3 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

r27 = r27 - 8

mem[r27] = Ra

**Registers Pushed:**

|  |  |
| --- | --- |
| Regno (Ra7) | Register Pushed |
| 00 to 63 | general register file |
| 64 to 79 | predicate registers #0 to #15 |
| 80 to 95 | code address registers |
| 96 to 111 | segment registers |
| 112 | predicate register array |
| 115 | loop counter |

### UNLINK – Unlink Stack

**Description:**

The specified base pointer register Ra is loaded into the stack pointer, then register Ra is popped from the stack.

**Instruction Format:**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 2322 | 21 16 | 15 8 | 7 0 | |
| ~2 | Ra6 | CCh8 | Pn4 | Pc4 |

**Clock Cycles:** 4 (one memory access)

**Execution Units:** All ALU’s / Memory

**Operation:**

SP = Ra

Ra = memory[SP]

SP = SP + 8

# Floating Point

## Operations Supported

Only the most basic floating point operations are supported with hardware. Supported operations include addition, subtraction, multiplication, division, absolute value, integer to float and float to integer conversions. Also supported are comparison operations. There are also a number of control and status instructions.

**Supported Operations:**

|  |  |  |  |
| --- | --- | --- | --- |
| Mnemonic | Precision | Clocks | Operation |
| FADD | S,D | 5 | addition |
| FSUB | S,D | 5 | subtraction |
| FMUL | S,D | 5 | multiplication |
| FDIV | S,D | 29,56 | division |
| FABS | S,D | 1 | absolute value |
| FNEG | S,D | 1 | negation |
| FTOI | S,D | 2 | float to integer |
| ITOF | S,D | 2 | integer to float |
| FSIGN | S,D | 1 | sign of value |
| FMAN | S,D | 1 | mantissa of value |
| FSTAT | - | 1 | get status register |
| FRM | - | 1 | set rounding mode |
| FTX | - | 1 | trigger exception |
| TCX | - | 1 | clear exception |
| TDX | - | 1 | disable exception |
| FEX | - | 1 | enable exception |
| FCMP | S, D | 1 | comparison |
| FTST | S, D | 1 | test against zero |

## Representation

The floating point format is an IEEE-754 representation for both single and double precision. Briefly,

**Double Precision Format:**

|  |  |  |  |
| --- | --- | --- | --- |
| 63 | 62 | 61 52 | 51 0 |
| SM | SE | Exponent | Mantissa |

**Single Precision Format:**

|  |  |  |  |
| --- | --- | --- | --- |
| 31 | 30 | 29 23 | 22 0 |
| SM | SE | Exponent | Mantissa |

Quad Precision Format:

|  |  |  |  |
| --- | --- | --- | --- |
| 127 | 126 | 125 112 | 111 0 |
| SM | SE | Exponent | Mantissa |

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 -1024 to +1023 for double precision numbers

If the core is built with the 32 bit data-bus 64 bit double precision floating point is unavailable.

Floating point comparisons and tests are executed on the integer ALU. This allows a comparison operation to proceed in parallel with another floating point operation.

## Performance

Generally, double precision operations are just as fast as single precision operations with the exception of the divide operation which takes multiple clock cycles.

The floating point divider uses a radix 8 division. (three bits are processed each clock cycle).

# 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:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 54 | Rt6 | Ra6 | 778 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FABS.S – Single Precision Absolute Value

**Description:**

This instruction takes the absolute value of a single precision floating point number contained in a general purpose register. The sign bit of the number is cleared.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 54 | Rt6 | Ra6 | 798 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FADD – Floating point addition

**Description:**

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

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 86 | Rt6 | Rb6 | Ra6 | 78h8 | Pn4 | Pc4 |

**Clock Cycles: 5**

**Execution Units:** All Floating Point

### FADD.S – Floating Point Single Precision addition

**Description:**

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

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 186 | Rt6 | Rb6 | Ra6 | 78h8 | Pn4 | Pc4 |

**Clock Cycles: 5**

**Execution Units:** All Floating Point

### FCMP - Float Compare

**Description:**

The register compare instruction compares two registers as floating point doubles and sets the flags in the target predict register as a result. While this is a floating point operation it is executed on the integer ALU.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 3128 | 27 22 | 21 16 | 15 12 | 11 8 | 7 0 | |
| 24 | Rb6 | Ra6 | 14 | Pt4 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

if Ra < Rb

P.lt = true

else

P.lt = false

if mag Ra < mag Rb

P.ltu = true

else

P.ltu = false

if Ra = Rb

P.eq = true

else

P.eq = false

if unordered

P.un = true

else

P.un = false

### FCMP.S - Float Compare Single

**Description:**

The register compare instruction compares two registers as floating point singles and sets the flags in the target predict register as a result. While this is a floating point operation it is executed on the integer ALU.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 3128 | 27 22 | 21 16 | 15 12 | 11 8 | 7 0 | |
| 14 | Rb6 | Ra6 | 14 | Pt4 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

if Ra < Rb

P.lt = true

else

P.lt = false

if mag Ra < mag Rb

P.ltu = true

else

P.ltu = false

if Ra = Rb

P.eq = true

else

P.eq = false

if unordered

P.un = true

else

P.un = false

### FDIV – Floating point division

**Description:**

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

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Bh6 | Rt6 | Rb6 | Ra6 | 78h8 | Pn4 | Pc4 |

**Clock Cycles: 56**

**Execution Units:** All Floating Point

### FDIV.S – Single Precision Floating point division

**Description:**

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

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 1Bh6 | Rt6 | Rb6 | Ra6 | 78h8 | Pn4 | Pc4 |

**Clock Cycles: 29**

**Execution Units:** All Floating Point

### 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:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| D4 | Immed6 | Ra6 | 798 | Pn4 | Pc4 |

**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 |

### FDX – Disable Floating Point Exceptions

**Description:**

This instruction disables floating point exceptions. The Exceptions disabled 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:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| F4 | Immed6 | Ra6 | 798 | Pn4 | Pc4 |

**Execution Units:** All Floating Point

**Operation:**

**Exceptions:**

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

### FEX – Enable Floating Point Exceptions

**Description:**

This instruction enables floating point exceptions. The Exceptions enabled 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:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| E4 | Immed6 | Ra6 | 798 | Pn4 | Pc4 |

**Execution Units:** All Floating Point

**Operation:**

**Exceptions:**

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

### 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:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| C4 | Immed6 | Ra6 | 798 | Pn4 | Pc4 |

**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 |

### FMAC – Floating Point Multiply Accumulate (planned)

**Description:**

Multiply two floating point numbers in registers Ra and Rb add a third number from register Rc and place the result into target register Rt.

**Instruction Format:**

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 4745 | 44 40 | 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~3 | O5 | Rt6 | Rc6 | Rb6 | Ra6 | 76h8 | Pn4 | Pc4 |

**Clock Cycles: 10**

**Execution Units:** All Floating Point

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| O5 | Precision | Mnemonic | Operation |  |
| 8 | S | FMAC.S | Rt = (Ra \* Rb) + Rc | multiply accumulate |
| 9 | S | FMAS.S | Rt = (Ra \* Rb) - Rc | multiply subtract |
| 10 | S | FNMAC.S | Rt = -((Ra \* Rb) + Rc) | negate multiply accumulate |
| 11 | S | FNMAS.S | Rt = -((Ra \* Rb) - Rc) | negate multiply subtract |
| 16 | D | FMAC | Rt = (Ra \* Rb) + Rc | multiply accumulate |
| 17 | D | FMAS | Rt = (Ra \* Rb) - Rc | multiply subtract |
| 18 | D | FNMAC | Rt = -((Ra \* Rb) + Rc) | negate multiply accumulate |
| 19 | D | FNMAS | Rt = -((Ra \* Rb) - Rc) | negate multiply subtract |

### FMAN – Mantissa of Number

**Description:**

This instruction provides the mantissa of a double precision floating point number contained in a general purpose register as a 52 bit zero extended result. The hidden bit of the floating point number remains hidden.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 74 | Rt6 | Ra6 | 778 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FMAN.S – Mantissa of Number

**Description:**

This instruction provides the mantissa of a single precision floating point number contained in a general purpose register as a 23 bit zero extended result. The hidden bit of the floating point number remains hidden.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 74 | Rt6 | Ra6 | 798 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FMOV – Move Double Precision

**Description:**

This instruction moves one general purpose register to another. This instruction is shorter and uses one less register port than using the OR instruction to move between registers. See also the [MOV](#_MOV_-_Register-Register) instruction. This instruction currently performs the same operation as the MOV instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 04 | Rt6 | Ra6 | 778 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FMOV.S – Move Single Precision

**Description:**

This instruction moves one general purpose register to another. This instruction is shorter and uses one less register port than using the OR instruction to move between registers. See also the [MOV](#_MOV_-_Register-Register) instruction. This instruction currently performs the same operation as the MOV instruction.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 04 | Rt6 | Ra6 | 798 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FMUL – Floating point multiplication

**Description:**

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

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| Ah6 | Rt6 | Rb6 | Ra6 | 78h8 | Pn4 | Pc4 |

**Clock Cycles: 5**

**Execution Units:** All Floating Point

### FMUL.S – Single Precision Floating point multiplication

**Description:**

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

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 1Ah6 | Rt6 | Rb6 | Ra6 | 78h8 | Pn4 | Pc4 |

**Clock Cycles: 5**

**Execution Units:** All Floating Point

### FNEG – Negate Register

**Description:**

This instruction negates a double precision floating point number contained in a general purpose register. The sign bit of the number is inverted.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 44 | Rt6 | Ra6 | 778 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FNEG.S – Negate Single Precision

**Description:**

This instruction negates a single precision floating point number contained in a general purpose register. The sign bit of the number is inverted.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 44 | Rt6 | Ra6 | 798 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FRM – Set Floating Point Rounding Mode

**Description:**

This instruction sets the rounding mode bits in the floating point control register (FPSCR). The rounding mode bits are set to the bitwise ‘or’ of an immediate field in the instruction and the contents of register Ra. Either Ra or the immediate field should be zero.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| D4 | Imm6 | Ra6 | 778 | Pn4 | Pc4 |

**Execution Units:** All Floating Point

**Operation:**

FPSCR.RM = Ra | Immediate

### FSIGN – Sign of Number

**Description:**

This instruction provides the sign of a double precision floating point number contained in a general purpose register as a floating point double result. The result is +1.0 if the number is positive, 0.0 if the number is zero, and -1.0 if the number is negative.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 64 | Rt6 | Ra6 | 778 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FSIGN.S – Single Precision Sign of Number

**Description:**

This instruction provides the sign of a single precision floating point number contained in a general purpose register as a floating point single result. The result is +1.0 if the number is positive, 0.0 if the number is zero, and -1.0 if the number is negative.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 64 | Rt6 | Ra6 | 798 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All Floating Point

**Operation:**

Rt = Ra

### FSTAT – Get Floating Point Status and Control

**Description:**

The floating point status and control register may be read using the FSTAT instruction. The format of the FPSCR register is outlined on the next page.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| C4 | Rt6 | ~6 | 778 | Pn4 | Pc4 |

**Execution Units:** All Floating Point

**Operation:**

Rt = FPSCR

**Floating Point Status And Control Register Format:**

|  |  |  |  |
| --- | --- | --- | --- |
| 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 |

Greyed out items are not implemented.

### FSUB – Floating point subtraction

**Description:**

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 96 | Rt6 | Rb6 | Ra6 | 78h8 | Pn4 | Pc4 |

**Clock Cycles: 5**

**Execution Units:** All Floating Point

### FSUB.S – Single Precision Floating point subtraction

**Description:**

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 196 | Rt6 | Rb6 | Ra6 | 78h8 | Pn4 | Pc4 |

**Clock Cycles: 5**

**Execution Units:** All Floating Point

### FTOI – Float to Integer

**Description:**

This instruction converts a floating point double value to an integer value.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 24 | Rt6 | Ra6 | 77h8 | Pn4 | Pc4 |

**Clock Cycles:** 2

**Execution Units:** All Floating Point

### FTOI.S – Single Precision Float to Integer

**Description:**

This instruction converts a floating point single value to an integer value.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 24 | Rt6 | Ra6 | 79h8 | Pn4 | Pc4 |

**Clock Cycles:** 2

**Execution Units:** All Floating Point

### FTST – Float Register Test Compare

**Description:**

The register test compare compares floating point double in a register against the value zero and sets the predicate flags appropriately. This instruction is executed on the integer ALU.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 2322 | 21 16 | 15 12 | 11 8 | 7 0 | |
| 22 | Ra6 | 04 | Pt4 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

if Ra < 0

Pt.lt = 1

else

Pt.lt = 0

if Ra = 0

Pt.eq = 1

else

Pt.eq = 0

if unordered

Pt.un = 1

else

Pt.un = 0

Pt.ltu = 0

**Exceptions:** none

### FTST.S – Float Single Test Compare

**Description:**

The register test compare compares floating point single in a register against the value zero and sets the predicate flags appropriately. This instruction is executed on the integer ALU.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 2322 | 21 16 | 15 12 | 11 8 | 7 0 | |
| 12 | Ra6 | 04 | Pt4 | Pn4 | Pc4 |

**Clock Cycles:** 1

**Execution Units:** All ALU’s

**Operation:**

if Ra < 0

Pt.lt = 1

else

Pt.lt = 0

if Ra = 0

Pt.eq = 1

else

Pt.eq = 0

if unordered

Pt.un = 1

else

Pt.un = 0

Pt.ltu = 0

**Exceptions:** none

### ITOF – Integer to Float

**Description:**

This instruction converts an integer value to a double precision floating point representation.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 34 | Rt6 | Ra6 | 77h8 | Pn4 | Pc4 |

**Clock Cycles:** 2

**Execution Units:** All Floating Point

### ITOF.S – Integer to Float Single

**Description:**

This instruction converts an integer value to a single precision floating point representation.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| 34 | Rt6 | Ra6 | 79h8 | Pn4 | Pc4 |

**Clock Cycles:** 2

**Execution Units:** All Floating Point

# Vector Programming Model

The ISA supports up to 64 vector registers of length 64. In the proof of concept RTL code there are eight, sixteen element vector registers.

|  |  |
| --- | --- |
| Reg no |  |
| 0 |  |
| 1 |  |
| 2 |  |
| 3 |  |
| 4 |  |
| 5 |  |
| 6 |  |
| 7 |  |

## Vector Length (VL register)

The vector length register controls how many elements of a vector are processed. The vector length register may not be set to a value greater than the number of elements supported by hardware.

|  |  |
| --- | --- |
| 7 | 6 0 |
| 0 | Length6..0 |

## Vector Predicates

The ISA supports up to sixteen, sixty-four element vector predicate registers. These registers take the place of the vector mask (VM) register in other architectures. In the proof-of-concept version there is a single sixteen element vector predicate register. All vector instructions are executed conditionally based on the value in a vector predicate register.

|  |  |
| --- | --- |
| Regno |  |
| 0 |  |

### Predicate Conditions

|  |  |  |  |
| --- | --- | --- | --- |
| Cond. |  | Test |  |
| 0 | PF | 0 | Always false – Instructions predicated with condition zero never execute regardless of the predicate register contents. This is used for extended immediate values as well. The false predicate byte for instructions is 90h. |
| 1 | PT | 1 | Always True – The instruction predicated with an always true condition always executes regardless of the predicate register contents. The always true predicate byte is 01h. Other true predicates are instruction short-forms. |
| 2 | PEQ | eq | Equal – instruction executes if the predicate register equal flag is set |
| 3 | PNE | !eq | Not Equal – instruction executes if the predicate register equal flag is clear |
| 4 | PLE | lt|eq | Less or Equal – predicate less or equal flag is set |
| 5 | PGT | !(lt|eq) | greater than |
| 6 | PGE | !lt | greater or equal |
| 7 | PLT | lt | less than |
| 8 | PLEU | ltu|eq | unsigned less or equal |
| 9 | PGTU | !(ltu|eq) | unsigned greater than |
| 10 | PGEU  POR | !ltu | unsigned greater or equal  Ordered for floating point |
| 11 | PLTU  PUN | ltu | unsigned less than  Unordered for floating point |
| 12 |  |  |  |
| 13 | PSIG | signal | execute if external signal is true |
| 14 |  |  |  |
| 15 |  |  |  |

## Detailed Vector Instruction Set

### VADD

Synopsis

Vector register add. Vt = Va + Vb

**Description**

Two vector registers (Va and Vb) are added together and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 03 | T3 | Vt6 | Vb6 | Va6 | 57h8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL - 1

if (Vp[x]) Vt[x] = Va[x] + Vb[x]

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | Float double |  |
| 4 | Float quad |  |

### VADDS

Synopsis

Vector register add. Vt = Va + Rb

**Description**

A vector and a scalar (Va and Rb) are added together and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 43 | T3 | Vt6 | Rb6 | Va6 | 57h8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

if (Vp[x]) Vt[x] = Vb[x] + Rb

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | Float double |  |
| 4 | Float quad |  |

### VAND

Synopsis

Vector register bitwise and. Vt = Va & Vb

***Description***

Two vector registers (Va and Vb) are bitwise and’ed together and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 03 | T3 | Vt6 | Vb6 | Va6 | 52h8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

if (Vp[x]) Vt[x] = Va[x] & Vb[x]

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
|  |  |  |
|  |  |  |
|  |  |  |

### VANDS

Synopsis

Vector register bitwise and. Vt = Va & Rb

***Description***

A vector registers (Va) is bitwise and’ed with a scalar register and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 43 | T3 | Vt6 | Rb6 | Va6 | 52h8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

if (Vp[x]) Vt[x] = Va[x] & Rb

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
|  |  |  |
|  |  |  |
|  |  |  |

### VBITS2V

Synopsis

Convert bits to Boolean vector.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 66 | Vt6 | Ra6 | 568 | Pn4 | Pc4 |

**Description**

Bits from a general register are copied to the corresponding vector target register.

**Operation**

For x = 0 to [Ra]-1

Vt[x] = Ra[x]

**Exceptions:** none

### VCMP

Synopsis

Vector register compare. Vt = Va ? Vb

**Description**

Two vector registers (Va and Vb) are compared and the comparison result is placed in the target vector predicate register Vpt.

**Instruction Format**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 3128 | 27 22 | 21 16 | 15 12 | 11 8 | 7 0 | |
| O4 | Vb6 | Va6 | 14 | Vpt4 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

Vt[x] = Va[x] ? Vb[x]

**Operation:**

**For each vector element**

if signed Va < signed Vb

P.lt = true

else

P.lt = false

if unsigned Va < unsigned Vb

P.ltu = true

else

P.ltu = false

if Va = Vb

P.eq = true

else

P.eq = false

Operand Type

|  |  |  |
| --- | --- | --- |
| O4 |  |  |
| 8 | Integer |  |
| 9 | Float single |  |
| A | float double |  |
| C | Float Quad |  |

### VCMPS

Synopsis

Vector register compare. Vt = Va ? Rb

**Description**

A vector registers (Va) is compared to a scalar register (Rb) and the comparison result is placed in the target vector predicate register Vpt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 35 | 3432 | 31 28 | 27 22 | 21 16 | 15 8 | 7 0 | |
| ~5 | T3 | Vpt4 | Rb6 | Va6 | 5Ch8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

Vt[x] = Va[x] ? Vb[x]

**Operation:**

**For each vector element**

if signed Va < signed Rb

P.lt = true

else

P.lt = false

if unsigned Va < unsigned Rb

P.ltu = true

else

P.ltu = false

if Va = Rb

P.eq = true

else

P.eq = false

### VEINS / VMOVSV

Synopsis

Vector element insert.

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 16 | Vt6 | Rb6 | Ra6 | 568 | Pn4 | Pc4 |

***Description***

A general purpose register Rb is transferred into one element of a vector register Vt. The element to insert is identified by Ra.

***Operation***

Rt = Va[Ra]

***Exceptions:*** none

### VEOR

Synopsis

Vector register bitwise exclusive or. Vt = Va ^ Vb

***Description***

Two vector registers (Va and Vb) are exclusively or’ed together and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 23 | T3 | Vt6 | Vb6 | Va6 | 52h8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

Vt[x] = Va[x] & Vb[x]

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
|  |  |  |
|  |  |  |
|  |  |  |

### VEORS

Synopsis

Vector register bitwise exclusive or. Vt = Va ^ Rb

**Description**

A vector registers (Va) is exclusively or’ed with a scalar register (Rb) and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 63 | T3 | Vt6 | Rb6 | Va6 | 52h8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

if (VM[x]) Vt[x] = Va[x] & Vb[x]

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
|  |  |  |
|  |  |  |
|  |  |  |

### VDIV

Synopsis

Vector register divide. Vt = Va / Vb

**Description**

Two vector registers (Va and Vb) are divided and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 13 | T3 | Vt6 | Vb6 | Va6 | 5Eh8 | Vpn4 | Pc4 |

**Operation**

Vt[Ra] =Va[Ra] + Vb[Ra]

or

for x = 1 to [Ra]

Vt[x] = Va[x] + Vb[x]

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | float double |  |
| 4 | Float Quad |  |

### VDIVS

Synopsis

Vector register divide. Vt = Va / Rb

**Description**

A vector register (Va) is divided by a scalar and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 53 | T3 | Vt6 | Vb6 | Va6 | 5Eh8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

Vt[x] = Va[x] / Rb

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | float double |  |
| 4 | Float Quad |  |

### VEX / VMOVS

Synopsis

Vector element extract.

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 06 | Rt6 | Va6 | Ra6 | 568 | Pn4 | Pc4 |

***Description***

One element of a vector register Va is transferred to a general purpose register Rt. The element to extract is identified by Ra.

***Operation***

Rt = Va[Ra]

***Exceptions:*** none

### VFLT2INT

Synopsis

Vector float to integer.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 46 | Vt6 | Va6 | 568 | Vpn4 | Pc4 |

***Description***

Elements of the vector are converted from floating point to integer.

***Operation***

For x = 0 to [Ra]-1

Vt[x] = (int)Va[x]

***Exceptions:*** none

### VINT2FLT

Synopsis

Vector float to integer.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 56 | Vt6 | Va6 | 568 | Vpn4 | Pc4 |

***Description***

Elements of the vector are converted from integer to floating point.

***Operation***

For x = 0 to VL-1

Vt[x] =(float) Va[x]

***Exceptions:*** none

### LV

Synopsis

Load vector

**Description:**

Load a vector register from memory using register indirect.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| ~4 | Vt6 | Ra6 | BDh8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to [Ra]-1

Vt[x] = memory64[Ra + 8 \* x]

**Exceptions:** DBE, DBG, LMT, TLB

### LVWS

Synopsis

Load vector using stride

**Description:**

Load a vector register from memory using register indirect with stride addressing.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| ~6 | Vt6 | Rb6 | Ra6 | BEh8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

Vt[x] = memory64[Ra+Rb \* x]

**Exceptions:** DBE, DBG, LMT, TLB

### LVX

Synopsis

Load vector

**Description:**

Load a vector register from memory using vector indexed addressing.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| ~6 | Vt6 | Vb6 | Ra6 | BFh8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to [Ra]-1

Vt[x] = memory64[Ra+Vb[x]]

**Exceptions:** DBE, DBG, LMT, TLB

### VMAC

Synopsis

Vector register multiply accumulate. Vt = +-( +- Va \*+- Vb +- Vc)

**Description**

Vector registers Va and Vb are multiplied together then accumulated with vector register Vc. The sign of Va, Vb, and Vc may be inverted. The sign of the entire result may be inverted.

**Instruction Format**

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 47 43 | 42 40 | 39 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| Sn5 | T3 | Vt6 | Vc6 | Vb6 | Va6 | 5Ah8 | Vpn4 | Pc4 |

**Operation**

Vt[Ra] =Va[Ra] \* Vb[Ra] + Vc

**Operand Type**

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | float double |  |
| 4 | Float Quad |  |

### VMUL

**Synopsis**

Vector register add. Vt = Va \* Vb

**Description**

Two vector registers (Va and Vb) are multiplied together and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 03 | T3 | Vt6 | Vb6 | Va6 | 5Eh8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

if (VM[x]) Vt[x] = Va[x] \* Vb[x]

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | float double |  |
| 4 | Float Quad |  |

### VMULS

**Synopsis**

Vector register add. Vt = Va \* Rb

**Description**

A vector register (Va) is multiplied by a scalar register (Rb) and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 43 | T3 | Vt6 | Rb6 | Va6 | 5Eh8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

if (VM[x]) Vt[x] = Va[x] \* Rb

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | float double |  |
| 4 | Float Quad |  |

### VOR

Synopsis

Vector register bitwise or. Vt = Va | Vb

***Description***

Two vector registers (Va and Vb) are or’ed together and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 13 | T3 | Vt6 | Vb6 | Va6 | 52h8 | Vpn4 | Pc4 |

**Operation**

for x = 01 to VL-1

Vt[x] = Va[x] | Vb[x]

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
|  |  |  |
|  |  |  |
|  |  |  |

### VORS

Synopsis

Vector register bitwise or. Vt = Va | Rb

***Description***

A vector register (Va) is or’ed with a scalar register (Rb) and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 8 | 7 | 0 |
| 53 | T3 | Vt6 | Rb6 | Va6 | 52h8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

Vt[x] = Va[x] | Rb

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
|  |  |  |
|  |  |  |
|  |  |  |

### VREC

**Synopsis**

Vector reciprocal. Vt = 1/Va

**Description**

The reciprocal of a vector (Va) is calculated placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 66 | Vt6 | Va6 | 568 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

if (VM[x]) Vt[x] = 1/ Va[x]

Operand Type

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | float double |  |
| 4 | Float Quad |  |

### VSHLV

Synopsis

Vector shift left.

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 26 | Vt6 | Va6 | Ra6 | 568 | Pn4 | Pc4 |

***Description***

Elements of the vector are transferred upwards to the next element position. Element #0 is loaded with the value zero.

***Operation***

For x = 0 to [Ra]-1

Vt[x+1] = Va[x]

Vt[0] = 0

***Exceptions:*** none

### VSHRV

Synopsis

Vector shift right.

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 36 | Vt6 | Va6 | Ra6 | 568 | Pn4 | Pc4 |

***Description***

Elements of the vector are transferred downwards to the next element position. The last is loaded with the value zero.

***Operation***

For x = 0 to [Ra]-1

Vt[x] = Va[x+1]

Vt[Ra-1] = 0

***Exceptions:*** none

### SV

Synopsis

Store vector

**Description:**

Store a vector register to memory using register indirect.

**Instruction Format:**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| ~4 | Vs6 | Ra6 | CDh8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to VL-1

memory64[Rb + x \* 8] = Vs[x]

**Exceptions:** DBE, DBG, LMT, TLB

### SVWS

Synopsis

Store vector using stride

**Description:**

Store a vector register to memory using register indirect with stride addressing.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| ~6 | Vs6 | Rb6 | Ra6 | CEh8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to [Ra]-1

memory64[Ra+Rb \* x] = Vs[x]

**Exceptions:** DBE, DBG, LMT, TLB

### SVX

Synopsis

Store vector

**Description:**

Store a vector register to memory using vector indexed addressing.

**Instruction Format:**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| ~6 | Vs6 | Vb6 | Ra6 | CFh8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to [Ra]-1

memory64[Ra+Vb[x]] = Vs[x]

**Exceptions:** DBE, DBG, LMT, TLB

### VSUB

Synopsis

Vector register subtract. Vt = Va - Vb

**Description**

Two vector registers (Va and Vb) are subtracted and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 23 | T3 | Vt6 | Vb6 | Va6 | 57h8 | Vpn4 | Pc4 |

**Operation**

Vt[Ra] =Va[Ra] + Vb[Ra]

or

for x = 1 to [Ra]

Vt[x] = Va[x] + Vb[x]

**Operand Type**

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | float double |  |
| 4 | Float Quad |  |

### VSUBS

Synopsis

Vector register subtract. Vt = Va - Rb

**Description**

A scalar register is subtracted from a vector register and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 53 | T3 | Vt6 | Rb6 | Va6 | 57h8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to [Ra]-1

Vt[x] = Va[x] + Rb

**Operand Type**

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | float double |  |
| 4 | Float Quad |  |

### VSUBRS

Synopsis

Vector register subtract. Vt = Rb - Va

**Description**

A vector register is subtracted from a scalar register and placed in the target vector register Vt.

**Instruction Format**

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 39 37 | 36 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 63 | T3 | Vt6 | Rb6 | Va6 | 57h8 | Vpn4 | Pc4 |

**Operation**

for x = 0 to [Ra]-1

Vt[x] = Va[x] + Rb

**Operand Type**

|  |  |  |
| --- | --- | --- |
| T3 |  |  |
| 0 | Integer |  |
| 1 | Float single |  |
| 2 | float double |  |
| 4 | Float Quad |  |

### V2BITS

Synopsis

Convert Boolean vector to bits.

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 39 34 | 33 28 | 27 22 | 21 16 | 15 0 | 7 | 0 |
| 66 | Rt6 | Va6 | Ra6 | 568 | Vpn4 | Pc4 |

***Description***

The least significant bit of each vector element is copied to the corresponding bit in the target register.

***Operation***

For x = 0 to VL-1

Rt[x] = Va[x].LSB

***Exceptions:*** none

Notes:

The register tag associated with a vector register contains both the element number and vector register number. The vector element being processed needs to be uniquely identified in the processor’s pipeline. With a large number of vector registers and a large number of elements the tag becomes quite large. The current core has 8 vector registers with sixteen elements each. This is to keep the tag within seven bits. The core ends up needing to process an eight bit register tag in order to handle all the registers.

Use of vector instructions serializes the core’s queuing of instructions. A separate instruction is queued for each element of the vector. This is done by stalling the instruction queued indicator until instructions for all the elements have been queued. In order to queue the vector instruction, queuing an element isn’t complete until the length is known. The length is in special register VL. If this register is valid the instruction will queue right away, otherwise it will be delayed until VL (argument a1) becomes valid. Once a1 becomes valid a new instruction should enqueue every clock cycle.

## Opcode Map

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | TST / FTST / FSTST | | | | | | | | | | | | | | | |
| 1x | CMP / FCMP / FSCMP | | | | | | | | | | | | | | | |
| 2x | CMPI | | | | | | | | | | | | | | | |
| 3x | BR | | | | | | | | | | | | | | | |
| 4x | {RR} | {R} | {P} |  |  | CHKI | BITI | ADDUI | ADDI | SUBI | MULI | DIVI | ADDUI | SUBUI | MULUI | DIVUI |
| 5x | {logic} | MLO | {VLOG} | ANDI | ORI | EORI | {VR} | {VAdd } | {shift} |  | VMAC | MODI | VCMPS | CHKXI | {VMUL} | MODUI |
| 6x |  |  |  |  |  |  |  |  | LEA | LEAX | LLA | \_2ADDUI | \_4ADDUI | \_8ADDUI | \_16ADDUI | LDI |
| 7x | JGR |  | MUX |  |  |  | {FMAC} | {double r} | {float rr} | {single r} |  |  |  |  | LDISEG | |
| 8x | LB | LBU | LC | LCU | LH | LHU | LW | LFS | LFD |  |  | LVWAR | SWCR | JSRI | LWS | LCL |
| 9x | SB | SC | SH | SW | SFS | SFD | STI | CAS | STSET | STMOV | STCMP | STFND |  | LDIS | SWS | CACHE |
| Ax | JSR | JSR | JSR | RTS | LOOP | SYS | INT | {R} | MFSPR | MTSPR | {bitfld} | MOVS | LVB | LVC | LVH | LVW |
| Bx | LBX | LBUX | LCX | LCUX | LHX | LHUX | LWX | JSRIX | LLAX |  |  |  |  | LV | LVWS | LVX |
| Cx | SBX | SCX | SHX | SWX | SFSX | SFDX | STIX | INC | PUSH | PEA | POP | LINK | UNLINK | SV | SVWS | SVX |
| Dx |  |  |  |  |  |  | LW |  |  |  |  |  |  |  |  |  |
| Ex |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Fx | {TLB} | NOP | RTS | RTE | RTI | {BCD} | STP | SYNC | MEMSB | MEMDB | CLI | SEI | RTD | RTF | JSF | IMM |

40 - {RR} Opcodes –Func6

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | ADD | SUB | MUL | DIV | ADDU | SUBU | MULU | DIVU | 2ADDU | 4ADDU | 8ADDU | 16ADDU |  |  |  |  |
| 1x | MIN | MAX | SQRT | MOD | CHKX | CHK |  | MODU |  |  |  |  |  |  |  |  |
| 2x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

50 - {logic} Opcodes – Func6

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | AND | OR | EOR | NAND | NOR | ENOR | ANDC | ORC |  |  |  |  |  |  |  |  |
| 1x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

F5 {BCD} Opcodes – Func6

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | BCDADD | BCDSUB | BCDMUL |  |  |  |  |  |  |  |  |  |  |  |  |  |

78 - {float -rr} Opcodes –Func6

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x |  |  |  |  |  |  |  | FCMP | FADD | FSUB | FMUL | FDIV |  |  |  |  |
| 1x |  |  |  |  |  |  |  | FCMPS | FADDS | FSUBS | FMULS | FDIVS |  |  |  |  |
| 2x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

77 - Double {R} Opcodes – Func4

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | FMOV |  | FTOI | ITOF | FNEG | FABS | FSIGN | FMAN | FNABS |  |  |  | FSTAT | FRM |  |  |

79 - Single {R} Opcodes – Func4

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | FMOVS |  | FTOIS | ITOFS | FNEGS | FABSS | FSIGNS | FMANS | FNABSS |  |  |  | FTX | FCX | FEX | FDX |

A7 {R} Opcodes – Func4

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | MOV | NEG | NOT | ABS | SGN | CNTLZ | CNTLO | CNTPOP | SXB | SXC | SXH | COM | ZXB | ZXC | ZXH |  |

41 {R} Opcodes – Func4

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | CPUID | REDOR | REDAND | PAR |  |  |  |  |  |  |  |  |  |  |  |  |

42 - {Predicate Logic} Opcodes – Func6

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | PAND | POR | PEOR | PNAND | PNOR | PENOR | PANDC | PORC |  |  |  |  |  |  |  |  |
| 1x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

52 {VLog} Opcodes – Func3

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 |
| 0x | VAND | VOR | VEOR |  | VANDS | VORS | VEORS |  |

57 {VAdd} Opcodes – Func3

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 |
| 0x | VADD | VSUB |  |  | VADDS | VSUBS | VSUBRS |  |

58 - {shift} Opcodes – Func6

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | SHL | SHR | SHLU | SHRU | ROL | ROR |  |  |  |  |  |  |  |  |  |  |
| 1x | SHLI | SHRI | SHLUI | SHRUI | ROLI | RORI |  |  |  |  |  |  |  |  |  |  |
| 2x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3x |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

AA {Bitfield} Opcodes – Func4

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | x0 | x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | xA | xB | xC | xD | xE | xF |
| 0x | BFINS | BFSET | BFCLR | BFCHG | BFEXTU | BFEXT | BFINSI |  |  |  |  |  |  |  |  |  |