Table of Contents

[Overview 2](#_Toc36495159)

[Design Objectives 3](#_Toc36495160)

[Thor2020 Differences from Thor Original 3](#_Toc36495161)

[Programming Model 4](#_Toc36495162)

[General Registers 4](#_Toc36495163)

[Code Address Registers 5](#_Toc36495164)

[Predicates 6](#_Toc36495165)

[Predicate Conditions 6](#_Toc36495166)

[Compiler Usage 7](#_Toc36495167)

[Summary of Special Purpose Registers 8](#_Toc36495168)

[Operating Levels 9](#_Toc36495169)

[Instructions 9](#_Toc36495170)

[Instruction Bundles 9](#_Toc36495171)

[Instruction Pointer 9](#_Toc36495172)

[Large Constants 9](#_Toc36495173)

[Placement Restrictions 9](#_Toc36495174)

[Instruction Set Summary 10](#_Toc36495175)

[Compare Instructions 10](#_Toc36495176)

[Jump Instructions 10](#_Toc36495177)

[Loops 10](#_Toc36495178)

[Detailed Instruction Set Description 16](#_Toc36495179)

[Control Flow Instructions 16](#_Toc36495180)

[BRK –Break 16](#_Toc36495181)

[BSR - Branch to Subroutine 17](#_Toc36495182)

[JML - Jump to Long Address 18](#_Toc36495183)

[JMP - Jump to Address 19](#_Toc36495184)

[JSR - Jump to Subroutine 20](#_Toc36495185)

[LOOP – Loop Branch 21](#_Toc36495186)

[RTS – Return from Subroutine 22](#_Toc36495187)

[Arithmetic / Logical 24](#_Toc36495188)

[ADD - Addition 24](#_Toc36495189)

[ADDIS – Add Immediate Shifted 24](#_Toc36495190)

[AND – Bitwise ‘And’ 25](#_Toc36495191)

[ANDCM – And with Compliment 25](#_Toc36495192)

[BIT – Test bits 26](#_Toc36495193)

[CMP - Compare 27](#_Toc36495194)

[CMPU – Unsigned Compare 27](#_Toc36495195)

[DIV - Divide 28](#_Toc36495196)

[DIVU – Unsigned Divide 29](#_Toc36495197)

[ENOR – Exclusive Nor 30](#_Toc36495198)

[EOR – Bitwise Exclusive Or 31](#_Toc36495199)

[MUL - Multiply 32](#_Toc36495200)

[MULU – Unsigned Multiply 32](#_Toc36495201)

[OR – Bitwise ‘Or’ 33](#_Toc36495202)

[ORIS – Or Immediate Shifted 33](#_Toc36495203)

[ORCM – Or with Compliment 34](#_Toc36495204)

[SHL – Shift Left 35](#_Toc36495205)

[SHR – Shift Right 35](#_Toc36495206)

[SUB - Subtract 36](#_Toc36495207)

[SUBF – Subtract from Immediate 36](#_Toc36495208)

[Bit Field 37](#_Toc36495209)

[CLR – Bit-field Clear 37](#_Toc36495210)

[DEP – Deposit (Bit-field Insert) 37](#_Toc36495211)

[EXT – Bit-field Extract 37](#_Toc36495212)

[EXTU – Bit-field Extract Unsigned 38](#_Toc36495213)

[Memory Operations 39](#_Toc36495214)

[LDB – Load Byte (8 bits) 39](#_Toc36495215)

[LDD – Load Double Word (64 bits) 40](#_Toc36495216)

[LDH – Load Half Word (16 bits) 41](#_Toc36495217)

[STD – Store Double Word (64-bits) 42](#_Toc36495218)

[MOVI – Move Immediate 43](#_Toc36495219)

# Overview

Thor2020 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. Thor2020 uses fixed length instructions three packed into a 128-bit bundle and handles 8, 16, 32, and 64-bit data within a 64-bit address space.

## 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.

## Thor2020 Differences from Thor Original

Instructions are fixed 41-bit length and packed into instruction bundles. Thor’s instruction set was variable length and byte aligned. The fixed instruction size of Thor2020 simplifies fetch logic removing instruction alignment requirements and the need to determine the instruction length.

Opcodes are seven bits instead of eight bits. About ½ of the opcode space of Thor is unassigned and instruction bits are valuable. Thor’s instruction set could be compressed to fit into seven bits.

Predicate registers are only two bits wide and record a +1,0, or -1 compare result. There are only eight predicate conditions testable. Reducing the number of tests reduces the number of encoding bits required to three from four. Reducing the predicate register size reduces hardware requirements and simplifies the design.

There is an auto-record bit in most instructions allowing the result status (plus, zero, or minus) to be placed into predicate register #1 for integer or predicate register #2 for floating-point operations. This allows some code compression by removing the need for a compare operation in some circumstances.

## Programming Model

### 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 or +0.0. Predicate register #0 is always 0.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAakAAAF3CAIAAACQeiNTAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAC8QSURBVHhe7d0PTNT3/T9w+M2WziIISm3a9GshwdBss0tBmDXftg6orbGOTph/2nwXINHMkaUB28a61mpta6rQpXEusADxu1Z0aG21cyJYrN/oAhazOk1bTUBly7aiKIq2WBd+T+719p0Pn7uDu+PuvM+9n4+k1/f7fZ9/9+Fzz3u/P3d+PrGDg4MxRESG+X/q/0REJmH2EZGJmH1EZCJmHxGZiNlHRCZi9hGRiZh9RGQiZh8RmYjZR0QmYvYRkYmMy76Kior8/HxVcaz29vZp06apip+Sk5O3bdumKkSmCl/2IXRiLfDuVU+E3cSJE1XJInI2zxerVq1au3atqsTEdHV1qe2Ojc3MzFStNyHs0K5f0ebNm2tra6VMZKwwZR86KXv27Bm8qa+v74knnrh8+bJ6OrwuXbqkSsPl5eXJ5jU0NOTk5ERs/GG/dXR0zJ07V6oIPuQdtlk2Hk9Ju6irq5s8eXJSUpKqx8RgRkxzq3Y+UYQIR/YtW7ZswoQJp06dUvWYmISEhN7eXjyqenh57PeBbl+0aBHCorOzU6qRZseOHYgzvfc2bdqUm5uLbZaqFWJxxYoV1h6itnfvXlUiMlI4sq+xsfH5559XFU/y8/NlvAa6P4LGbdu2yXgNrL0wj9Oja6mnl4k9Tgbe+n3WdoSLFGQzpIzF6kXZVldUVIRH37dWFiWsZ+68bbPVyZMnp06dqioxMfX19QsWLFCV4RCLxcXFuocoEJpoRCyqOpGRQp598h5LS0uTqju829HhkvFabW3t7Nmz1RMxMYsXL963bx/ay8vLf/GLX0ijx+kRE+fPn8f0Z86cQXt2djYmKy0tlckwuzUdRu33oaN6+vRpW2TAxYsXpeC+OuQmhsmytdgqlCW5rFuLzUhMTEQ79gmG/G1tbdKue8Qj7Aqr48eP//jHP5ay7N7W1laVl7GxFRUV+inEYmVl5YULF6TF6uOPP1YlIiOFPPt6enp0ZIDuGUlnB+/Pjo4O3SssKSm5cuVKU1MTykiBhoYGxArKCxcuPHbsmKSGx+nRl0FPDdPrkWBzc7MeBn7ve9/DEFvKI8BYUratpqamr6/PfUiuz5q5rw701mKrMCUGlejctbS06C8WEEPp6elYS2pqKmbfvn27tIsRdoXN2bNnkbyq4hIfHy+JiTytqqqSXucLL7yA/p1MYOPjDiGKYiHPvpSUFOu5M7zlpFMzYcIEaUEyopckoQPocElWehuZepveFgeIEp2z6ACq1piY/v5+VXKjv+sA9+Czkn6fqvgDc40fPx4F9PXQKZPNsw6QPb40K1m1HpKLGTNmSAHhK3sby/zss8+QttJOHsmZB+mhB5G3xYZodVEJ+8p6LsgjvMHH8mutkGcf+jiZmZmvvPKKqt+ETg0OgkmTJuG9qkd/wuNpe+Hj9FgyRtmbN2+WCdAjk9XhKXSRvKWqx7Gwx0bp96mKi3UyWdEIw3whHwN4Lcg7/KWlcdSXhlXn5ubq5JUu5NGjR6UKsmHoVCI6hxI0NhZbIh8YGFPLNCdPnsRxI+UoYP19kn6NoSMRFoYVBayurk72htCnQQJQVFR0S16p7Vdcuh8D+sNj48aNO3fulHIAwvFdB4aQeK/aUhz9PryNAcm4YcMG1eqF7v74OL3tDNfy5ctldVL1GGfgMROx0/X+feKJJ6SAvW/r92HexYsXS4RhVIsNzsjIkF6Y7nUuW7YMUWWLM+kXoyAfEqO+NMAmnTt3TlViYmbPnn3w4EEp46CXM5Xo8an4HBxEN1A6g83NzTLZ8ePHve0Ex5G9oV7q4OD06dPffPNN9dxo3LvVvsCoZenSpS0tLaruxttiA1tdYB566CHZIfi7Y4Th+z6xwYE98qGCYA16OMr5H33CHcvH5728nPLycn0eHIUDBw7oKPSbLDEMMKJUq3RBX0w94fZUX18fGgsLC/U06A3pdvA4fXp6unWZKKunY2LeeOMNPCvt2HfWsa2GdqxRVYaTbAJsBsoeV4dlomqdUj1hmV1vw759+6RF2JajWl30S7bC9HpRwjqX+yxowTbYNsm6UufCX822K/xiO658ITsTjzhaEIKqdThviw1gdYHBhmG36BV5O+aDYoQ3TsBsR7j1cLXtw7EcyeHLvugm2acqISb9uIDfQjK7qjjcyIe+x48EvHzV5PpQtO7JkT9CBGJFckQXhLfFemwHvLex5dIuH0se1y5vdaG7ctbPTt1ohW2zttviadTdImSr0MPV89o2BvNaF6X3hsfly18Kj2jEcmyLkmk060oBC9TToAxSBrw07FVV8ROzLzjw9whb9sFYVocZrUePc+F9hfcS3kWqPhxeo37/4B2C95i8D63tCCBrO0g7dpG132SFaWTP29aOdm+L9dhuLYN1Mlk7CvIpZXuBHhttrNuPR6xIthncVySTYZkSIqhal6/7jN7W6x6sHpdvfb2jvgQsAYtVFRcsFrODLen05gWA2Rcc+APowysMcNzI2yMAOOzCuamhM8JbSHpG8k4T8qpts+jJpB2P0g7Yve5Llsn0YvFHl7fiyIt1bwe067+CbTLQVRTc+zUeG63Q78OKNKxO2t1XJC/T1m49mK3R5nG91vTxtnwU0G496jwuSrM9K4vFWrAleDnW5dh6uH4Jx3cdJrD+nDAMsrOzrf9G0C+9vb3h3NTQSU1NxSPeGFK1wltFlW6Sr7/l16YZGRnSqCebNGkS2tPS0tRXia4fGLkvubW1FZMlJibKNC0tLfX19Wj3tlhv7QnDfyeAtePR+vMmzCVrxx9rw4YN0qh/DOCx0UZ/NCIvsrKyVKuL7XdUWJH8WkB+cCrfM1h/paC/A/S2XtuXIe7LV09YjPwSsDH6u0RsT2Zm5ubNm/EWa2xsRJLqLxVh/Pjx+icc/mL2kYMVFxf78isH/b28fKv+xRdfSLt24cIFtFs7LOD+CbFixQprpwPvaiwW70Nvi/XWbvudgPwswdvaEROo4lnrb6E8Nlrp38++9dZbCCDr7+A8rgjbU1VVhSSSH4fJr/SFNdo8rtf2AwlvL8TG20vAzpk6dar+bJDPD/2dr/4Fq1TxafTggw/qn3D4hdlHDlZWVnbgwAHrbyzq6upQxTsEHR/9DxnXrFkjvy6SriJmwSM6FPpHS778wAjvT+ubEDBXbm4uuku2fpN1sR7bbe9VWc6qVatU3RP9Wygrj41C94awcAxL5RMCZY8vs6mpCU9JVIEtrdx/+4WerHW9SDEpeFs+6CyzcX8J2DnTp0/X/+ZSes360hv4++KvoLulWLX75vlKvVwix8rz9G0j6DeV9ZQQugy6HZ0ORKQ+HWZdDuh2YfvyUciZNUzpbbEe2wGN1i4kuK8d06uKi0zvsdHGdhZMZsGjVD2+TNspQr1Yfb7P23p1F0zvefflg/X1jvoSPG6/pl8IuO9G38XiP7VIIjISOlOlpaVIKOmQooeLcaiuhp+c4ztz5szIG4CO7f333z/qZN5wzEtEQ11jnSAnTpyQwq0iY+dRLzG5Y8cOTBZwQLPfR0RD/27M+q/0bmGnT6Dv+eyzz3766acjbEZycvLmzZu9fZcyKmYfEZmIY14iMhGzj4hMxOwjIhMx+4jIRMw+IjIRs4+ITMTsIyITMfuIyETMPiIyEbOPiEzE7CMiEzH7iMhEzD4iMhGzj4hM5ODs6+rqkvs8wbRp0+TuBB4biYAHTIjk5+erPRgb66AdGLTsW7ZsmXr1LtYbL4UCDtm0tDR9qf5Tp07JNQ6XLl3aefMuq+fPn//tb38r05PvHHooj4wHTIjgjS93XAPszNmzZzvmmJGNHjvrLYrlvidySxHsDt0eRNZbJntj3STyEf5e+tau2IHWW/k4Gg+YUJA7MembB8k9iaz3EopkwRzz6vt4lpSUYBfIDZzi4+Ntty4eO3yw1NfX6zsQeoTPeUxTWlqq6uQD7LTGxsZ3331XqmVlZegKud9e1nF4wIQIus/Wm68Lfee2CBfM7HO/USZGT1VVVTt27MDoCWW0JCcnb9u2TcZTTU1NMllgWltbZTlQUVEhjTjKpUVusRzwtfzNJPeB1odyqututk45lEfFAybocLSokktCQkJubu7Ro0dVPbKFpN+HAws7BYdRc3OzHkegLM8uX75chlFz5syRFn9duHABy7///vtdXdeh23ciYeUMI/a+NAJWVFRUJLOQL9xv0JWZmYkOkao4Fg+YELl27Zoq3YQOkLfbkEeaYGaf9O8ABxbSTbVaMhGwX/DpKqeZxwJjaumVQHZ2th5iW+3btw+b5JgzrxFg/PjxqnQT/nYY9qqKk/GACYXvf//7qnRTR0eH3s8RLmjZ19/fbz2XrNMN7VIAHFVBeSPJzh21P2LrkNOokAiqdNOBAwdmzJihKo7FAyZEUlJScMzoM8Kyh9PS0qQa4YKWffHx8e7n+8DajkAMVn+4uLi4vr5eynV1dThq586di2zFGE0aYePGjYjjsfcxzTFz5kznHsoj4wETCvhQyc3NXbVqlVTXr1+PKrrVUo1wITnfZ9Pb2yuFYPX7oLKycurUqTLELi0tlZ4mZGVlSSNgexobG9UM5APsQGTBhg0bpOqsQ3lkPGBCBHsM41zZgZ9++qmDdmAsDgJVHJuKiorjx4/rLzQ09B3wdsLHbF5eHp6dNm3a2rVr+W1aJEtOTpbRX3p6+qlTp6SRKMoELfuIiBwkmGNeIiKnYPYRkYmYfURkImYfEZmI2UdEJmL2EZGJmH1EZCJmHxGZKDi/bf7v//ndlasDquKnCXfG/d///kJV/DGWlZK/Av4zEUWm4GTfDxf85q87n1MVPwU871hWSv7i3qYow+wjnzh6b3OIEE6OGSIg+8buwZ++rUr+C3jesayU/OXovc1DJZycsrf5XUf4WO/9OOp1NIkopJh9YWK9jancL1E9QTRcVN4fOQIx+8IBvbzGxsbf/e53Ul29ejVaxnibOopK+Iw8e/as/ozMyspi/IUIsy8cPN7GVK4PSqTJZ2T03R85MjH7wsEWcwmOuo0phU103x850jD7wsHRtzGlsInW+yNHJmZfODj6NqZ0C0XN/ZEjELMvHBx9G1MKm3vvvVeVboqO+yNHJmZfODj6NqYUNlF8f+QIxOwLE+fexpTCJiF6748cgZh94aN/24wQVE1EwzU3N2OcK5+Rra2t/IwMHWYfUWTRn5G8MXxIMfuIyETMPiIyUXCu3/dY2T483hY34duBK/4+Xv/68pHan8ly/PJw6R/vnHjvCEuO2EdsvK0RLRFeCPjPFAl4qcdwcsreDk72jeXVBjwvD+hwcvTexsfk7d9N8D3ob0lBP6LFVtCPI8weOQU4uOkJKUQ010nVsRrL1QoDnpcXpAwnR+9tHirh5JS9zfN9RBHt0KFDsbyQXwgw+0Klrq5OfqUlKioq1BM3LVu2DO08pqOe/KFFfn6+anXx5Rj48MMP582bl5CQoOouox5dkpi21ZEVsy+EMjIypHfd2dlZX1//6quvqidiYpKTk2tqam6//XZVp2h048YN/KH17/Vg+vTpchjIU74cA1u3bn355ZdVxWKEowvee++9pUuXIgH54eoNsy9U8Kn7n//8R8qpqanFxcX6n3Pg0x4tn3zyyfXr1wcGeP+wqPXiiy9OmTLF+m8zKisrJaTwlD4G5CmPEGoTJ050/2dtIxxd0NPTg5Vu2LDh8ccf/9Of/qRaaThmX6jgA3nChKGv6kR/f/8dd9wh5erqahypUo2Li5NGijLo2SG5Vq9ererDIQRxDIwbN07VvUCnb+HChapiMcLRBXv27Jk1axaGyU8//TSWoFppOGZfqOCT+cqVKzLikGuRL1iwQJ4iE/zzn//E48hXYZHs89b37+7uRj6Wl5erusXIR1dDQ8MzzzyDQn5+/uHDh9vb26WdrJh9oYJP5tOnTycmJuIwxRvgzJkzixYtUs+5oF+gShSN5O975513StWjkadZt25dbm6u7VsOMcLRhShEYs6fPx/l++67LzMzc+/evfIUWTH7QgUHZXp6Oo5RKCwszMrKUk/cNOp4hxwt1XVd7r/97W9S9UiOgatXr0rVZvfu3d7GCrajKycnR98X4eDBgxcvXkSeYhpoaWnZvn27+10TiNkXKjgo9RmZt956C5/S27Ztk6r45ptvVImiVHFx8XvvvacqnozQ72tqaurt7Z07d66qD2c7ujo7OxGUUq2oqMCY15WKQ86dO/fvf//b/U4gxOwLFXzk6jMy6AKUl5fb3gbWk9MUlZ577rnDhw9bf2RXX19vrY7Q79u/f//KlSs9DnjBdnSVlZXJ0dXe3o5OnzUxMezFwBldP1Wnm5h9oYKPXHwy62N34cKFH330kZx1ll+0YpyCspyy4dnoqITcQd8NH3L4E4v333+/ubkZT1mPgbvuugtl6zHQ1dWFlPTW6QNvR1dtbS2GwLbEfPLJJ6uqqjjstXP1i8dqLP+CL+B5+Y80w8nRe9txG19XV5eRkfHtt9+quqM4ZW+z30cUcbZu3bp69Wp+GxZSvH5fkB+xYSMURmBdyC1/xPbYCrx+H/nIKXub1+8jnzh6b498/b6gP7rWGQjfZ9dTBjzLGB+xnBEKvH6fTwKe19FnoBzH0Xubh0o4OWVv83wfEZmI2UdEJmL2EZGJmH1EZCJmHxGZiNlHRCZi9hGRiZh9RGQiZh8RmYjZR0QmYvYR3WJdXV3JycmxsbEnT56UFrm6n77Qt9yJvKioSKoUFMw+okihL+Ast/Q9evSoVNva2vDY2dnJG40HEbOPKCIkJSVlZGRIWbp4M2bMkKpc3jkrK8vbJewpAMw+olssNTW110VHW3V19eDgoL7tZElJCapolCoFBbOPiEzE7CMiEzH7iMhEzD4iMhGzj4hMxOwjIhMx+4jIRMw+IjIRs4+ITMTsIyITMfuIyESxg4ODqjgGP1zwm7/ufE5V/BTwvGNZKfnL0Xv7sbJ9UrgtbsK3A1dYCGnh+teXj9T+DNVIh+wbuwd/+rYq+S/geceyUvKXo/c2D5Vwcsre5piXKBIdOXIkNjaWF+wLHWYfUUjItZfFU089pVpdV2mOi4uT9gceeEC1utmyZUtBQYH1gn2HDh3CLO3t7aoeE5Ofny9Llgs7axUVFTKBJvNielUnZh9RKCQnJ/f29qrB1eDgtGnTJI+6u7szMjKQa9L++eefy/TuWltbV65cqSoujzzyyLx5837+859fu3YNVXQMW1pa3nvvPXk2PT1dltnX11dfX2+Lvw8//HDp0qWYnh1JjdlHFGTo8aWmpsp150WlCwrr1q2bP3++viipN+jHfec738nOzlb1m9555x2k5+7du1FGDq5evVp3DCdMmCAFtBQVFZ07d06qgJ4m0nDDhg15eXl79+5VrcZj9hEFGbLp+eefV5Xh0JtbsGCBqni3a9euuXPnqooFIvX3v//94sWL33zzzSlTprz66qvSjvHslStXdJ8uPj7+xo0bUgas9NFHH0UmlpSU6H4iMfuIggmdrIGBgbS0NFW3wFPnz5/fv3+/66TcEPcTc4DJDh8+/Nprr6n6cAi+pKSkl156CZ0+1eT6tQb6fdIHxOxVVVULFy6Up6ChoUGqP/rRj7Bk6xlDkzH7iIJp3LhxquQFkktOzLW1tSGk3JNo06ZNs2bNGj9+vKq7QbdOlSyOHTsmeYrY7evr08Pqnp6ejo4O6UWi24gO4Pbt2+UpwzH7iIJp0qRJcXFxnZ2dqu5G330tOzsbOWib8tq1a/X19c8884yqu1m2bFlmZmZdXR06gPKlh3jooYckUvPy8mbPnq1aY2L27Nlz8eLFxMREScYPPvjg4MGD6jmzMfuIggn9tSVLlng8rYZu1+TJk/Vdd8G9B3fixAlElceTfYBOYk1NzcqVK4uLiwsKCn7yk5+oJ2Ji9Pm+nTt3fvnllwhQaV+xYgXGvBKL8NVXX2FQfOjQIXnWZMw+oiArKytrbW19+umnVd31va38tg49Mt3tQmN3d7ct5mpra9944w3rz/qsVq1ahciT73+RgC0tLXrIrM/34RHdRvk+t6mpCUlq/Vo5JSUF3caPP/5Y1Q3G7CMKMvTv+l1kmAnoeTU3N+Op6urq5ORkaSwtLe3r67PGHKKwsbExNzdX1YdDViLstmzZIlUkYGFh4bPPPovyd7/7Xev3vFjyjh07EIv79+/HEFgaNXRL16xZwx/68d/zkk8cvbedsvHo9OnTds7llL3Nfh9RpED3EONlVaEQY/YRRQqMi4uLi1WFQozZR0QmYvYRkYl43WbySRRct9n3Kw8H/IgluBcCM8IC/Sp4bJRCAI+Yd9QCr9vsq4DndfQ3j47j6L3NQyWcnLK3OeYlIhMx+4jIRMw+IjIRs4+ITMTsIyITMfuIIl1TU1Ms71cZbMw+opCz3q9SLmbV3d2t6hYeL2EP+/fvnzdvnu3CVtZlgu2SfO5rJBtmH1EIXbt2zXa/yunTpyPj7rvvPlV36ezsTEpKst5kQ7tx48bWrVtffvllVb8pPj6+oKBAZq+trX300UflWn7e1ihzkcbsIwohZNaUKVM83q/SatOmTbm5ue43pYQ//OEPEydO9PhUf3+/FEpKSu6++265/L2PayRmH1GoyM03rDdU86jLdf9cb/euRKfPY38QkImqFBMzMDAgBV/WSMDsIwoVuUmux/tVWrW2tk6ePNnjDcu7u7s7OjrKy8tVfbhLly5JAUNaucuHfB8y6hoJmH1EoXLhwgVVGtGKFSvWrl2rKsOtW7cOY2Fvt+9oaWmRbzOqqqquXr2KyXxcIwGzjyhUUlNT8TjC/Sph27ZtI9yYbffu3d7GwlBYWKi+zhgclPv5+rJGEsw+ohAqLi7euXOnqniyfPlybzdma2pq+te//jV//nxVH05/0WEz6hpJMPuIQqisrOzAgQPWX9jp+1VCe3s7On3ebsy2f//+1atXS4fOXXx8vD7fZzXyGklj9hGFEAahvb29KMiJOdizZ4/crxJWrVqVl5fn8fcr8uWvt7GwsH7Pq7mvUd8hk6yYfUQhh+hRp+UGB3ft2qVaXe3eUungwYNTpkzxGIuisrLS+iM+G+sava3CcMw+oki0detW/kwvpJh9RJEInTWPv/ijYGH2EZGJmH1EZCLeo5J84ui9jY1XJQoLRxwqzD7yCfc2RRmOeYnIRMw+IjIRs4+ITMTsIyITMfuIyETMPiIyEbOPiEzE7CMiEzH7iMhEzD4iMhGzj4hMxOwjIhMx+4jIRMw+IjIRs4+ITMTsIyITMfuIyETMPiIyEbOPiEzE7CMiEzH7iMhEzD4iMhGzj4hMxOwjIhMx+4jIRMw+IjIRs4+ITMTsIyITMfuIyETMPiIyEbOPiEzE7CMaq6amptjY2K6uLlUnn2HXTZs27fLly6ruj+Tk5Lq6OlXxH7OPDLVs2TIEltbe3q6e8N+ECRPwOGnSJDzmu7iaQw7vfLX1LhUVFeoJPyF6wrnZVhs3bly7dm1CQoKq3/y72NIQnyvyGkFnJeZtaGiQCQLA7CNDxcfHFxQUDLrU1tbm5OSgD6Ke89O4ceNUaQzwng8gfdLT0+UlfPXVV/X19YHFH6Jn4sSJquJFYJs3MiRaR0fH3LlzVd3VlaupqUHhwoUL0gKYLC0tDTEnr/TUqVOSlYWFhZg9sD4jMPvIUP39/TqzSkpKkpKSLl68KFV/WWdsdlEVP40aQCNISUkpKio6d+6cqvupsbFx1M0ey+Z51Nrampqaqjt9iFdU9+3bhzIK0gjr169HzC1atEjVh9u7d68q+YnZR4ZCv+/SpUuqEhMzefJkKaDrsW3bNhleSU8Q/R2pgj6pZx2F/eMf/5BGQM/L2j/S83pshJ6eHmlBf2fHjh1o0VNaJ9PrtcFwW3d8bK/I4+zWzRZHjhxBu3Wz5fSlkAGm75tn3Xvt7e3ui5LJxMmTJzG9qsTEVFdXox+HDyGUra8XubxgwQJVsUBoFhcXHz16VNX9xOwjc+mODHocp0+f1oOv5cuX9/X1YXg1Z84cvMMxmYy2MDRGBwQT4D28dOlSlKV9xYoVMqPQi5WYkGmmT5+OUJDG0tJSaSwvL1+yZAka0edCWRYo/S/rvLLeGzduoMXmypUr0m9CWGDMiyVLu/vsqGKzMzMz33jjDTR2dnYiZdra2h5++GHXHGqzsZzFixejXeaVAaaPmyfRpvceuqLui8IE2vHjx2fNmqUqw+l+n4QgeogqQd1Oawbc1WX2kbmkIwPo1ODtKu9M9J42b94sZXTK0BN5/vnnXZMPDY2RNdIZtLbLME2TzhfetJjm9ddfl8bKykoZtSE79PBtxowZZ8+elTLoXpttXlnvgQMHpGqFyJaXkJaWdubMGVmyx9mx2QMDA6jm5ubiEeGCHEQCuiYZImtHO7rAHgeSI2weWo4dO4adZt17sqjt27fLZO7w2rFhqjKcdIc1LFYCFElaVVWlv5jKysr67LPPbN1JHzH7yFD9/f3SkRHydkXnBe0yAaB88eLFnJwcyRdA1qDlL3/5Cx6zs7PVdMNJBwrvXo/TICbUsmJj0S2S74iF7jAK9/WqJyz0dx15eXmzZ89WrS7us6MjhnbJUMkvJKZr2iF67eigvfPOOzKj9evvETYPC5cYte49wKLQG5VpbN+kI7DOnz+vTzVo8jLj4uKkKvAhIQXsT3RXdWR//fXX2IHyt/MXs48MZTs7Jmzf2E6aNEkGhpIvAn2rmTNnot3bz2JksQgaTCNn0zQkDnpb+itLFNDx0d0WvT3ycxn39cqzVvp8386dO9Hzsv7mw9vsL730EpIIqYcOmjWarXujt7cXs2AJCDj9MgPYPPC4KEBgoQeK+FP1m7DTVMlFOo/Wk3rWuLSdMfQLs4/MZevIuMP7E1G1YcMGVb9p/PjxeJTRHOIM72rrO1YWK4PKt99+WxqXLVsm5/us3bfly5dbuy2ICSl4W687RKfMjselS5e+//77KMuq3WdH9OApiSqwpZX73pD4VpWANk+zLUogtnw5W4f+7MGDB6VcV1dnPTN7/PjxUf+I3jD7yFzu/T6wjcKam5sxmYzaBPpZ6B6eOXNGRnPoQKFTo6Z20YvFvBhgylxfffUVsgbRg64ZhrrSKGcMpeO2evVqdNzQKF8jeFzv0EKHs37PW1paumPHDulbeZwdvbxf/vKXqu4icSxkszG7em5437CsrExG6yNvnnXvoc+rnvPUzQSE2meffaYqro8HTIkPEpQTExNRltdSXV2NlHQtJhavUZ+ZBQzbPX4F7BP1ETA2D/70bVXyX8DzjmWl5C/u7ShQW1uLt7x8CQsS2boafvJdc8AbMMbZ2e8LFXxIyoeVPschH2v6XyDKP0gqKiqSKlEYpKen607TiRMnpHCryNg84B8nI7sxu345/mL2hdD169dVyaWxsRGPJ0+elKp86uKzy+PvtoiCrqSkZOrUqUNDRxf5mWHA2REUr7/++iuvvKIqflq+fLn+PWMAmH2hEh8ff88996CQkZEhLcXFxXjU39bLeY20tLSg/GtQIl80NzfLiE+o1lsnOzv71KlTquKn3t5eb18u+4LZFyopKSn4o+Lw0p+rlZWVqOq/Fj6EUZXOIBGFGbOPiEzE7CMiEzH7iMhEzD4iMhGzj4hMxOwjIhMx+4jIRMw+IjIRs4+ITMTsIyITMfuIyETMPiIyEbOPiEzE7CMiEzH7iMhEzD4iGqvLly/n5+er60F7ua1SpGH2ERlNbiPT1dWl6gFZs2bN2bNnh64EPThYXl6elZUV+fHH7CMyFOIpOTm5pqYG5fvuu08aA4DcrK+vf/fdd6VaVlZ2/vz5L774QqoRi9lHZCh01lJTUw8fPoyy9Y7p/urp6cHs+r40WCYeOzs7pRqxmH1EhqqsrOzo6JByXFycFALgfq/LzMzMMQ6iw4DZR2S0UNwmcOLEiRj2qkqkYvYRGW0so11x7733qpLLjRs3Dhw4oO/FGrGYfURGS0pKUqVAzZw5EwvRX250d3fjMS0tTaoRi9lHZDR001QpUAkJCZmZmW+++aZU169fn5ubm52dLdWIxewjMlpQzvc1Nzd/8skn8sPm1tZWR9xxn9lHZCj5VXNOTg7KiYmJKLe3t8tTAejt7ZXfNp86dUo1RTZmH5GhqqurJa20yB+oBhGzj4hMxOwjIhMx+4jIRMw+IjIRs4+ITMTsIyITMfuIyETMPiIyEbOPiEzE7CMiE8UODg6q4hj8cMFv/rrzOVXxU8DzjmWl5C/u7Sjz3//zuytXB1QlBCbcGfd///sLVYlM8u/4xujBn76tSv4LeN6xrJT8xb0dZUL9B438A4ZjXiIyEbOPiEzE7COiIXI5P01fy+/y5cv5+fmqNTY28m867iNmHxENiY+Pz8vLk3NhtbW1OTk5En9r1qw5e/astJeXl2dlZUVH/DH7iGhIf3//xIkTpVxSUpKUlNTZ2dnV1VVfX//uu+9Ke1lZ2fnz5/VtiRyN2UdEQ9DvUyWLnp6eixcvZmRkSDU1NRWPyESpOhqzj4iGoN+nSq5zf3icO3fuiRMnpEXLzMxEZ1BVnIzZR0RD0O/bsWOHfKFRU1Nz5syZhISE8ePHq6dvwrgYw15VcTJmHxENQb+vsLBQvtMABB8a3e9cfuDAgRkzZqiKkzH7iGiIx/N9M2fORPzpLzdktJuWliZVR2P2EdEQ6/k+Db2/zMzMDRs2SHX9+vW5ubnRcStLZh8RDUG/79KlS6pi0dzcjHGunAdsbW1tbGxUTzgcs4+IhlRWViLmVGW43t5eOQl46tQp1eR8zD4iMhGzj4hMxGuXkk+4t6PMY2X7pHBb3IRvB67gEWVdsJatjZo04hFlj4WeM0cj/YCRYfwYjeU6hQHPy6tphhP3dpQJ9R808g8YjnmJyETMPiIa4u36fUKejZqL9wGzj4iGxMfHFxQUyHiwrq5OX78P/uu//qumpkbKUYPZR0TKjRs3pFBcXCzX70MZPb6UlJR9+/bdfvvt8mx0YPYRkQf6n/dWV1d3dHQgCq9fvy4t0YHZR0TKuHHjpIC+Xnd3d2FhoVSjErOPiJQPPvhAvuioqanp6+vTUagNDITwduZhxuwjoiEer9+nXbx4EY9xcXFSjQLMPiIaEh8f/80336iKG/eLmDods4+IlDvuuEOVDMDsIyLF4/X75FfNOTk5KCcmJqLc1NQkTzkas4+Ihni7fl91dbU6BXjTnDlz1HNOxuwjIhMx+4jIRLx+H/mEezvKPFa2Ty63px/VEz6zzqsv26cLvH7f6AKel1eUCyfu7SgT6j9o5B8wHPMSkYmYfURkImYfEZmI2UdEJmL2EZGJmH1EZCJmHxGZiNlHRCZi9hGRiZh9RGQiZh8RmYjZR0QmYvYRmaurqys5OTk2Nra9vV1a5CrNdXV1UkUB1aKiIqlGE2YfkdFsdxxvbGzE48mTJ6Xa1taGx87Ozhs3bkhL1GD2EZkrPj7+nnvuQSEjI0NaiouL8Thjxgypym060tLS3O/V63TMPiJzpaSknDp1atByN97KykpUFy1aJNWSkhJUpTMYZZh9RGQiZh8RmYjZR0QmYvYRkYmYfURkImYfEZmI2UdEJmL2EZGJmH1EZKLYwcFBVRyDHy74zV93Pqcqfgp43rGslPzFvR1lHi794+3fTbgtbsK3A1dQlcLIj3oyXwrXv758pPZnqEYuZN/YPfjTt1XJfwHPO5aVkr+4t6NMqP+gkX/AcMxLRCYKzpj3sbJ9ePS9P2wtBNw3lpWCX6tjIbCCA4Yw5I9Qn8RwwEkS6f6N0Vj6twHPy1FYOHFvR5lQ/0Ej/4DhmJeIhsgVm7UjR46oJ1zk2Z6eHlW3kCs/26aPfMw+IhoSHx9fUFAgfaLa2tpZs2bJhexv3LiBdKupqbn99tvj4uJkYq2urm7y5MlJSUmOu7gps4+IFH1h+pKSkrvvvruzsxPlF198MTU19ZNPPrFd3R66urpWrFixdu1aVXcUZh8RDenv77/jjjtUJSZmYGBACpWVlR0dHR67devXr//Vr36Vm5ur6o7C7COiIRjzfvPNN1KuqKi4ePHi3LlzpQqSfToQoaenp7Gxsby8XM/lLMw+IlI++ugj1/ccsVVVVd9++62+iQfIcPjOO+/U1SVLlqDTh2kcegs3Zh8RKfPmzZPvOsA2yJXq1atXpdre3v73v//917/+NcroMEqjszD7iGiI7XyfjQxsdb9vy5YtX3zxxW233YZO4l133YUBck5OzlNPPSXPOgKzj4iGWM/3uZNY1P2+6upq1T8cHOzr60tKSmpra9uzZ4886wjMPiJSPPb75FfNcpNydPFQlt/9aRcuXFAlR2H2EdGQyspKj/cgt3bxRHZ2tnrOJTU1tbe319YY+Zh9RGQiZh8RmYjXbSafcG9HmYdL/3jnxHu/dV2TGVVd8It1Ltuirl76B6/bPIqA5+VVlcKJezvKhPoPGvkHDMe8RGQiXreZBZ8KvG5zlAn1SQwHnCSR7t8YjaV/G/C8HIWFE/d2lAn1HzTyDxiOeYnIRMw+IjIRs+8WO3LkSKyX2yAQUegw+0ZRV1eHbNIqKirUEy5dXV3qidjYBx54YIRGb7Zs2VJQUJCSkqLqw2fftm2bNNruI2P7B5VE5C9m3+jS09Pl5GhfX199fb2Ov+7u7h/84AcNDQ3y7Oeffy7t5eXlbW1t0njp0iVbXNq0trauXLlSVVwefvjh1atXy+zbt2+/fPkyGuPj4/W11RDHOTk5jrstFkU42+froUOH1BMu8iyOeVV3m37k4zwCMftGN2HCBLkybUJCQlFR0blz56R93bp1Tz755KJFi6Sq7dq1S/+77iVLlsgNXzzauHEjFm79R+Do9A0MDOhrhWNRcu1c67XViouLk5KS9GYQBUthYaF8vtbW1j766KMyvLh27Zq+T9ukSZNkSqGnh8rKStXqEMy+UeAD7cqVK/jzSxX9L32F7t27dy9YsEDKHvX09GzatGnhwoWq7ubw4cOPPfaYqrikpqbGxcW99tprqn6T7dpq7rcKJBoj6+WXS0pK8PkqH9svv/yyvk+b9fL01umdiNk3CnygoWsmnS90yqqqqiTLpIOGEat0+EH3+fUJu7vuumvLli3uHUOByXA8ucccxrly2wTbIEL3+zDW6O3tnT9/vlSJggJjC1UaTu7T5n5pP2/TOwWzb3THjh2TLEtLS+vr65Mskw89PEqHv62tDbEoYwR8SEojvPDCC/n5+UNLcYMu4axZs8aPH6/qNz3yyCOYsaGhAQvESuV8H+zYsUM2A6MP9CjdZyQaCxzMly5dkjI+d233aXOH6fUxOW3aNH2gOgWzb3QZGRkSZHl5ebNnz5ZGfOhdvXr18ccfl2p2drYeI1jh4GhpaXE/LDCIrq+vf+aZZ1TdDRIWS8My16xZIy1Yu2wGWG+gRRQsOFYly/C5azvM3C9nj/6gHI0wdepU/dZwCmbf6NDDkvDauXPnl19+WVdXhzI6d/h779+/3zXJkMmTJ6uSD06cODHq5ypWkZmZqRc7ceJEKRCFiPW7C9V0k8fL2Wuvv/46hkdNTU2q7gTMvtGhjyYfgHhET+3Pf/6ztOOD7uDBg1JGIJ4+fRpZ1tXVZR3krlq1qqCgwL2bVltbu3r1avd2LEfPjhE0Pof1Te/1eIQoFEY+f+fLDcjnzJmjSk7A7Bud7vdBaWkphrFyXq+6ujo5OVnGCGjv6+tDlqGzlpaWJo2AT8tdu3bJvFp3d3djY6PHTl9JScn06dNl3pycnLa2Nv0LGPb7KKSs5/vc2fp9eAtYP+OfffbZvLw8VXEIZt8oEEYdHR26g4YkwnBA51Fzc7MMEEBPY723i8e79mEuRKT1Z31W1tMoehpv95EhCiKPn6/yG2a5T1tiYiLKCD45Ml2f0UOeeuopHNWuyR2D2XcLNDQ0rFixQlWIIoO3z1dv92mzfvBjXpnYQYJ2vw5VCkjA9+tQJQoL3q8jmvDapcHJPiJyFmYfx7xEZCL2+4hMFIZTRhzzEhFFHI55ichEzD4iMhGzj4hMxOwjIhMx+4jIRMw+IjIRs4+ITMTsIyITMfuIyETMPiIyEbOPiEzE7CMiEzH7iMhEzD4iMhGzj4hMxOwjIvPExPx/jnwK4TEPGvUAAAAASUVORK5CYII=)

### Code Address Registers

The processor contains eight code address registers (C0-C7). 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 | Catch Link Register | Used by the compiler to link to try/catch handlers. |
| 6 | Exceptioned PC | This register is automatically set during a hardware interrupt or exception. |
| 7 | Instruction Pointer | Relative address formation. This register is read-only. |

Code address registers may be used to point to a block of code from which the JMP instruction can index into with its 24-bit offset. For instance, a register may contain a pointer to a class method jump list; the JMP 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 instruction pointer register is read-only. The instruction pointer cannot be modified by moving a value to this register.

#### Instruction Pointer

|  |  |  |
| --- | --- | --- |
| 63 32 | 31 0 | |
| Instruction Bank | Instruction Pointer | 04 |

The instruction pointer is special in that it is always incrementing by the size of an instruction bundle fetched as a program runs. Program code is 128-bit aligned. To improve performance only the low order 32 bits of the program counter increment. The entire instruction pointer may be loaded with a jump instruction. If the upper eight bits of the instruction pointer / 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 32, 2-bit predicate registers. The predicate registers hold the value +1,0, or -1. The value is set as the result of a compare operation. If the first operand is greater than the second then the value +1 is stored in the predicate register. If the first operand is equal to the second then the value 0 is stored in the predicate register. Otherwise if the first operand is less than the second then the value -1 is stored in the predicate register.

All instructions are executed conditionally determined by the value of a predicate register.

### Predicate Conditions

There are eight predicate conditions that can be checked, summarized in the table below.

|  |  |  |  |
| --- | --- | --- | --- |
| Cond. |  | Test |  |
| 0 | PUN | p = -2 | unordered (floating point) |
| 1 |  |  | reserved |
| 2 | PZ | p = 0 | Instruction executes if the predicate register zero |
| 3 | PNZ | p = 1 or p = -1 | Instruction executes if the predicate register is non-zero |
| 4 | PLE | p = 0 or p = -1 | predicate less than or equal to zero |
| 5 | PGT | p = 1 | predicate greater than zero |
| 6 | PGE | p = 0 or p = 1 | predicate greater or equal to zero |
| 7 | PLT | p = -1 | predicate less than zero |

### 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 P1 and incrementing are applied for use as the control flow nesting level increases. The compiler does not support control flow nesting more than 13 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 | always 1 – allows unconditional instruction execution. This predicate is automatically implied by the assembler if no other predicate is specified. |
| P1 | control flow nesting level 1 |
| P2 | control flow nesting level 2 |
| … |  |
| Pn | control flow nesting level n (n not to exceed 29) |
| … |  |
| 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 |

## **Summary of Special Purpose Registers**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Reg # | R/W | Size |  |  |  |
| 01h | R | 64 | HARTID | hardware thread id |  |
| 02h | R | 64 | TICK | tick count |  |
| 06h | RW | 16 | CAUSE | exception cause code |  |
| 07h | RW | 64 | BADADDR | fault address |  |
| 09h | RW | 64 | SCRATCH | scratchpad register |  |
| 0Dh | RW | 60 | KEYS | memory keys (0-2) |  |
| 0Eh | RW | 60 | KEYS | memory keys (3-5) |  |
| 0Fh | RW | 60 | KEYS | memory keys |  |
| 12h | RW | 32 | ASID | address space identifier / process id |  |
| 14h | RW | 64 | FSTAT | floating-point status and control |  |
| 16h | RW | 32 | PREGS | predicate register array |  |
| 17h | RW | 64 | LC | loop counter |  |
| 20-27h | RW | 64 | CREGS | Code address register array (C0 to C7) |  |
| 40h | RW | 32 | IM | interrupt mask stack |  |
| 44h | RW | 64 | STATUS | machine status register |  |
| 60-67h | RW | 64 | SREGS | Segment register array (zs,ds,es,fs,gs,hs,ss,cs) |  |
|  | RW |  | USP | user stack pointer |  |

# Operating Levels

The core operates at one of four basic levels: application/user, supervisor, hypervisor or machine. Machine level is switched to when an interrupt or exception occurs, or when debugging is triggered. On power-up the core is running at the machine level. An RTI instruction must be executed in order to leave machine level after power-up.

A subset of instructions is limited to the machine level.

# Instructions

## Instruction Bundles

Thor2020 uses instruction bundles. Three 41-bit instructions are placed in a 128-bit bundle. The remaining bits of the bundle are for control. Instructions are effectively executed in the order slot0, slot1, then slot2. Multiple instructions may be executed in the same clock cycle. Stop bits in the control part of the bundle indicate when multiple cycles are required to resolve dependencies.

|  |  |  |  |
| --- | --- | --- | --- |
| 127 123 | 122 82 | 81 41 | 40 0 |
| Control | Slot2 | Slot1 | Slot0 |

|  |  |
| --- | --- |
| Control | Description |
| 123 | stop after instruction zero |
| 124 | stop after instruction one |
| 125 | stop after instruction two |
| 126 | reserved |
| 127 | reserved |

## Instruction Pointer

The instruction pointer is always bundle (128-bit) aligned. Jumps and branches target a 128-bit aligned address. The first slot of a bundle is always targeted. Since branch targets must be bundle aligned it may be necessary for the assembler / compiler to output NOP instructions.

## Large Constants

Constants less than 15 bits in size are directly supported for most instructions. For larger constants there are two options: a) constants less than 35 bits in size can be built using the OR and ORIS instructions b) the MOVI instruction can be used to move a full 64-bit constant into a register. Note that MOVI is restricted to placement in slot #0 only and also occupies slot #1. Using the OR / ORIS to build a 34-bit constant may be done using any available slots. Constants up to 34 bits may also be built using the ADD / ADDIS instructions.

## Placement Restrictions

Most instructions may occupy any slot. However, there are some instructions which can only be placed in specific slots. The restrictions are present because the hardware does not support operations on all pipes symmetrically. Some infrequently used instructions are limited to a single pipe.

MOVI can only be placed in slot #0.

MFSPR must be placed in slot #0.

MTSPR must be placed in slot #2.

# Instruction Set Summary

## Compare Instructions

The results of multiple compare operations may target the same register by using one of the Boolean operations (.or, .and, .orcm, .andcm).

|  |  |  |
| --- | --- | --- |
| Op3 | Mne. Ext | Operation |
| 0 |  | set predicate to true if condition is true, otherwise set to false. |
| 1 | .unc | always set target predicate to zero, then set to true if condition is true and qualifying predicate is true. |
| 2 | .or | set predicate to true if condition is true, otherwise target is unaltered |
| 3 | .and | set predicate to false if condition is false, otherwise target is unaltered |
| 4 | .orcm | set predicate to true if condition is false, otherwise target is unaltered |
| 5 | .andcm | set predicate to false if condition is true, otherwise target is unaltered |
| 6 |  | reserved |
| 7 |  | reserved |

## Jump Instructions

The core uses predicated a jump instruction to perform branching. Branches may be relative to the address of the current instruction by specifying code address register seven (the instruction pointer) as a reference. A single jump instruction may be used to implement branching on multiple complex conditions when combined with a predicate. The jump instruction supports a 24-bit displacement field.

## 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.

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  |  | | | | | | | | |  |  | | Pred6 |  |
| 27 | 47 | | | | | ~ | P | Rb6 | | Ra6 | Rt6 | | Pr6 | ADD |
| 27 | 57 | | | | | ~ | P | Rb6 | | Ra6 | Rt6 | | Pr6 | SUB |
| 27 | 87 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | AND |
| 27 | 97 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | OR |
| 27 | 107 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | EOR |
| 27 | 117 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | ANDCM |
| 27 | 127 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | NAND |
| 27 | 137 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | NOR |
| 27 | 147 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | ENOR |
| 27 | 157 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | ORCM |
| 27 | 167 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | SHL |
| 27 | 177 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | SHR |
| 27 | 187 | | | | |  | | Rb6 | | Ra6 | Rt6 | | Pr6 | ASR |
| 27 | 207 | | | | |  | | Imm6 | | Ra6 | Rt6 | | Pr6 | SHL # |
| 27 | 217 | | | | |  | | Imm6 | | Ra6 | Rt6 | | Pr6 | SHR # |
| 27 | 227 | | | | |  | | Imm6 | | Ra6 | Rt6 | | Pr6 | ASR # |
| 27 | 327 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CLT |
| 27 | 337 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CGE |
| 27 | 347 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CLE |
| 27 | 357 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CGT |
| 27 | 367 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CLTU |
| 27 | 377 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CGEU |
| 27 | 387 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CLEU |
| 27 | 397 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CGTU |
| 27 | 407 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CEQ |
| 27 | 417 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | CNE |
| 27 | 427 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | INTERSECT (BIT) |
| 27 | 437 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | UNION |
| 27 | 447 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | DISJOINT |
| 27 | 467 | | | | |  | | Spr12 | | | Rt6 | | Pr6 | MFSPR |
| 27 | 477 | | | | |  | | Spr12 | | | Rs6 | | Pr6 | MTSPR |
| 27 | 487 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | FCLT |
| 27 | 497 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | FCGE |
| 27 | 507 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | FCLE |
| 27 | 517 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | FCGT |
| 27 | 527 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | FCEQ |
| 27 | 537 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | FCNE |
| 27 | 557 | | | | | Op3 | | Rb6 | | Ra6 | Pt6 | | Pr6 | FCUN |
| 27 | 797 | | | | |  | | Imm12 | | | Ca3 | ~ | Pr6 | RTS |
| 27 | 807 | | | | |  |  | Rb6 | | Ra6 | Rt6 | | Pr6 | LDB |
| 27 | 817 | | | | |  | S | Rb6 | | Ra6 | Rt6 | | Pr6 | LDH |
| 27 | 827 | | | | |  | S | Rb6 | | Ra6 | Rt6 | | Pr6 | LDW |
| 27 | 837 | | | | |  | S | Rb6 | | Ra6 | Rt6 | | Pr6 | LDD |
| 27 | 847 | | | | |  |  | Rb6 | | Ra6 | Rt6 | | Pr6 | LDBU |
| 27 | 857 | | | | |  | S | Rb6 | | Ra6 | Rt6 | | Pr6 | LDHU |
| 27 | 867 | | | | |  | S | Rb6 | | Ra6 | Rt6 | | Pr6 | LDWU |
| 27 | 877 | | | | |  | S2 | Rb6 | | Ra6 | Rt6 | | Pr6 | LEA |
| 27 | 897 | | | | |  | S | Rb6 | | Ra6 | Fpt6 | | Pr6 | LDFS |
| 27 | 907 | | | | |  | S | Rb6 | | Ra6 | Fpt6 | | Pr6 | LDFD |
| 27 | 967 | | | | |  |  | Rb6 | | Ra6 | Rs6 | | Pr6 | STB |
| 27 | 977 | | | | |  | S | Rb6 | | Ra6 | Rs6 | | Pr6 | STH |
| 27 | 987 | | | | |  | S | Rb6 | | Ra6 | Rs6 | | Pr6 | STW |
| 27 | 997 | | | | |  | S | Rb6 | | Ra6 | Rs6 | | Pr6 | STD |
| 47 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | ADD # |
| 57 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | SUBF # |
| 87 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | AND # |
| 97 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | OR # |
| 107 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | EOR # |
| 167 | Immediate22 | | | | | | | | | | Rt6 | | Pr6 | ANDIS # |
| 177 | Immediate22 | | | | | | | | | | Rt6 | | Pr6 | ORIS # |
| 187 | Immediate22 | | | | | | | | | | Rt6 | | Pr6 | EORIS # |
| 207 | ~4 | | | Rc6 | | | | Rb6 | | Ra6 | Rt6 | | Pr6 | SHLP |
| 217 | ~4 | | | Rc6 | | | | Rb6 | | Ra6 | Rt6 | | Pr6 | SHRP |
| 227 | ~4 | | | Imm6 | | | | Rb6 | | Ra6 | Rt6 | | Pr6 | SHLP # |
| 237 | ~4 | | | Imm6 | | | | Rb6 | | Ra6 | Rt6 | | Pr6 | SHRP # |
| 247 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | MUL # |
| 257 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | MULU # |
| 267 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | DIV # |
| 277 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | DIVU # |
| 287 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | DIVR # |
| 297 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | DIVRU # |
| 327 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CLT # |
| 337 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CGE # |
| 347 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CLE # |
| 357 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CGT # |
| 367 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CLTU # |
| 377 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CGEU # |
| 387 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CLEU # |
| 397 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CGTU # |
| 407 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CEQ # |
| 417 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | CNE # |
| 427 | Op3 | Immediate13 | | | | | | | | Ra6 | Pt6 | | Pr6 | INTERSECT # |
| 567 | 04 | | | Me6 | | | | Mb6 | | Ra6 | Rt6 | | Pr6 | EXTU |
| 567 | 14 | | | Me6 | | | | Mb6 | | Ra6 | Rt6 | | Pr6 | EXT |
| 567 | 24 | | | Me6 | | | | Mb6 | | Ra6 | Rt6 | | Pr6 | DEP |
| 567 | 34 | | | Me6 | | | | Mb6 | | Imm6 | Rt6 | | Pr6 | DEP # |
| Imm41 | 647 | Immediate22 | | | | | | | | | | Rt6 | | Pr6 | MOV # |
| Imm41 | 657 | Immediate22 | | | | | | | | | | Rt6 | | Pr6 | MOV # |
| 727 | Displacement23..2 | | | | | | | | | | Ca3 | Ct3 | Pr6 | JMP |
| 737 | Displacement23..2 | | | | | | | | | | Ca3 | Ct3 | Pr6 | JMP.ctop |
| 747 | Displacement23..2 | | | | | | | | | | Ca3 | Ct3 | Pr6 | JMP.cexit |
| 757 | Displacement23..2 | | | | | | | | | | Ca3 | Ct3 | Pr6 | JMP.wtop |
| 767 | Displacement23..2 | | | | | | | | | | Ca3 | Ct3 | Pr6 | JMP.wexit |
| 777 | Displacement23..2 | | | | | | | | | | Ca3 | Ct3 | ~6 | LOOP |
| Disp63..24 | 797 | Displacement23..2 | | | | | | | | | | Ca3 | Ct3 | Pr6 | JML |
| 807 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | LDB |
| 817 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | LDH |
| 827 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | LDW |
| 837 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | LDD |
| 847 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | LDBU |
| 857 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | LDHU |
| 867 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | LDWU |
| 877 | Immediate16 | | | | | | | | | Ra6 | Rt6 | | Pr6 | LEA |
| 897 | Immediate16 | | | | | | | | | Ra6 | Fpt6 | | Pr6 | LDFS |
| 907 | Immediate16 | | | | | | | | | Ra6 | Fpt6 | | Pr6 | LDFD |
| 967 | Immediate16 | | | | | | | | | Ra6 | Rs6 | | Pr6 | STB |
| 977 | Immediate16 | | | | | | | | | Ra6 | Rs6 | | Pr6 | STH |
| 987 | Immediate16 | | | | | | | | | Ra6 | Rs6 | | Pr6 | STW |
| 997 | Immediate16 | | | | | | | | | Ra6 | Rs6 | | Pr6 | STD |
| 1017 | Immediate16 | | | | | | | | | Ra6 | Fps6 | | Pr6 | STFS |
| 1027 | Immediate16 | | | | | | | | | Ra6 | Fps6 | | Pr6 | STFD |
| 1127 | rm3 | | ~ | | Rc6 | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FMADD |
| 1137 | rm3 | | ~ | | Rc6 | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FMSUB |
| 1147 | rm3 | | ~ | | Rc6 | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FNMADD |
| 1157 | rm3 | | ~ | | Rc6 | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FNMSUB |
| 1167 | 03 | | ~ | | Rc6 | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FMIN3 |
| 1167 | 13 | | ~ | | Rc6 | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FMAX3 |
| 1197 | rm3 | | 47 | | | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FADD |
| 1197 | rm3 | | 57 | | | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FSUB |
| 1197 | rm3 | | 67 | | | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FMUL |
| 1197 | rm3 | | 77 | | | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FDIV |
| 1197 | 03 | | 87 | | | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FSGNJ |
| 1197 | 13 | | 87 | | | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FSGNJN |
| 1197 | 23 | | 87 | | | | | | Rb6 | Ra6 | Fpt6 | | Pr6 | FSGNJX |
| 1197 | rm3 | | 97 | | | | | | 06 | Ra6 | Fpt6 | | Pr6 | FCVT.L.D |
| 1197 | rm3 | | 97 | | | | | | 16 | Ra6 | Fpt6 | | Pr6 | FCVT.W.S |
| 1197 | rm3 | | 97 | | | | | | 26 | Ra6 | Fpt6 | | Pr6 | FCVT.S.D |
| 1197 | rm3 | | 97 | | | | | | 46 | Fpa6 | Rt6 | | Pr6 | FCVT.D.L |
| 1197 | rm3 | | 97 | | | | | | 56 | Fpa6 | Rt6 | | Pr6 | FCVT.S.W |
| 1197 | rm3 | | 97 | | | | | | 66 | Fpa6 | Fpt6 | | Pr6 | FCVT.D.S |
| 1197 | ~3 | | 97 | | | | | | 86 | Fpa6 | Rt6 | | Pr6 | FGETMAN |
| 1197 | ~3 | | 97 | | | | | | 96 | Fpa6 | Rt6 | | Pr6 | FGETEXP |
| 1197 | ~3 | | 97 | | | | | | 106 | Ra6 | Fpt6 | | Pr6 | FSETMAN |
| 1197 | ~3 | | 97 | | | | | | 116 | Ra6 | Fpt6 | | Pr6 | FSETEXP |
| 1197 | ~3 | | 97 | | | | | | 126 | Ra6 | Fpt6 | | Pr6 | FTRUC |
| 1197 | rm3 | | 97 | | | | | | 136 | Fpa6 | Fpt6 | | Pr6 | FSRQT |
| 1197 | ~3 | | 97 | | | | | | 146 | Fpa6 | Fpt6 | | Pr6 | FSIGN |
| 1197 | ~3 | | 97 | | | | | | 156 | Fpa6 | Fpt6 | | Pr6 | FMAN |
| 1197 | ~3 | | 97 | | | | | | 166 | Fpa6 | Fpt6 | | Pr6 | FMOV |
| 1197 | ~3 | | 97 | | | | | | 206 | Fpa6 | Fpt6 | | Pr6 | FRES |
| 1197 | ~3 | | 97 | | | | | | 216 | Fpa6 | Fpt6 | | Pr6 | FRSQRTE |
| 1197 | ~3 | | 97 | | | | | | 286 | Fpa6 | Fpt6 | | Pr6 | FISNAN |
| 1197 | ~3 | | 97 | | | | | | 296 | Fpa6 | Fpt6 | | Pr6 | FFINITE |
| 1197 | ~3 | | 97 | | | | | | 306 | Fpa6 | Fpt6 | | Pr6 | FCLASS |
| 1197 | ~3 | | 487 | | | | | | Fpb6 | Fpa6 | Pt6 | | Pr6 | FCLT |
| 1197 | ~3 | | 497 | | | | | | Fpb6 | Fpa6 | Pt6 | | Pr6 | FCGE |
| 1197 | ~3 | | 507 | | | | | | Fpb6 | Fpa6 | Pt6 | | Pr6 | FCLE |
| 1197 | ~3 | | 517 | | | | | | Fpb6 | Fpa6 | Pt6 | | Pr6 | FCGT |
| 1197 | ~3 | | 527 | | | | | | Fpb6 | Fpa6 | Pt6 | | Pr6 | FCEQ |
| 1197 | ~3 | | 537 | | | | | | Fpb6 | Fpa6 | Pt6 | | Pr6 | FCNE |
| 1197 | ~3 | | 557 | | | | | | Fpb6 | Fpa6 | Pt6 | | Pr6 | FCUN |

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 47 | | | Pr4 | Pc3 | Rc | ADD # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 57 | | | Pr4 | Pc3 | Rc | SUBF # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 87 | | | Pr4 | Pc3 | Rc | AND # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 97 | | | Pr4 | Pc3 | Rc | OR # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 107 | | | Pr4 | Pc3 | Rc | EOR # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 247 | | | Pr4 | Pc3 | Rc | MUL # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 257 | | | Pr4 | Pc3 | Rc | MULU # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 267 | | | Pr4 | Pc3 | Rc | DIV # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 277 | | | Pr4 | Pc3 | Rc | DIVU # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 287 | | | Pr4 | Pc3 | Rc | DIVR # |
| Immediate14 | | | | | | | Ra6 | Rt6 | | | | | 297 | | | Pr4 | Pc3 | Rc | DIVRU # |
| Immediate20 | | | | | | | | Rt6 | | | | | 307 | | | Pr4 | Pc3 | Rc | ADDIS # |
| Immediate20 | | | | | | | | Rt6 | | | | | 317 | | | Pr4 | Pc3 | Rc | ORIS # |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 53 | Func4 | | Pr4 | Pc3 | Rc | LDx |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 807 | | | Pr4 | Pc3 | Rc | LDB |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 817 | | | Pr4 | Pc3 | Rc | LDH |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 827 | | | Pr4 | Pc3 | Rc | LDW |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 837 | | | Pr4 | Pc3 | Rc | LDD |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 847 | | | Pr4 | Pc3 | Rc | LDBU |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 857 | | | Pr4 | Pc3 | Rc | LDHU |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 867 | | | Pr4 | Pc3 | Rc | LDWU |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 897 | | | Pr4 | Pc3 | Rc | LDFS |
| Disp13..0 | | | | | | | Ra6 | Rt6 | | | | | 907 | | | Pr4 | Pc3 | Rc | LDFD |
| Disp13..0 | | | | | | | Ra6 | Rs6 | | | | | 63 | Func4 | | Pr4 | Pc3 | Rc | STx |
| Disp13..0 | | | | | | | Ra6 | Rs6 | | | | | 967 | | | Pr4 | Pc3 | ~ | STB |
| Disp13..0 | | | | | | | Ra6 | Rs6 | | | | | 977 | | | Pr4 | Pc3 | ~ | STH |
| Disp13..0 | | | | | | | Ra6 | Rs6 | | | | | 987 | | | Pr4 | Pc3 | ~ | STW |
| Disp13..0 | | | | | | | Ra6 | Rs6 | | | | | 997 | | | Pr4 | Pc3 | ~ | STD |
| Disp13..0 | | | | | | | Ra6 | Rs6 | | | | | 1017 | | | Pr4 | Pc3 | ~ | STFS |
| Immediate14 | | | | | | | Ra6 | 0 | | Pt5 | | | 67 | | | Pr4 | Pc3 | ~ | CMPU # |
| Immediate14 | | | | | | | Ra6 | 1 | | Pt5 | | | 67 | | | Pr4 | Pc3 | ~ | CMP # |
| Immediate14 | | | | | | | Ra6 | ~ | | Pt5 | | | 77 | | | Pr4 | Pc3 | ~ | BIT # |
|  | | | | | | |  |  | | | | |  | | |  |  |  |  |
|  | | |  | | |  |  |  | | | | |  | | |  |  |  |  |
| 47 | | | | Oe | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | ADD |
| 57 | | | | Oe | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | SUB |
| 87 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | AND |
| 97 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | OR |
| 107 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | EOR |
| 117 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | ANDCM |
| 127 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | NAND |
| 137 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | NOR |
| 147 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | ENOR |
| 157 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | ORCM |
| 167 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | SHL |
| 177 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | SHR |
| 187 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | ASR |
| 207 | | | | ~ | | imm6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | SHL # |
| 217 | | | | ~ | | imm6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | SHR # |
| 227 | | | | ~ | | imm6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | ASR # |
| 247 | | | | Oe | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | MUL |
| 257 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | MULU |
| 267 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | DIV |
| 277 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | DIVU |
| 287 | | | | ~ | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | MOD |
| 327 | | | | ~ | | Spr12 | | Rt6 | | | | | 27 | | | Pr4 | Pc3 | Rc | MFSPR |
| 337 | | | | ~ | | Spr12 | | Rs6 | | | | | 27 | | | Pr4 | Pc3 | Rc | MTSPR |
| 67 | | | | ~ | | Rb6 | Ra6 | 02 | | Pt4 | | | 27 | | | Pr4 | Pc3 | ~ | CMPU |
| 67 | | | | ~ | | Rb6 | Ra6 | 12 | | Pt4 | | | 27 | | | Pr4 | Pc3 | ~ | CMP |
| 77 | | | | ~ | | Rb6 | Ra6 | ~ | | Pt4 | | | 27 | | | Pr4 | Pc3 | ~ | BIT |
| 02 | Me6 | | | | | Mb6 | Ra6 | Rt6 | | | | | 567 | | | Pr4 | Pc3 | Rc | EXTU |
| 12 | Me6 | | | | | Mb6 | Ra6 | Rt6 | | | | | 567 | | | Pr4 | Pc3 | Rc | EXT |
| 22 | Me6 | | | | | Mb6 | Ra6 | Rt6 | | | | | 567 | | | Pr4 | Pc3 | Rc | DEP |
| 32 | Me6 | | | | | Mb6 | Imm6 | Rt6 | | | | | 567 | | | Pr4 | Pc3 | Rc | DEP # |
| r21 | Rc6 | | | | | Rb6 | Ra6 | Rt6 | | | | | 566 | | r0 | Pr5 | Pc3 | Rc | FMADD |
| r21 | Rc6 | | | | | Rb6 | Ra6 | Rt6 | | | | | 576 | | r0 | Pr5 | Pc3 | Rc | FMSUB |
| r21 | Rc6 | | | | | Rb6 | Ra6 | Rt6 | | | | | 586 | | r0 | Pr5 | Pc3 | Rc | FNMADD |
| r21 | Rc6 | | | | | Rb6 | Ra6 | Rt6 | | | | | 596 | | r0 | Pr5 | Pc3 | Rc | FNMSUB |
| 02 | Rc6 | | | | | Rb6 | Ra6 | Rt6 | | | | | 1207 | | | Pr5 | Pc3 | Rc | FMIN3 |
| 12 | Rc6 | | | | | Rb6 | Ra6 | Rt6 | | | | | 1207 | | | Pr5 | Pc3 | Rc | FMAX3 |
| 44 | | rm3 | | | ~ | Rb6 | Ra6 | Rt6 | | | | | 1217 | | | Pr5 | Pc3 | Rc | FADD |
| 54 | | rm3 | | | ~ | Rb6 | Ra6 | Rt6 | | | | | 1217 | | | Pr5 | Pc3 | Rc | FSUB |
| 64 | | rm3 | | | ~ | Rb6 | Ra6 | Rt6 | | | | | 1217 | | | Pr5 | Pc3 | Rc | FMUL |
| 74 | | rm3 | | | ~ | Rb6 | Ra6 | Rt6 | | | | | 1217 | | | Pr5 | Pc3 | Rc | FDIV |
| 84 | | 03 | | | ~ | Rb6 | Ra6 | Rt6 | | | | | 1217 | | | Pr5 | Pc3 | Rc | FSGNJ |
| 84 | | 13 | | | ~ | Rb6 | Ra6 | Rt6 | | | | | 1217 | | | Pr5 | Pc3 | Rc | FSGNJN |
| 84 | | 23 | | | ~ | Rb6 | Ra6 | Rt6 | | | | | 1217 | | | Pr5 | Pc3 | Rc | FSGNJX |
| 797 | | | | ~ | | Imm12 | | Ca3 | | | ~3 | | 27 | | | Pr4 | Pc3 | ~ | RTS |
| 807 | | | | Sc | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr5 | Pc3 | Rc | LDB |
| 817 | | | | Sc | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr5 | Pc3 | Rc | LDH |
| 827 | | | | Sc | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr5 | Pc3 | Rc | LDW |
| 837 | | | | Sc | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr5 | Pc3 | Rc | LDD |
| 847 | | | | Sc | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr5 | Pc3 | Rc | LDBU |
| 857 | | | | Sc | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr5 | Pc3 | Rc | LDHU |
| 867 | | | | Sc | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr5 | Pc3 | Rc | LDWU |
| 897 | | | | Sc | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr5 | Pc3 | Rc | LDFS |
| 907 | | | | Sc | | Rb6 | Ra6 | Rt6 | | | | | 27 | | | Pr5 | Pc3 | Rc | LDFD |
| 967 | | | | Sc | | Rb6 | Ra6 | Rs6 | | | | | 27 | | | Pr5 | Pc3 | ~ | STB |
| 977 | | | | Sc | | Rb6 | Ra6 | Rs6 | | | | | 27 | | | Pr5 | Pc3 | ~ | STH |
| 987 | | | | Sc | | Rb6 | Ra6 | Rs6 | | | | | 27 | | | Pr5 | Pc3 | ~ | STW |
| 997 | | | | Sc | | Rb6 | Ra6 | Rs6 | | | | | 27 | | | Pr5 | Pc3 | ~ | STD |
| 1017 | | | | Sc | | Rb6 | Ra6 | Rs6 | | | | | 27 | | | Pr5 | Pc3 | ~ | STFS |
| Immediate22..3 | | | | | | | | Rt6 | | | | | 84 | I2..0 | | Pr4 | Pc3 | Rc | MOVI |
| Displacement22..3 | | | | | | | | | Ca3 | | | Ct3 | 777 | | | Pr4 | Pc3 | D2 | LOOP |
| Displacement22..3 | | | | | | | | | Ca3 | | | Ct3 | 787 | | | Pr4 | Pc3 | D2 | JMP |
| Displacement22..3 | | | | | | | | | Ca3 | | | Ct3 | 797 | | | Pr4 | Pc3 | D2 | JML |

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 0 | 0 | 1 | 2  {RR} | 3 | 4  ADD # | 5  SUBF # | 6 | 7 |
| 1 | 8  AND # | 9  OR # | 10  EOR # | 11 | 12 | 13 | 14 | 15 |
| 2 | 16  ANDIS # | 17  ORIS # | 18  EORIS # | 19 | 20 | 21 | 22 | 23 |
| 3 | 24  MUL # | 25  MULU # | 26  DIV # | 27  DIVU # | 28  DIVR # | 29  DIVRU # | 30  ADDIS | 31 |
| 4 | 32  CLT # | 33  CGE # | 34  CLE # | 35  CGT # | 36  CLTU # | 37  CGEU # | 38  CLEU # | 39  CGTU # |
| 5 | 40  CEQ # | 41  CNE # | 42  INTERSECT | 43  UNION | 44  DISJOINT | 45 | 46  MFSPR | 47  MTSPR |
| 6 | 48  FCLT | 49  FCGE | 50  FCLE | 51  FCGT | 52  FCEQ | 53  FCNE | 54 | 55  FCUN |
| 7 | 56  EXT / DEP | 57 | 58 | 59 | 60 | 61 | 62 | 63 |
| 8 | 64  MOVI | | 66 | 67 | 68 | 69 | 70 | 71 |
| 9 | 72  JMP.ctop | 73  JMP.cexit | 74  JMP.wtop | 75  JMP.wexit | 76  LOOP | 77 | 78 | 79  JML |
| A | 80  LDB | 81  LDH | 82  LDW | 83  LDD | 84  LDBU | 85  LDHU | 86  LDWU | 87  LEA |
| B | 88 | 89  LDFS | 90  LDFD | 91 | 92 | 93 | 94 | 95 |
| C | 96  STB | 97  STH | 98  STW | 99  STD | 100 | 101  STFS | 102  STFD | 103 |
| D | 104 | 105 | 106 | 107 | 108 | 109 | 110 | 111 |
| E | 112  FMADD | 113  FMSUB | 114  FNMADD | 115  FNMSUB | 116 FMIN3  FMAX3 | 117 | 118 | 119  {FRR} |
| F | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 |

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 0 | 0  FCVT.L.D | 1  FCVT.W.S | 2  FCVT.S.D | 3 | 4  FCVT.D.L | 5  FCVT.S.W | 6  FCVT.D.S | 7 |
| 1 | 8  FGETMAN | 9  FGETEXP | 10  FSETMAN | 11  FSETEXP | 12  FTRUNC | 13  FSQRT | 14  FSIGN | 15  FMAN |
| 2 | 16  FMOV | 17 | 18 | 19 | 20  FRES | 21  FRSQRTE | 22  FSIG | 23 |
| 3 | 24  FSTAT | 25 | 26 | 27 | 28  ISNAN | 29  FINITE | 30  FCLASS | 31  UNORD |
| 4 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 |
| 5 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 |
| 6 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 |
| 7 | 56  FTX | 57  FCX | 58  FEX | 59  FDX | 60  FRM | 61 | 62 | 63  FSYNC |

# Detailed Instruction Set Description

## Control Flow Instructions

### BRK –Break

**Description:**

The Break exception is executed. The core will be switched to kernel mode. The cause code register is set to four. The program counter is reset to $FFFFFFFFFFFC0000 and instructions begin executing.

**Instruction Format: BRK**

**Operation:**

CAUSE = 40h | Const4

OLS = OLS << 2

DLS = DLS << 2

XL = IP + 1

IP = $FFFFFFFFFFFC0000

**Execution Units**: Branch

**Clock Cycles**:

**Exceptions**: none

**Notes**:

### BSR - Branch to Subroutine

**Description:**

This is an alternate mnemonic for the JMP 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. Cr is specified as C7, which reflects the value of the instruction pointer. The result is an instruction pointer relative branch.

The subroutine return address is stored in a code address register specified in the Ct field of the instruction. Typically, code address register #1 is used to store the return address. If not specified code address register #1 will be assumed by the assembler.

**Instruction Formats: JMP**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement23..4 | 73 | 13 | 787 | Pr4 | Pc4 | JMP |

**Execution Units**: Branch

**Clock Cycles:** 0.33

**Exceptions:** none

### JML - Jump to Long Address

**Description:**

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 Ca. An absolute address may be jumped to by specifying C0 as the code address register for Ca.

A subroutine return address may be stored in a code address register specified in the Ct field of the instruction. Typically, code address register #1 is used.

This instruction is unusual in that it occupies the first two slots of a bundle. A full 64-bit address may be formed.

**Instruction Format**:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 127 123 | 122 82 | 81 41 | 40 0 | |
| Control | Slot2 | Address63..24 | Address23..2 | Other |

**Clock cycles**: 0.66 (two slots are occupied).

**Execution Unit:** FCU

**Operation:**

C[t] = ip + 16

ip = C[n] + offset

**Exceptions**: none

### JMP - Jump to Address

**Description:**

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 Ca. An absolute address may be jumped to by specifying C0 as the code address register for Ca.

A subroutine return address may be stored in a code address register specified in the Ct field of the instruction. Typically, code address register #1 is used.

**Instruction Formats: JMP**

**Clock Cycles:** 0.33

**Execution Units:** All ALU’s

**Operation:**

Cr[t] = pc

pc = Cr[n] + displacement

**Exceptions**: none

### JSR - Jump to Subroutine

**Description:**

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 Ca. Normally for JSR the code address register is assumed to be C0.

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

**Instruction Formats: JMP**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Displacement23..4 | 03 | 13 | 787 | Pr4 | Pc4 | JMP |

**Clock Cycles:** 0.33 to 1.0

**Execution Unit:** All ALU’s

**Operation:**

Ct[t] = ip

ip = Ca[n] + displacement

**Exceptions:** none

### LOOP – Loop Branch

**Description:**

A branch is made if the loop count register is non-zero. The loop count register is decremented by this instruction. The loop branch is predicted as always taken and does not consume room in the branch predication tables. The target address is the sum of a code address register and displacement specified in the instruction. This instruction is unusual in that the predicate is ignored.

**Instruction Format: JMP**

**Clock Cycles:** 0.33 to 1.0

**Execution Units:** Branch

**Operation:**

If LC <> 0

IP <= Ca + displacement

LC = LC – 1

### RTS – Return from Subroutine

**Description:**

This is an alternate mnemonic for the JMP instruction where the code address register used is assumed to be C1 (the default return address).

The instruction pointer is loaded with the value contained in the specified code address register plus a displacement constant specified in the instruction. 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.

**Instruction Formats: JMP**

**Execution Unit:** Branch

**Operation:**

PC = Ca[N] +Imm

**Exceptions:** none

## Arithmetic / Logical

### ADD - Addition

**Description:**

Add two registers or a register and an immediate value and place the sum in the target register. The register form of the instruction may cause an overflow exception is enabled.

**Instruction Format: R2, RI**

**Clock Cycles:** 0.33

**Execution Unit:** AllALU’s

**Operation:**

Rt = Ra + Rb

Rt = Ra + Imm

**Exceptions**: integer overflow

### ADDIS – Add Immediate Shifted

**Description:**

Add an immediate value to a target register. The immediate value is sign extended to sixty-four bits and shifted left by sixteen bits before use. This instruction may follow an ADD # instruction to form a 38-bit immediate addition. It may also be used to load a constant into a register.

**Instruction Format: RIS**

**Clock Cycles:** 0.33

**Execution Unit:** AllALU’s

**Operation:**

Rt = Rt + (Imm << 16)

**Exceptions**: none

### AND – Bitwise ‘And’

**Description:**

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

**Instruction Format: R2, RI**

**Clock Cycles:** 0.33

**Execution Unit:** AllALU’s

**Operation:**

Rt = Ra & Rb

Rt = Ra & ones\_extend(Imm)

**Exceptions:** none

### ANDCM – 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: R2**

**Clock Cycles:** 0.33

**Execution Unit:** AllALU’s

**Operation:**

Rt = Ra & ~Rb

**Exceptions:** none

### ANDIS – And Immediate Shifted

**Description:**

Bitwise ‘and’ an immediate value to a target register. The immediate value is shifted left sixteen times and one filled to the left and right before use. This instruction may follow an AND # instruction to form a 38-bit immediate and.

**Instruction Format: RIS**

**Clock Cycles:** 0.33

**Execution Unit:** AllALU’s

**Operation:**

Rt = Rt | (Imm << 16)

**Exceptions**: none

### BIT – Test bits

**Description:**

Logically and’s register and an immediate value or two registers 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: R2, RI**

**Clock Cycles:** 0.33

**Execution Unit:** All ALU’s

**Operation:**

Pt = flag results( Ra & immediate)

Pt = flag results (Ra & Rb)

**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

### CMP - Compare

**Description:**

The compare instruction compares two registers or a register and an immediate value and sets the flags in the target predicate register as a result.

**Instruction Format: R2, RI**

**Clock Cycles:** 0.33

**Execution Unit:** AllALU’s

**Operation:**

if signed Opa < signed Opb

P = -1

else if Opa = Opb

P = 0

else

P = 1

**Exceptions:** none

### CMPU – Unsigned Compare

**Description:**

The compare instruction compares two registers or a register and an immediate value and sets the flags in the target predicate register as a result.

**Instruction Format: R2, RI**

**Clock Cycles:** 0.33

**Execution Unit:** AllALU’s

**Operation:**

if unsigned Opa < unsigned Opb

P = -1

else if Opa = Opb

P = 0

else

P = 1

**Exceptions:** none

### DIV - Divide

**Description:**

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

**Instruction Format: R2, RI**

**Clock Cycles:** 68

**Execution Units:** ALU

**Operation:**

Rt = Ra / Rb

Rt = Ra / #imm

**Exceptions**: divide by zero

### DIVU – Unsigned Divide

**Description:**

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

**Instruction Format: R2, RI**

**Clock Cycles:** 68

**Execution Units:** ALU

**Operation:**

Rt = Ra / Rb

Rt = Ra / #imm

**Exceptions:** none

### ENOR – Exclusive Nor

**Description:**

Bitwise exclusive or register with register and place inverted result in target register. There is no immediate form of this instruction.

**Instruction Format: R2**

**Clock Cycles:** 0.33

**Execution Unit:** All ALU’s

**Operation:**

Rt = ~(Ra ^ Rb)

**Exceptions:** none

### EOR – Bitwise Exclusive Or

**Description:**

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

**Instruction Format: R2, RI**

**Clock Cycles:** 0.33

**Execution Unit:** All ALU’s

**Operation:**

Rt = Ra ^ Rb

**Exceptions:** none

### MUL - Multiply

**Description:**

Performs a signed multiply of two registers or a register and an immediate value and places the product in the target register.

**Instruction Format: R2, RI**

**Clock Cycles:** 20

**Execution Unit:** ALU

**Operation:**

Rt = Ra \* Rb

### MULU – Unsigned Multiply

**Description:**

Performs a unsigned multiply of two registers or a register and an immediate value and places the product in the target register.

**Instruction Format: R2, RI**

**Clock Cycles:** 20

**Execution Unit:** ALU

**Operation:**

Rt = Ra \* Rb

### OR – Bitwise ‘Or’

**Description:**

Bitwise inclusively or two registers or a register and an immediate value and place the result in the target register.

**Instruction Format: R2, RI**

**Clock Cycles:** 0.33

**Execution Units:** ALU

**Operation:**

Rt = Ra | Rb

Rt = Ra | #zero\_extend(imm)

**Exceptions:** none

### ORIS – Or Immediate Shifted

**Description:**

Or an immediate value to a target register. The immediate value is zero extended to sixty-four bits and shifted left by sixteen bits before use. This instruction may follow an OR # instruction to form a 38-bit immediate or. It may also be used to load a constant into a register.

**Instruction Format: RIS**

**Clock Cycles:** 0.33

**Execution Unit:** AllALU’s

**Operation:**

Rt = Rt | (Imm << 16)

**Exceptions**: none

### ORCM – Or with Compliment

**Description:**

Bitwise inclusively or register Ra and the compliment of register Rb and place the result in the target register. There is no immediate form for this instruction.

**Instruction Format: R2**

**Clock Cycles:** 0.33

**Execution Units:** All ALU’s

**Operation:**

Rt = Ra | ~Rb

**Exceptions:** none

### SHL – Shift Left

**Description:**

Shift register Ra left by Rb bits or an immediate value and place result into register Rt. A zero is shifted into the least significant bit.

**Instruction Format: R2, RSI**

**Clock Cycles:** 0.33

**Execution Units:** ALU

**Operation:**

Rt = Ra << Rb

**Exceptions:** none

### SHLP – Shift Left Pair

**Description:**

The shift left pair instruction treats a pair of registers as a 128-bit value and shifts it to the left by the value in a third register or an immediate value. The *upper* 64-bits of the result are then transferred to the target register. This instruction may be used to perform a left rotate operation by specifying the same register for each register of the pair.

**Instruction Format: SHP, SHPI**

**Clock Cycles:** 0.33

**Execution Units:** ALU

**Operation:**

Rt = Upper64({Ra,Rb} << Rc)

Rt = Upper64({Ra,Rb} << Imm)

**Exceptions:** none

### SHR – Shift Right

**Description:**

Shift register Ra right by Rb bits or an immediate value and place result in register Rt. Zeros are shifted into the most significant bits.

**Instruction Format: R2, RSI**

**Clock Cycles:** 0.33

**Execution Units:** ALU

**Operation:**

Rt = Ra >> Rb

**Exceptions:** none

### SHRP – Shift Right Pair

**Description:**

The shift right pair instruction treats a pair of registers as a 128-bit value and shifts it to the right by the value in a third register or an immediate value. The *lower* 64-bits of the result are then transferred to the target register. This instruction may be used to perform a right rotate operation by specifying the same register for each register of the pair.

**Instruction Format: SHP, SHPI**

**Clock Cycles:** 0.33

**Execution Units:** ALU

**Operation:**

Rt = Lower64({Rb,Ra} >> Rc)

Rt = Lower64({Rb,Ra} >> Imm)

**Exceptions:** none

### SUB - Subtract

**Description:**

This instruction subtracts one register from another and places the result into a third register. There is no immediate form for this instruction, use ADD # instead.

**Instruction Format: R2**

**Clock Cycles:** 0.33

**Execution Unit:** All ALU’s

**Operation:**

Rt = Ra - Rb

### SUBF – Subtract from Immediate

**Description:**

This instruction subtracts a register from an immediate value and places the result into a target register. There is no register form for this instruction, use SUB (swap operands) instead.

**Instruction Format: R2**

**Clock Cycles:** 0.33

**Execution Unit:** All ALU’s

**Operation:**

Rt = Imm - Ra

## Bit Field

### CLR – Bit-field Clear

**Description:**

This is an alternate mnemonic for the DEP instruction where the value deposited is zero. Sets the bits to zero in the target register located between the mask begin (mb) and mask end (me) bits.

**Instruction Format: BF3**

**Clock Cycles:** 0.33

**Execution Units:** ALU

**Exceptions:** none

### DEP – Deposit (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 or from a six-bit immediate constant. Note that the target register is used as a source operand.

**Instruction Format: BF3**

**Clock Cycles:** 0.33

**Execution Units:** ALU

**Exceptions:** none

### EXT – 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: BF3**

**Clock Cycles:** 0.33

**Execution Units:** ALU

**Exceptions:** none

### EXTU – 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: BF3**

**Clock Cycles:** 0.33

**Execution Units:** ALU

**Exceptions:** none

## Memory Operations

### LDB – Load Byte (8 bits)

**Description:**

An eight-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 OR the sum of register Ra and Rb. The memory address must be double word aligned. Setting the record bit in the instruction will store +1, 0, or -1 to predicate register #1 depending on the sign of the value loaded.

**Instruction Format: LD, LDX**

**Clock Cycles:** 1+ (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]

Rt = mem[Ra + Rb]

if (Record)

p1 = sign\_of(Rt)

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

### LDD – Load Double Word (64 bits)

**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 OR the sum of register Ra and Rb. Rb may be scaled by the size of the operand (eight). The memory address must be double word aligned. Setting the record bit in the instruction will store +1, 0, or -1 to predicate register #1 depending on the sign of the value loaded.

**Instruction Format: LD, LDX**

**Clock Cycles:** 1+ (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]

Rt = mem[Ra + Rb \* Scale] (scale = 1 or 8)

if (Record)

p1 = sign\_of(Rt)

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

### LDH – Load Half Word (16 bits)

**Description:**

A sign extended sixteen-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 OR the sum of register Ra and Rb. Rb may be scaled by the size of the operand (two). The memory address must be double word aligned. Setting the record bit in the instruction will store +1, 0, or -1 to predicate register #1 depending on the sign of the value loaded.

**Instruction Format: LD, LDX**

**Clock Cycles:** 1+ (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]

Rt = mem[Ra + Rb \* Scale] (scale = 1 or 2)

if (Record)

p1 = sign\_of(Rt)

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

### STD – Store Double Word (64-bits)

**Description:**

A sixty-four-bit value is stored to memory from the source register Rs. The memory address is the sum of the sign extended displacement and register Ra OR the sum of register Ra and register Rb. Register Rb may be scaled by the size of the operand (eight). The memory address must be double word aligned.

**Instruction Format: ST, STX**

**Clock Cycles:** 1+ (one memory access)

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

**Operation:**

memory[Ra+displacement] = Rs

memory[Ra + Rb \* Scale] = Rs (scale = 1 or 8)

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

## MOVI – Move Immediate

Description:

The immediate move instruction is unusual in that it occupies two slots of the bundle as shown below. The movi instruction may be placed only in the first two instruction slots.

Instruction Format:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 127 123 | 122 82 | 81 41 | 40 0 | |
| Control | Slot2 | Immediate63..23 | Immed22..3 | Other |

Clock cycles: 0.66 (two slots are occupied).