

# MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture

Document Number: MD00101 Revision 3.00 April 30, 2010

MIPS Technologies, Inc. 1225 Charleston Road Mountain View, CA 94043-1353



Copyright © 2004-2005, 2008, 2010 MIPS Technologies, Inc. All rights reserved.

Unpublished rights (if any) reserved under the copyright laws of the United States of America and other countries.

This document contains information that is proprietary to MIPS Technologies, Inc. ("MIPS Technologies"). Any copying, reproducing, modifying or use of this information (in whole or in part) that is not expressly permitted in writing by MIPS Technologies or an authorized third party is strictly prohibited. At a minimum, this information is protected under unfair competition and copyright laws. Violations thereof may result in criminal penalties and fines.

Any document provided in source format (i.e., in a modifiable form such as in FrameMaker or Microsoft Word format) is subject to use and distribution restrictions that are independent of and supplemental to any and all confidentiality restrictions. UNDER NO CIRCUMSTANCES MAY A DOCUMENT PROVIDED IN SOURCE FORMAT BE DISTRIBUTED TO A THIRD PARTY IN SOURCE FORMAT WITHOUT THE EXPRESS WRITTEN PERMISSION OF MIPS TECHNOLOGIES, INC.

MIPS Technologies reserves the right to change the information contained in this document to improve function, design or otherwise. MIPS Technologies does not assume any liability arising out of the application or use of this information, or of any error or omission in such information. Any warranties, whether express, statutory, implied or otherwise, including but not limited to the implied warranties of merchantability or fitness for a particular purpose, are excluded. Except as expressly provided in any written license agreement from MIPS Technologies or an authorized third party, the furnishing of this document does not give recipient any license to any intellectual property rights, including any patent rights, that cover the information in this document.

The information contained in this document shall not be exported, reexported, transferred, or released, directly or indirectly, in violation of the law of any country or international law, regulation, treaty, Executive Order, statute, amendments or supplements thereto. Should a conflict arise regarding the export, reexport, transfer, or release of the information contained in this document, the laws of the United States of America shall be the governing law.

The information contained in this document constitutes one or more of the following: commercial computer software, commercial computer software documentation or other commercial items. If the user of this information, or any related documentation of any kind, including related technical data or manuals, is an agency, department, or other entity of the United States government ("Government"), the use, duplication, reproduction, release, modification, disclosure, or transfer of this information, or any related documentation of any kind, is restricted in accordance with Federal Acquisition Regulation 12.212 for civilian agencies and Defense Federal Acquisition Regulation Supplement 227.7202 for military agencies. The use of this information by the Government is further restricted in accordance with the terms of the license agreement(s) and/or applicable contract terms and conditions covering this information from MIPS Technologies or an authorized third party.

MIPS I, MIPS II, MIPS III, MIPS IV, MIPS V, MIPS7, MIPS32, MIPS64, microMIPS32, microMIPS64, MIPS-3D, MIPS16, MIPS16e, MIPS-Based, MIPSsim, MIPSpro, MIPS Technologies logo, MIPS-VERIFIED, MIPS-VERIFIED logo, 4K, 4Kc, 4Km, 4Kp, 4KE, 4KEc, 4KEm, 4KEp, 4KS, 4KSc, 4KSd, M4K, M14K, 5K, 5Kc, 5Kf, 24K, 24Kc, 24Kef, 24Kef, 24Kef, 34K, 34Kc, 34Kf, 74K, 74Kc, 74Kf, 1004Kc, 1004Kf, R3000, R4000, R5000, ASMACRO, Atlas, "At the core of the user experience.", BusBridge, Bus Navigator, CLAM, CorExtend, CoreFPGA, CoreLV, EC, FPGA View, FS2, FS2 FIRST SILICON SOLUTIONS logo, FS2 NAVIGATOR, HyperDebug, HyperJTAG, JALGO, Logic Navigator, Malta, MDMX, MED, MGB, microMIPS, OCI, PDtrace, the Pipeline, Pro Series, SEAD, SEAD-2, SmartMIPS, SOC-it, System Navigator, and YAMON are trademarks or registered trademarks of MIPS Technologies, Inc. in the United States and other countries.

All other trademarks referred to herein are the property of their respective owners.

Template: nB1.02, Built with tags: 2B ARCH MIPS32

# **Table of Contents**

| Chapter 1: About This Book                                                           | 11       |
|--------------------------------------------------------------------------------------|----------|
| 1.1: Typographical Conventions                                                       | 11       |
| 1.1.1: Italic Text                                                                   | 11       |
| 1.1.2: Bold Text                                                                     | 12       |
| 1.1.3: Courier Text                                                                  | 12       |
| 1.2: UNPREDICTABLE and UNDEFINED                                                     | 12       |
| 1.2.1: UNPREDICTABLE                                                                 | 12       |
| 1.2.2: UNDEFINED                                                                     | 13       |
| 1 2 3' UNSTABLE                                                                      | 13       |
| 1.3: Special Symbols in Pseudocode Notation                                          | 13       |
| 1.4: For More Information                                                            | 16       |
| Chapter 2: Guide to the Instruction Set                                              | 17       |
| 2 1: Understanding the Instruction Fields                                            | 17       |
| 2.1.1: Instruction Fields                                                            | 10       |
| 2.1.2: Instruction Descriptive Name and Mnemonic                                     | 10       |
| 2.1.2. Instruction Descriptive Name and Whemonio                                     | 10       |
| 2.1.0.1 Ornat Field                                                                  | 13       |
| 2.1.4. Fulpose Field                                                                 | 20       |
| 2.1.5. Description Field                                                             | 20       |
| 2.1.0. Restrictions Field                                                            | 20<br>21 |
| 2.1.7. Operation Theld                                                               |          |
| 2.1.0. Exceptions Tield                                                              | 21<br>22 |
| 2.2: Operation Section Notation and Eulertions                                       | 22<br>22 |
| 2.2.1: Instruction Execution Ordering                                                | 22       |
| 2.2.2. Pseudocode Eurotions                                                          | 22       |
| 2.2.2. F Seddocode Functions                                                         | 22       |
| 2.3. Op and 1 differior Subleic Notation                                             | 31       |
|                                                                                      |          |
| Chapter 3: The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture | 33       |
| 3.1: Base Architecture Requirements                                                  | 33       |
| 3.2: Software Detection of the ASE                                                   | 33       |
| 3.3: Compliance and Subsetting                                                       | 33       |
| 3.4: Overview of the SmartMIPS ASE                                                   | 34       |
| 3.4.1: Support for Cryptographic Algorithms in the SmartMIPS ASE                     | 34       |
| 3.4.2: Code Density Optimization                                                     | 34       |
| 3.4.3: Other ISA Enhancements                                                        | 35       |
| 3.4.4: Privileged Resource Architecture Enhancements                                 | 36       |
| 3.5: Instruction Bit Encoding                                                        | 37       |
| Chapter 4: The SmartMIPS® Cryptographic Feature Set                                  | 41       |
| 4.1: The Special Register ACX                                                        | 41       |
| 4.2: Change to MADDU Semantics                                                       | 42       |
| 4.3: Change to MULTU Semantics                                                       | 42       |
| 4.4: Possible Changes to other Multiply/Accumulate Semantics                         | 42       |
| 4.5: New Instructions                                                                | 42       |

| 4.5.2: MTLHX.       42         4.5.3: MADDP       42         4.5.4: MULTP.       42         4.5.6: PPERM.       43         4.5.6: ROTR.       43         4.5.7: ROTRV.       43         Chapter 5: Other ISA Elements of the SmartMIPS® ASE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 4.5.1: MFLHXU                                                                       |    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|----|
| 4.5.3: MADDP       42         4.5.4: MULTP       42         4.5.5: PPERM       43         4.5.6: ROTR       43         4.5.6: ROTR       43         4.5.7: ROTRV       43         Chapter 5: Other ISA Elements of the SmartMIPS® ASE       45         5.1: LWXS Instruction       45         Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture       57         6.1: Introduction       57         6.2: Overview       57         6.3: Compliance       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor       58         6.6: Virtual Memory       58         6.6: Copensel Exception       58         6.6: Virtual Memory       58         6.6: TLB Bradie Exception       58         6.6: TLB Invalid Exception       62         6.6: Copensel Exception       62         6.6: Copensel Exception       62         6.6: TLB Invalid Exception       62         6.6: TLB Invalid Exception       62         6.6: TLB Invalid Exception       62         6: 7. 1: PageMask Register (CPO Register 5, Select 0)       62         6: 7.2: PageGrain Register                                                                                                                                                                         | 4.5.2: MTLHX                                                                        |    |
| 4.5.4: MULTP.       42         4.5.5: PPERM       43         4.5.6: ROTR.       43         4.5.7: ROTRV.       43         Chapter 5: Other ISA Elements of the SmartMIPS® ASE.       45         5.1: LWXS Instruction.       45         Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture.       57         6.1: Introduction.       57         6.3: Compliance.       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor.       58         6.6: Ital Koopper Summary       58         6.6: Virtual Memory.       58         6.6: Virtual Memory.       58         6.6: TLB Based Virtual Address Translation.       68         6.6: TLB Based Virtual Address Translation.       68         6.6: TLB Invalid Exception       61         6.6: TLB Invalid Exception       61         6.6: TLB Invalid Exception       62         6: 7. ProgeoFain Register (CPO Register 5, Select 0)       62         6: 7. 4: Dregister (CPO Register 10, Select 0.       66         6: 7. 4: Dregister (CPO Register 10, Select 0.       66         6: 7. 4: Configuration Register (CPO Register 16, Select 3)       66         6: 7. 4: Configu                                                                                                   | 4.5.3: MADDP                                                                        | 42 |
| 4.5.5: PPERM       43         4.5.6: ROTR       43         4.5.7: ROTRV       43         Chapter 5: Other ISA Elements of the SmartMIPS® ASE       45         5.1: LWXS Instruction       45         Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture       57         6.1: Introduction       57         6.2: Overview       57         6.3: Compliance       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor       58         6.5: The SmartMIPS system Coprocessor       58         6.6: Virtual Memory       58         6.6: TLB-Based Virtual Address Translation       58         6.6: Zinze Relit Exception Processing       61         6.6: A. TLB Relit Exception       61         6.6: A. TLB Nualid Exception       62         6.7: CPO Register S       Select 0)       62         6.7. PageGrain Register (CPO Register 5, Select 0)       62         6.7. PageGrain Register (CPO Register 16, Select 3)       66         6.7. PageGrain Register (CPO Register 16, Select 3)       66         6.7. PageGrain Register (CPO Register 16, Select 3)       66         6.7. A. Configuration Register 3 (CPO Register 16, Select 3)                                                                                     | 4.5.4: MULTP                                                                        | 42 |
| 4.5.6; ROTR.       43         4.5.7; ROTRV.       43         Chapter 5: Other ISA Elements of the SmartMIPS® ASE.       45         5.1: LWXS Instruction.       45         Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture.       57         6.1: Introduction.       57         6.2: Overview.       57         6.3: Compliance       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: Coeneral Exception Processing.       61         6.6: General Exception Processing.       61         6.6: TLB Modified Exception       61         6.6: TLB Invalid Exception       62         6.7: PageMask Register (CP0 Register 5, Select 0)       62         6.7.3: EntryHi Register (CP0 Register 16, Select 3)       66         6.6       67.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         6.6       67.4: Configuration Register 3 (CP0 Register 16, Select 3)       67         6.6.7.1: PageMask Register (CP0 Register 16, Select 3)       66         6.7.2: PageGrain Register 3                                                                                  | 4.5.5 <sup>.</sup> PPERM                                                            | 43 |
| 4.5.7: ROTRV.       43         Chapter 5: Other ISA Elements of the SmartMIPS® ASE.       45         5.1: LWXS Instruction.       45         Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture.       57         6.1: Introduction       57         6.2: Overview.       57         6.3: Compliance.       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor.       58         6.6: Virtual Memory.       58         6.6: Virtual Memory.       58         6.6: Virtual Memory.       58         6.6: TLB Refile Exception       61         6.6.3: TLB Refile Exception       61         6.6.4: TLB Invalid Exception       61         6.6.5: TLB Modified Exception       62         6.7: CPO Register S.       62         6.7: CPO Register Signer (CPO Register 5, Select 1)       64         6.7: A: DageMask Register (CPO Register 5, Select 1)       64         6.7: A: Configuration Register 3 (CPO Register 16, Select 3)       66         6.6       67.4: Configuration Register 3 (CPO Register 16, Select 3)       67         A.1: Introduction       67       A1: Introduction       67         A.2: Overview                                                                                                           | 4.5.6 <sup>.</sup> ROTR                                                             | 43 |
| Chapter 5: Other ISA Elements of the SmartMIPS® ASE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 4.5.7 ROTRV                                                                         | 43 |
| Chapter 5: Other ISA Elements of the SmartMIPS® ASE       45         5.1: LWXS Instruction       45         Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture       57         6.1: Introduction       57         6.2: Overview       57         6.3: Compliance       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor       58         6.6: NTLB-Based Virtual Address Translation       58         6.6: 1: TLB-Based Virtual Address Translation       58         6.6: 1: TLB Memory       58         6.6: 1: TLB Modified Exception       61         6.6: 1: TLB Modified Exception       61         6.6: 1: TLB Modified Exception       62         6: 7: CPO Register S       69         6: 7: 1: PageGrain Register (CPO Register 5, Select 0)       62         6: 7: 4: PageGrain Register (CPO Register 10, Select 0)       62         6: 7: 4: Configuration Register (CPO Register 16, Select 3)       66         6: 7: 4: Configuration Register (CPO Register 16, Select 3)       67         A: Interaction between the SmartMIPS® Release 2 of the MIPS32 Architecture       67         A: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       67 <td< td=""><td></td><td></td></td<> |                                                                                     |    |
| 5.1: LWXS Instruction       45         Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture       57         6.1: Introduction       57         6.2: Overview       57         6.3: Compliance       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS system Coprocessor       58         6.5: The SmartMIPS ased Virtual Address Translation       58         6.6: Virtual Memory       58         6.6: Virtual Xeoption Processing       61         6.6.3: TLB Refill Exception       61         6.6.4: TLB Invalid Exception       61         6.6.5: TLB Modified Exception       62         6.7: CPR Registers       62         6.7: LP Register (CPO Register 5, Select 1)       64         6.7.2: PageGrain Register (CPO Register 5, Select 1)       64         6.7.4: Configuration Register (CPO Register 16, Select 3)       66         6.7.4: Configuration Register 3       67         6.7.4: Configuration Register 3       67         7.7: Progenase       67         7.7: Progenase       66         6.7.4: Configuration Register 10, Select 3)       66         6.7.4: Configuration Register 3       69         6.5: The SmartMIPS Sys                                                                                                   | Chapter 5: Other ISA Elements of the SmartMIPS® ASE                                 | 45 |
| Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture.       57         6.1: Introduction.       57         6.2: Overview.       57         6.3: Compliance.       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor.       58         6.5: The SmartMIPS System Coprocessor.       58         6.6: Vittual Memory.       58         6.6: Vittual Memory.       58         6.6: S. TLB Based Virtual Address Translation.       58         6.6: S. TLB Roeffiel Exception Processing.       61         6.6: S. TLB Modified Exception.       61         6.6: S. TLB Modified Exception.       62         6.7: CP0 Registers       62         6.7.1: PageMask Register (CP0 Register 5, Select 0).       62         6.7.2: PageGrain Register (CP0 Register 10, Select 0       64         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3).       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3).       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68 <td>5 1 · I WXS Instruction</td> <td>45</td>                                | 5 1 · I WXS Instruction                                                             | 45 |
| Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture       57         6.1: Introduction       57         6.2: Overview       57         6.3: Compliance       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor       58         6.5: The SmartMIPS Bystem Coprocessor       58         6.6: 1: TLB-Based Virtual Address Translation       58         6.6: 2: General Exception Processing       61         6.6: 3: TLB Modified Exception       61         6.6: 4: TLB Invalid Exception       62         6.7: CP0 Registers       62         6.7.1: PageMask Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 5, Select 1)       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0       66         6.7.4: Configuration Register 3 (CP0 Register 15, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68                                                |                                                                                     |    |
| 6.1: Introduction       57         6.2: Overview       57         6.3: Compliance       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor       58         6.6: I. CPO Register Summary       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: TLB -Based Virtual Address Translation       58         6.6: 2: General Exception Processing       61         6.6: 3: TLB Refill Exception       61         6.6: 4: TLB Invalid Exception       61         6.6: 5: TLB Modified Exception       62         6: 7.1: PageMask Register (CP0 Register 5, Select 0)       62         6: 7.1: PageMask Register (CP0 Register 10, Select 0       62         6: 7.2: PageGrain Register (CP0 Register 10, Select 3)       66         6: 7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         A: Introduction       67         A: Compliance       67         A: Intraction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A: S: The SmartMIPS System Coprocessor       68         A: S: The SmartMIPS System Coprocessor       68         A: S: The SmartMIPS System Coprocessor                                                                            | Chapter 6: The SmartMIPS® Release 3 Privileged Resource Architecture                | 57 |
| 6.2: Overview.       57         6.3: Compliance.       57         6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor.       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: Xirtual Memory       58         6.6: Airtual Memory       58         6.6: Airtual Memory       61         6: 6: 7.1: PageMask Register (CP0 Register 5, Select 0)       62         6: 7.2: PageGrain Register (CP0 Register 10, Select 0)       62         6: 7.4: Configuration Register 3 (CP0 Register 10, Select 1)       64         6: 7.4: Configuration Register 3 (CP0 Register 10, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A: S: The SmartMIPS                                                                                                   | 6.1: Introduction                                                                   | 57 |
| 6.3: Compliance       57         6.4: Interaction between the SmarttMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor.       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: C. General Exception Processing       61         6.6.3: TLB Refill Exception       61         6.6.4: TL Binvalid Exception       62         6.7: CPO Registers       62         6.7. LP BageGrain Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 5, Select 1)       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.5: The SmartMIPS System Coprocessor       68                                                                                                          | 6.2. Overview                                                                       |    |
| 6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       58         6.5: The SmartMIPS System Coprocessor.       58         6.5.1: CP0 Register Summary       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: Si The Based Virtual Address Translation       58         6.6: Ceneral Exception Processing       61         6.6: TLB Modified Exception       61         6.6: TLB Modified Exception       62         6.7: CP0 Registers       62         6.7.1: PageMask Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 5, Select 1)       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS@ Release 2 Privileged Resource Architecture       67         A1: Introduction       67         A2: Overview       67         A3: Compliance       67         A4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.6: Virtual Memory       69         A.6: TLB Refill Exception       72         A.6: TLB Refill Exception </td <td>6.3: Compliance</td> <td>57</td>                        | 6.3: Compliance                                                                     | 57 |
| 6.5: The SmartNIPS System Coprocessor       58         6.5: The SmartNIPS System Coprocessing       58         6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6: TLB-Based Virtual Address Translation       58         6.6.1: TLB-Based Virtual Address Translation       68         6.6.2: General Exception Processing       61         6.6.3: TLB Refill Exception       61         6.6.4: TLB Invalid Exception       61         6.6.5: TLB Modified Exception       62         6.7.1: PageMask Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 10, Select 0       62         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor                                                                           | 6.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture | 58 |
| 6.5.1 CPO Register Summary       58         6.6.2 General Exception Processing       61         6.6.3 TLB Bedill Exception       61         6.6.4 TLB Invalid Exception       61         6.6.5.1 CPO Registers       62         6.7 CPO Registers       62         6.7.1 PageMask Register (CPO Register 5, Select 0)       62         6.7.2 PageGrain Register (CPO Register 10, Select 0)       62         6.7.3 EntryHi Register (CPO Register 10, Select 0)       64         6.7.4 Configuration Register 3 (CPO Register 16, Select 3)       66         6.7.4 Configuration Register 3 (CPO Register 16, Select 3)       66         6.7.4 Configuration Register 3 (CPO Register 16, Select 3)       66         A.1 Introduction       67         A.2 Overview       67         A.3 Compliance       67         A.4. Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5.1 CPO Register Summary       68         A.5.1 CPO Register Summary       68         A.6.1 TLB-Based Virtual Address Translation       69         A.6.2 General Exception Processing       72         A.6.3 TLB Refill Exception       72         A.6.4 TLB Invalid Exception       72         A.6.5 TLB Modified Exception       72                                                                                            | 6.5: The SmartMIPS System Concressor                                                | 58 |
| 6.6: Virtual Memory       58         6.6: Virtual Memory       58         6.6.1: TLB-Based Virtual Address Translation       58         6.6.2: General Exception Processing       61         16.6.3: TLB Refill Exception       61         6.6.4: TLB Invalid Exception       62         6.7: CP0 Registers       62         6.7.1: PageGrain Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 10, Select 0)       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0)       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.5: The SmartMIPS @ Release 2 Privileged Resource Architecture       67         A.5: The SmartMIPS @ Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68         A.6: Virtual Memory       69         A.6.1: TLB-Based Virtual Address Translation       69         A.6.2: General Exception Processing       72         A.6.3: TLB Refill Exception                                                                          | 6.5.1: CPO Register Summary                                                         | 58 |
| 6.6.1: TLB-Based Virtual Address Translation       58         6.6.2: General Exception Processing       61         6.6.3: TLB Refill Exception       61         6.6.4: TB Invalid Exception       61         6.6.5: TLB Modified Exception       62         6.7: CP0 Registers       62         6.7.1: PageGrain Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 5, Select 1)       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS@ Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68         A.6: Virtual Memory       69         A.6: Virtual Memory       69         A.6: Virtual Medress Translation       72         A.6: TLB-Based Virtual Address Translation       72         A.6: TLB Invalid Exception       72         A.6: TLB Invalid Exception       72 <td>6 6: Virtual Memory</td> <td></td>                                     | 6 6: Virtual Memory                                                                 |    |
| 6.6.2: General Exception Processing.       61         6.6.3: TLB Refill Exception       61         6.6.4: TLB Invalid Exception       61         6.6.5: TLB Modified Exception       62         6.7: CP0 Registers       62         6.7: 1: PageMask Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 5, Select 1)       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0)       66         6.7.4: Configuration Register 3 (CP0 Register 10, Select 0)       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: TCP0 Register Summary       68         A.6: Virtual Memory       69         A.6: Virtual Address Translation       69         A.6: Z General Exception       72         A.6: 3: TLB Modified Exception       72         A.6: 3: TLB Modified Exception       72         A.6: 4: TLB Invalid Exception       72         A.7: CP0 Register Summary       73                                                                                 | 6.6.1: TI B-Based Virtual Address Translation                                       | 58 |
| 0.02.2       Otheral Exception       61         6.6.3       TLB Refill Exception       61         6.6.4       TLB Invalid Exception       62         6.7       CPO Registers       62         6.7.1       PageGrain Register (CPO Register 5, Select 0)       62         6.7.2       PageGrain Register (CPO Register 10, Select 0)       62         6.7.3       EntryHi Register (CPO Register 10, Select 0)       66         6.7.4       Configuration Register 3 (CPO Register 16, Select 3)       66         6.7.4       Configuration Register 3 (CPO Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1       Introduction       67         A.2       Overview       67         A.3       Compliance       67         A.5       TCPO Register Summary       68         A.5.1       CPO Register Summary       68         A.5.1       CPO Register Summary       69         A.6.2       General Exception Processing       72         A.6.3       TLB Based Virtual Address Translation       72         A.6.4       TLB Invalid Exception       72         A.6.3       TLB Baddified Exception       72      <                                                                                                                                                         | 6.6.2: General Excention Processing                                                 |    |
| 0.63.5       TLB Invalid Exception       61         6.6.4       TLB Modified Exception       62         6.7       CPO Registers       62         6.7.1       PageMask Register (CP0 Register 5, Select 0)       62         6.7.2       PageGrain Register (CP0 Register 5, Select 1)       64         6.7.3       EntryHi Register (CP0 Register 10, Select 0       66         6.7.4       Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1       Introduction       67         A.2       Overview       67         A.3       Compliance       67         A.4       Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5       The SmartMIPS System Coprocessor       68         A.5       17 CP0 Register Summary       68         A.6       Virtual Memory       69         A.6.1       TLB-Based Virtual Address Translation       69         A.6.2       General Exception Processing       72         A.6.3       TLB Refill Exception       72         A.6.4       TLB Invalid Exception       73         A.7.1       EntryLo1 (CP0 Registers 2 and 3,                                                                                                                                  | 6.6.3: TI B Refill Exception                                                        | 01 |
| 66.5: TLB Modified Exception       62         6.7: CP0 Registers       62         6.7: CP0 Registers       62         6.7: 2: PageGrain Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 5, Select 1)       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0)       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68         A.6: Virtual Memory       69         A.6: Virtual Memory       69         A.6: TLB Register Summary       72         A.6: TLB Invalid Exception       72         A.6: TLB Invalid Exception       72         A.6: TLB Modified Exception       73         A.7: CPO Registers       73         A.7: CPO Registers       73         A.7: CPO Registers       73         A.7: Context Register (CPO Register 4, Select 0) </td <td>6.6.4: TLB Invalid Exception</td> <td>01</td>                                              | 6.6.4: TLB Invalid Exception                                                        | 01 |
| 6.7: CP0 Registers       62         6.7.1: PageMask Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 5, Select 1)       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0)       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.5.1: CP0 Register Summary       68         A.6: Virtual Memory       69         A.6.1: TLB-Based Virtual Address Translation       69         A.6.2: General Exception Processing       72         A.6.3: TLB Modified Exception       72         A.6.4: TLB Invalid Exception       73         A.7: CP0 Registers       73         A.7: CP0 Register (CP0 Register 5, Select 0)       73         A.7: CP0 Register (CP0 Register 4, Select 1)       74         A.7: CP0 Register (CP0 Register 5, Select 1)       74         A.7: Context Register (CP0 Register 5, Select 0)       73         A.7:                                                                | 6.6.5: TLB Modified Exception                                                       | 62 |
| 6.7.1: PageMask Register (CP0 Register 5, Select 0)       62         6.7.2: PageGrain Register (CP0 Register 5, Select 1)       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0)       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68         A.5: T. CP0 Register Summary       69         A.6: Virtual Memory       69         A.6: Virtual Memory       69         A.6: Z General Exception Processing       72         A.6.3: TLB Refill Exception       72         A.6.4: TLB Invalid Exception       72         A.6.5: TLB Modified Exception       73         A.7: CP0 Registers       73         A.7: CP0 Register (CP0 Register 4, Select 0)       73         A.7: Context Register (CP0 Register 4, Select 0)       75         A.7: PageMask Register (CP0 Register 4, Select 1)       76         A.7: PageGrain Register (CP0 Register 5, Select 1)       76         A.7: PageGrain Register (CP0 Register 5, Select 1) <td>6.7. CP0 Registers</td> <td>62</td>                            | 6.7. CP0 Registers                                                                  | 62 |
| 6.7.2: PageGrain Register (CP0 Register 5, Select 1).       64         6.7.3: EntryHi Register (CP0 Register 10, Select 0).       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3).       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68         A.6: Virtual Memory       69         A.6: Virtual Memory       69         A.6.2: General Exception Processing       72         A.6.3: TLB Refill Exception       72         A.6.4: TLB Invalid Exception       72         A.6.4: TLB Invalid Exception       73         A.7: CPO Register S       73         A.7: CPO Register (CP0 Register 4, Select 0)       73         A.7.2: Context Register (CP0 Register 4, Select 1)       76         A.7.4: PageMask Register (CP0 Register 5, Select 1)       76         A.7.4: PageGrain Register (CP0 Register 5, Select 1)       77         A.7.5: EntryHi Register (CP0 Register 5, Select 1)       77                                                                | 6.7.1: PageMask Register (CP0 Register 5, Select 0)                                 | 62 |
| 6.7.3: EntryHi Register (CP0 Register 10, Select 0)       66         6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68         A.6: Virtual Memory       69         A.6: Virtual Memory       69         A.6: Z General Exception Processing       72         A.6: TLB-Based Virtual Address Translation       69         A.6: X TLB Refill Exception       72         A.6: X TLB Refill Exception       72         A.6: X TLB Refill Exception       72         A.6: X TLB Invalid Exception       72         A.6: X TLB Modified Exception       73         A.7: Context Register (CP0 Register 4, Select 0)       73         A.7: Context Register (CP0 Register 4, Select 1)       76         A.7: Context Register (CP0 Register 5, Select 1)       76         A.7: PageGrain Register (CP0 Register 5, Select 1)       77         A.7: Configuration Re                                                                | 6.7.2. PageGrain Register (CP0 Register 5, Select 1)                                |    |
| 6.7.4: Configuration Register 3 (CP0 Register 16, Select 3).       66         Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68         A.6: Virtual Memory       69         A.6: Virtual Memory       69         A.6: General Exception Processing       72         A.6: TLB hased Virtual Address Translation       69         A.6: TLB Refill Exception       72         A.6: TLB Indiffed Exception       72         A.6: TLB Indiffed Exception       72         A.6: TLB Modified Exception       73         A.7: CP0 Registers       73         A.7: Context Register (CP0 Register 4, Select 0)       73         A.7: Context Register (CP0 Register 5, Select 1)       76         A.7: PageGrain Register (CP0 Register 5, Select 1)       77         A.7: EntryHi Register (CP0 Register 10, Select 3)       81                                                                                                                                                                                 | 6.7.3: EntryHi Register (CP0 Register 10, Select 0                                  |    |
| Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture       67         A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68         A.5: The SmartMIPS System Coprocessor       68         A.6: Virtual Memory       69         A.6: Virtual Memory       69         A.6: Virtual Memory       69         A.6: Z General Exception Processing       72         A.6: TLB hased Virtual Address Translation       69         A.6: TLB Refill Exception       72         A.6: TLB Nulid Exception       72         A.6: TLB Invalid Exception       72         A.6: TLB Modified Exception       73         A.7: CPO Registers       73         A.7: Context Register (CP0 Register 4, Select 0)       75         A.7: S Context Register (CP0 Register 4, Select 1)       76         A.7: Context Register (CP0 Register 5, Select 1)       76         A.7: PageMask Register (CP0 Register 16, Select 0)       77         A.7: EntryHi Register (CP0 Register 16, Select 0)       77                                                                                                 | 6.7.4: Configuration Register 3 (CP0 Register 16, Select 3)                         |    |
| Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture67A.1: Introduction67A.2: Overview67A.3: Compliance67A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture68A.5: The SmartMIPS System Coprocessor68A.5: I CP0 Register Summary68A.6: Virtual Memory69A.6.1: TLB-Based Virtual Address Translation69A.6.2: General Exception Processing72A.6.3: TLB Refill Exception72A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.71: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)71A.7.6: EntryHi Register (CP0 Register 10, Select 0)71A.7.6: EntryHi Register (CP0 Register 10, Select 0)71A.7.6: EntryHi Register (CP0 Register 10, Select 0)71A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                        |                                                                                     |    |
| A.1: Introduction       67         A.2: Overview       67         A.3: Compliance       67         A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture       68         A.5: The SmartMIPS System Coprocessor       68         A.5: I CP0 Register Summary       68         A.6: Virtual Memory       69         A.6: Virtual Memory       69         A.6: Ceneral Exception Processing       72         A.6: TLB-Based Virtual Address Translation       69         A.6: Strub Refill Exception       72         A.6: TLB Refill Exception       72         A.6: TLB Invalid Exception       72         A.6: TLB Invalid Exception       72         A.6: TLB Modified Exception       73         A.7: CP0 Registers       73         A.7: CP0 Register (CP0 Register 2 and 3, Select 0)       73         A.7: Context Register (CP0 Register 4, Select 1)       76         A.7: Context Register (CP0 Register 4, Select 1)       76         A.7: PageMask Register (CP0 Register 5, Select 1)       77         A.7: PageGrain Register (CP0 Register 5, Select 1)       79         A.7: PageGrain Register (CP0 Register 10, Select 0)       71         A.7: Configuration Register 10, Select 0       81         A.7: C                                                                                                   | Appendix A: The SmartMIPS® Release 2 Privileged Resource Architecture               |    |
| A.2: Overview67A.3: Compliance67A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture68A.5: The SmartMIPS System Coprocessor68A.5: The SmartMIPS System Coprocessor68A.5.1: CP0 Register Summary68A.6: Virtual Memory69A.6.1: TLB-Based Virtual Address Translation69A.6.2: General Exception Processing72A.6.3: TLB Refill Exception72A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.7: CP0 Registers73A.7: CP0 Registers73A.7: CP0 Register (CP0 Register 4, Select 0)75A.7: Context Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 1)79A.7.5: PageGrain Register (CP0 Register 5, Select 0)77A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | A.1: Introduction                                                                   |    |
| A.3: Compliance67A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture68A.5: The SmartMIPS System Coprocessor68A.5.1: CP0 Register Summary68A.6: Virtual Memory69A.6.1: TLB-Based Virtual Address Translation69A.6.2: General Exception Processing72A.6.3: TLB Refill Exception72A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.7.1: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: Context Config Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 1)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)71A.7.6: EntryHi Register (CP0 Register 10, Select 0)71A.7.6: EntryHi Register (CP0 Register 10, Select 0)71A.7.7: Configuration Register 3 (CP0 Register 10, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                        | A.2: Overview                                                                       |    |
| A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture68A.5: The SmartMIPS System Coprocessor68A.5: 1: CP0 Register Summary68A.6: Virtual Memory69A.6.1: TLB-Based Virtual Address Translation69A.6.2: General Exception Processing72A.6.3: TLB Refill Exception72A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.7.1: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | A.3: Compliance                                                                     |    |
| A.5: The SmartMIPS System Coprocessor68A.5.1: CP0 Register Summary69A.6: Virtual Memory69A.6.1: TLB-Based Virtual Address Translation69A.6.2: General Exception Processing72A.6.3: TLB Refill Exception72A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.7.1: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: ContextConfig Register (CP0 Register 5, Select 0)77A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | A.4: Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture |    |
| A.5.1: CP0 Register Summary68A.6: Virtual Memory69A.6.1: TLB-Based Virtual Address Translation69A.6.2: General Exception Processing72A.6.3: TLB Refill Exception72A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.7.1: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: ContextConfig Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | A.5: The SmartMIPS System Coprocessor                                               |    |
| A.6: Virtual Memory       69         A.6.1: TLB-Based Virtual Address Translation       69         A.6.2: General Exception Processing       72         A.6.3: TLB Refill Exception       72         A.6.4: TLB Invalid Exception       72         A.6.5: TLB Modified Exception       72         A.6.5: TLB Modified Exception       73         A.7: CP0 Registers       73         A.7.1: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)       73         A.7.2: Context Register (CP0 Register 4, Select 0)       75         A.7.3: ContextConfig Register (CP0 Register 5, Select 1)       76         A.7.4: PageMask Register (CP0 Register 5, Select 1)       77         A.7.5: PageGrain Register (CP0 Register 5, Select 1)       79         A.7.6: EntryHi Register (CP0 Register 10, Select 0       81         A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)       81                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A.5.1: CP0 Register Summary                                                         |    |
| A.6.1: TLB-Based Virtual Address Translation.69A.6.2: General Exception Processing72A.6.3: TLB Refill Exception72A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.7.1: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: ContextConfig Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 1)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | A.6: Virtual Memory                                                                 |    |
| A.6.2: General Exception Processing72A.6.3: TLB Refill Exception72A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.71: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: ContextConfig Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | A.6.1: TLB-Based Virtual Address Translation                                        | 69 |
| A.6.3: TLB Refill Exception72A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.7: LentryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.1: EntryLo0, EntryLo1 (CP0 Register 4, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: ContextConfig Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | A.6.2: General Exception Processing                                                 | 72 |
| A.6.4: TLB Invalid Exception72A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.7: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: ContextConfig Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | A.6.3: TLB Refill Exception                                                         | 72 |
| A.6.5: TLB Modified Exception73A.7: CP0 Registers73A.7: I: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: ContextConfig Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | A.6.4: TLB Invalid Exception                                                        | 72 |
| A.7: CP0 Registers       73         A.7.1: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)       73         A.7.2: Context Register (CP0 Register 4, Select 0)       75         A.7.3: ContextConfig Register (CP0 Register 4, Select 1)       76         A.7.4: PageMask Register (CP0 Register 5, Select 0)       77         A.7.5: PageGrain Register (CP0 Register 5, Select 1)       79         A.7.6: EntryHi Register (CP0 Register 10, Select 0)       81         A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)       81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A.6.5: TLB Modified Exception                                                       | 73 |
| A.7.1: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)73A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: ContextConfig Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | A.7: CP0 Registers                                                                  | 73 |
| A.7.2: Context Register (CP0 Register 4, Select 0)75A.7.3: ContextConfig Register (CP0 Register 4, Select 1)76A.7.4: PageMask Register (CP0 Register 5, Select 0)77A.7.5: PageGrain Register (CP0 Register 5, Select 1)79A.7.6: EntryHi Register (CP0 Register 10, Select 0)81A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | A.7.1: EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)                         | 73 |
| A.7.3: ContextConfig Register (CP0 Register 4, Select 1)       76         A.7.4: PageMask Register (CP0 Register 5, Select 0)       77         A.7.5: PageGrain Register (CP0 Register 5, Select 1)       79         A.7.6: EntryHi Register (CP0 Register 10, Select 0)       81         A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)       81                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | A.7.2: Context Register (CP0 Register 4, Select 0)                                  | 75 |
| A.7.4: PageMask Register (CP0 Register 5, Select 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A.7.3: ContextConfig Register (CP0 Register 4, Select 1)                            |    |
| A.7.5: PageGrain Register (CP0 Register 5, Select 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | A.7.4: PageMask Register (CP0 Register 5, Select 0)                                 | 77 |
| A.7.6: EntryHi Register (CP0 Register 10, Select 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | A.7.5: PageGrain Register (CP0 Register 5, Select 1)                                | 79 |
| A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | A.7.6: EntryHi Register (CP0 Register 10, Select 0                                  | 81 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | A.7.7: Configuration Register 3 (CP0 Register 16, Select 3)                         | 81 |

| Appendix B: Revision History |  |
|------------------------------|--|
|------------------------------|--|

# **List of Figures**

| Figure 2.1: Example of Instruction Description                      | . 18 |
|---------------------------------------------------------------------|------|
| Figure 2.2: Example of Instruction Fields                           | . 19 |
| Figure 2.3: Example of Instruction Descriptive Name and Mnemonic    | 19   |
| Figure 2.4: Example of Instruction Format                           | 19   |
| Figure 2.5: Example of Instruction Purpose                          | 20   |
| Figure 2.6: Example of Instruction Description                      | 20   |
| Figure 2.7: Example of Instruction Restrictions                     | 21   |
| Figure 2.8: Example of Instruction Operation                        | 21   |
| Figure 2.9: Example of Instruction Exception                        | 21   |
| Figure 2.10: Example of Instruction Programming Notes               | 22   |
| Figure 2.11: COP_LW Pseudocode Function                             | 23   |
| Figure 2.12: COP_LD Pseudocode Function                             | 23   |
| Figure 2.13: COP_SW Pseudocode Function                             | 23   |
| Figure 2.14: COP_SD Pseudocode Function                             | 24   |
| Figure 2.15: CoprocessorOperation Pseudocode Function               | 24   |
| Figure 2.16: AddressTranslation Pseudocode Function                 | 24   |
| Figure 2.17: LoadMemory Pseudocode Function                         | 25   |
| Figure 2.18: StoreMemory Pseudocode Function                        | 25   |
| Figure 2.19: Prefetch Pseudocode Function                           | 26   |
| Figure 2.20: SyncOperation Pseudocode Function                      | 27   |
| Figure 2.21: ValueFPR Pseudocode Function                           | 27   |
| Figure 2.22: StoreFPR Pseudocode Function                           | 28   |
| Figure 2.23: CheckFPException Pseudocode Function                   | 29   |
| Figure 2.24: FPConditionCode Pseudocode Function                    | 29   |
| Figure 2.25: SetFPConditionCode Pseudocode Function                 | 29   |
| Figure 2.26: SignalException Pseudocode Function                    | 30   |
| Figure 2.27: SignalDebugBreakpointException Pseudocode Function     | 30   |
| Figure 2.28: SignalDebugModeBreakpointException Pseudocode Function | 30   |
| Figure 2.29: NullifyCurrentInstruction PseudoCode Function          | 31   |
| Figure 2.30: JumpDelaySlot Pseudocode Function                      | 31   |
| Figure 2.31: PolyMult Pseudocode Function                           | 31   |
| Figure 6.1: SmartMIPS PageMask Register Format                      | 62   |
| Figure 6.2: SmartMIPS PageGrain Register Format                     | 64   |
| Figure 6.3: SmartMIPS EntryHi Register Format                       | 66   |
| Figure A.1: Contents of a TLB Entry                                 | 69   |
| Figure A.2: SmartMIPS EntryLo0, EntryLo1 Register Format            | 74   |
| Figure A.3: SmartMIPS Context Register Format                       | 76   |
| Figure A.4: SmartMIPS ContextConfig Register Format                 | 77   |
| Figure A.5: SmartMIPS PageMask Register Format                      | 78   |
| Figure A.6: SmartMIPS PageGrain Register Format                     | 79   |
| Figure A.7: SmartMIPS EntryHi Register Format                       | 81   |

# **List of Tables**

| Table 1.1: Symbols Used in Instruction Operation Statements                     | 13 |
|---------------------------------------------------------------------------------|----|
| Table 2.1: AccessLength Specifications for Loads/Stores                         |    |
| Table 3.1: Symbols Used in the Instruction Encoding Tables                      |    |
| Table 3.2: SmartMIPS ASE Encoding of the Opcode Field                           |    |
| Table 3.3: SmartMIPS ASE SPECIAL Opcode Encoding of Function Field              |    |
| Table 3.4: SmartMIPS ASE SPECIAL2 Encoding of Function Field                    |    |
| Table 3.5: SmartMIPS ASE SRL Encoding of Shift/Rotate                           |    |
| Table 3.6: SmartMIPS ASE SRLV Encoding of Shift/Rotate                          |    |
| Table 3.7: SmartMIPS ASE MFLO Encoding of MFLO/MFLHXU                           |    |
| Table 3.8: SmartMIPS ASE MTLO Encoding of MTLO/MTLHX                            |    |
| Table 3.9: SmartMIPS ASE MULTU Encoding of MULTU/MULTP                          |    |
| Table 3.10: SmartMIPS ASE MADDU Encoding of MADDU/MADDP/PPERM                   |    |
| Table 3.11: SmartMIPS ASE LXS Encoding of LWXS                                  |    |
| Table 6.1: SmartMIPS Changes to Coprocessor 0 Registers in Numerical Order      | 58 |
| Table 6.2: Physical Address Generation                                          | 60 |
| Table 6.3: TLB Refill Exception State Saved in Addition to the Cause Register   | 61 |
| Table 6.4: TLB Invalid Exception State Saved in Addition to the Cause Register  | 61 |
| Table 6.5: TLB Modified Exception State Saved in Addition to the Cause Register | 62 |
| Table 6.7: Values for the Mask Field of the PageMask Register                   | 63 |
| Table 6.6: PageMask Register Field Descriptions                                 | 63 |
| Table 6.8: SmartMIPS PageGrain Register Field Descriptions                      | 64 |
| Table 6.9: PageGrain Implementation Subset Behavior                             | 65 |
| Table 6.10: EntryHi Register Field Descriptions                                 | 66 |
| Table A.1: SmartMIPS Changes to Coprocessor 0 Registers in Numerical Order      | 68 |
| Table A.2: Physical Address Generation                                          | 71 |
| Table A.3: TLB Refill Exception State Saved in Addition to the Cause Register   | 72 |
| Table A.4: TLB Invalid Exception State Saved in Addition to the Cause Register  | 73 |
| Table A.5: TLB Modified Exception State Saved in Addition to the Cause Register | 73 |
| Table A.6: SmartMIPS EntryLo0, EntryLo1 Register Field Descriptions             | 74 |
| Table A.7: SmartMIPS Context Register Field Descriptions                        | 76 |
| Table A.8: SmartMIPS ContextConfig Register Field Descriptions                  | 77 |
| Table A.9: Recommended ContextConfig Values for SmartMIPS                       | 77 |
| Table A.10: PageMask Register Field Descriptions                                | 78 |
| Table A.11: Values for the Mask Field of the PageMask Register                  | 78 |
| Table A.12: SmartMIPS PageGrain Register Field Descriptions                     | 79 |
| Table A.13: PageGrain Implementation Subset Behavior                            | 80 |
| Table A.14: EntryHi Register Field Descriptions                                 | 81 |

Chapter 1

# **About This Book**

The MIPS® Architecture for Programmers Volume IV-d: The SmartMIPS® Application-Specific Extension to the MIPS32<sup>®</sup> Architecture comes as part of a multi-volume set.

- Volume I-A describes conventions used throughout the document set, and provides an introduction to the MIPS32® Architecture
- Volume I-B describes conventions used throughout the document set, and provides an introduction to the • microMIPS32<sup>TM</sup> Architecture
- Volume II-A provides detailed descriptions of each instruction in the MIPS32® instruction set •
- Volume II-B provides detailed descriptions of each instruction in the microMIPS32<sup>TM</sup> instruction set
- Volume III describes the MIPS32® and microMIPS32<sup>TM</sup> Privileged Resource Architecture which defines and governs the behavior of the privileged resources included in a MIPS® processor implementation
- Volume IV-a describes the MIPS16e<sup>TM</sup> Application-Specific Extension to the MIPS32® Architecture. Beginning • with Release 3 of the Architecture, microMIPS is the preferred solution for smaller code size.
- Volume IV-b describes the MDMX<sup>TM</sup> Application-Specific Extension to the MIPS64® Architecture and • microMIPS64<sup>TM</sup>. It is not applicable to the MIPS32<sup>®</sup> document set nor the microMIPS32<sup>TM</sup> document set
- Volume IV-c describes the MIPS-3D® Application-Specific Extension to the MIPS® Architecture ٠
- Volume IV-d describes the SmartMIPS®Application-Specific Extension to the MIPS32® Architecture and the microMIPS32<sup>TM</sup> Architecture
- Volume IV-e describes the MIPS® DSP Application-Specific Extension to the MIPS® Architecture •
- Volume IV-f describes the MIPS<sup>®</sup> MT Application-Specific Extension to the MIPS<sup>®</sup> Architecture
- Volume IV-h describes the MIPS® MCU Application-Specific Extension to the MIPS® Architecture •

## 1.1 Typographical Conventions

This section describes the use of *italic*, **bold** and courier fonts in this book.

## 1.1.1 Italic Text

is used for emphasis

- is used for *bits*, *fields*, *registers*, that are important from a software perspective (for instance, address bits used by software, and programmable fields and registers), and various *floating point instruction formats*, such as *S*, *D*, and *PS*
- is used for the memory access types, such as *cached* and *uncached*

### 1.1.2 Bold Text

- represents a term that is being **defined**
- is used for **bits** and **fields** that are important from a hardware perspective (for instance, **register** bits, which are not programmable but accessible only to hardware)
- is used for ranges of numbers; the range is indicated by an ellipsis. For instance, **5..1** indicates numbers 5 through 1
- is used to emphasize UNPREDICTABLE and UNDEFINED behavior, as defined below.

## 1.1.3 Courier Text

Courier fixed-width font is used for text that is displayed on the screen, and for examples of code and instruction pseudocode.

## **1.2 UNPREDICTABLE and UNDEFINED**

The terms **UNPREDICTABLE** and **UNDEFINED** are used throughout this book to describe the behavior of the processor in certain cases. **UNDEFINED** behavior or operations can occur only as the result of executing instructions in a privileged mode (i.e., in Kernel Mode or Debug Mode, or with the CP0 usable bit set in the Status register). Unprivileged software can never cause **UNDEFINED** behavior or operations. Conversely, both privileged and unprivileged software can cause **UNPREDICTABLE** results or operations.

## **1.2.1 UNPREDICTABLE**

**UNPREDICTABLE** results may vary from processor implementation to implementation, instruction to instruction, or as a function of time on the same implementation or instruction. Software can never depend on results that are **UNPREDICTABLE**. **UNPREDICTABLE** operations may cause a result to be generated or not. If a result is generated, it is **UNPREDICTABLE**. **UNPREDICTABLE** operations may cause arbitrary exceptions.

**UNPREDICTABLE** results or operations have several implementation restrictions:

- Implementations of operations generating **UNPREDICTABLE** results must not depend on any data source (memory or internal state) which is inaccessible in the current processor mode
- UNPREDICTABLE operations must not read, write, or modify the contents of memory or internal state which is inaccessible in the current processor mode. For example, UNPREDICTABLE operations executed in user mode must not access memory or internal state that is only accessible in Kernel Mode or Debug Mode or in another process
- UNPREDICTABLE operations must not halt or hang the processor

## **1.2.2 UNDEFINED**

UNDEFINED operations or behavior may vary from processor implementation to implementation, instruction to instruction, or as a function of time on the same implementation or instruction. UNDEFINED operations or behavior may vary from nothing to creating an environment in which execution can no longer continue. UNDEFINED operations or behavior may cause data loss.

UNDEFINED operations or behavior has one implementation restriction:

**UNDEFINED** operations or behavior must not cause the processor to hang (that is, enter a state from which there is no exit other than powering down the processor). The assertion of any of the reset signals must restore the processor to an operational state

## 1.2.3 UNSTABLE

**UNSTABLE** results or values may vary as a function of time on the same implementation or instruction. Unlike UNPREDICTABLE values, software may depend on the fact that a sampling of an UNSTABLE value results in a legal transient value that was correct at some point in time prior to the sampling.

**UNSTABLE** values have one implementation restriction:

Implementations of operations generating UNSTABLE results must not depend on any data source (memory or internal state) which is inaccessible in the current processor mode

## **1.3 Special Symbols in Pseudocode Notation**

In this book, algorithmic descriptions of an operation are described as pseudocode in a high-level language notation resembling Pascal. Special symbols used in the pseudocode notation are listed in Table 1.1.

| Symbol          | Meaning                                                                                                                                                                                                                                                                     |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>←</i>        | Assignment                                                                                                                                                                                                                                                                  |
| =, ≠            | Tests for equality and inequality                                                                                                                                                                                                                                           |
| I               | Bit string concatenation                                                                                                                                                                                                                                                    |
| x <sup>y</sup>  | A <i>y</i> -bit string formed by <i>y</i> copies of the single-bit value <i>x</i>                                                                                                                                                                                           |
| b#n             | A constant value <i>n</i> in base <i>b</i> . For instance 10#100 represents the decimal value 100, 2#100 represents the binary value 100 (decimal 4), and 16#100 represents the hexadecimal value 100 (decimal 256). If the "b#" prefix is omitted, the default base is 10. |
| 0bn             | A constant value <i>n</i> in base 2. For instance 0b100 represents the binary value 100 (decimal 4).                                                                                                                                                                        |
| 0xn             | A constant value <i>n</i> in base 16. For instance 0x100 represents the hexadecimal value 100 (decimal 256).                                                                                                                                                                |
| x <sub>yz</sub> | Selection of bits $y$ through $z$ of bit string $x$ . Little-endian bit notation (rightmost bit is 0) is used. If $y$ is less than $z$ , this expression is an empty (zero length) bit string.                                                                              |
| +, -            | 2's complement or floating point arithmetic: addition, subtraction                                                                                                                                                                                                          |
| *,×             | 2's complement or floating point multiplication (both used for either)                                                                                                                                                                                                      |
| div             | 2's complement integer division                                                                                                                                                                                                                                             |

**Table 1.1 Symbols Used in Instruction Operation Statements** 

| Symbol        | Meaning                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| mod           | 2's complement modulo                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| /             | Floating point division                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| <             | 2's complement less-than comparison                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| >             | 2's complement greater-than comparison                                                                                                                                                                                                                                                                                                                                |  |  |  |
| ≤             | 2's complement less-than or equal comparison                                                                                                                                                                                                                                                                                                                          |  |  |  |
| 2             | 2's complement greater-than or equal comparison                                                                                                                                                                                                                                                                                                                       |  |  |  |
| nor           | Bitwise logical NOR                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| xor           | Bitwise logical XOR                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| and           | Bitwise logical AND                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| or            | Bitwise logical OR                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| GPRLEN        | The length in bits (32 or 64) of the CPU general-purpose registers                                                                                                                                                                                                                                                                                                    |  |  |  |
| GPR[x]        | CPU general-purpose register x. The content of $GPR[0]$ is always zero. In Release 2 of the Architecture, $GPR[x]$ is a short-hand notation for $SGPR[SRSCtl_{CSS}, x]$ .                                                                                                                                                                                             |  |  |  |
| SGPR[s,x]     | In Release 2 of the Architecture and subsequent releases, multiple copies of the CPU general-purpose registers may be implemented. $SGPR[s,x]$ refers to GPR set s, register x.                                                                                                                                                                                       |  |  |  |
| FPR[x]        | Floating Point operand register <i>x</i>                                                                                                                                                                                                                                                                                                                              |  |  |  |
| FCC[CC]       | Floating Point condition code CC. FCC[0] has the same value as COC[1].                                                                                                                                                                                                                                                                                                |  |  |  |
| FPR[x]        | Floating Point (Coprocessor unit 1), general register x                                                                                                                                                                                                                                                                                                               |  |  |  |
| CPR[z,x,s]    | Coprocessor unit <i>z</i> , general register <i>x</i> , select <i>s</i>                                                                                                                                                                                                                                                                                               |  |  |  |
| CP2CPR[x]     | Coprocessor unit 2, general register x                                                                                                                                                                                                                                                                                                                                |  |  |  |
| CCR[z,x]      | Coprocessor unit <i>z</i> , control register <i>x</i>                                                                                                                                                                                                                                                                                                                 |  |  |  |
| CP2CCR[x]     | Coprocessor unit 2, control register x                                                                                                                                                                                                                                                                                                                                |  |  |  |
| COC[z]        | Coprocessor unit <i>z</i> condition signal                                                                                                                                                                                                                                                                                                                            |  |  |  |
| Xlat[x]       | Translation of the MIPS16e GPR number x into the corresponding 32-bit GPR number                                                                                                                                                                                                                                                                                      |  |  |  |
| BigEndianMem  | Endian mode as configured at chip reset (0 $\rightarrow$ Little-Endian, 1 $\rightarrow$ Big-Endian). Specifies the endianness of the memory interface (see LoadMemory and StoreMemory pseudocode function descriptions), and the endianness of Kernel and Supervisor mode execution.                                                                                  |  |  |  |
| BigEndianCPU  | U The endianness for load and store instructions $(0 \rightarrow \text{Little-Endian}, 1 \rightarrow \text{Big-Endian})$ . In User mode, this endianness may be switched by setting the <i>RE</i> bit in the <i>Status</i> register. Thus, BigEndianCPU may be computed as (BigEndianMem XOR ReverseEndian).                                                          |  |  |  |
| ReverseEndian | Signal to reverse the endianness of load and store instructions. This feature is available in User mode only, and is implemented by setting the <i>RE</i> bit of the <i>Status</i> register. Thus, ReverseEndian may be computed as $(SR_{RE} \text{ and User mode})$ .                                                                                               |  |  |  |
| LLbit         | Bit of <b>virtual</b> state used to specify operation for instructions that provide atomic read-modify-write. <i>LLbit</i> is set when a linked load occurs and is tested by the conditional store. It is cleared, during other CPU operation, when a store to the location would no longer be atomic. In particular, it is cleared by exception return instructions. |  |  |  |

#### Table 1.1 Symbols Used in Instruction Operation Statements (Continued)

| Symbol                            | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                                                  |  |  |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------|--|--|
| I:,<br>I+n:,<br>I-n:              | This occurs as a prefix to <i>Operation</i> description lines and functions as a label. It indicates the instruction time during which the pseudocode appears to "execute." Unless otherwise indicated, all effects of the current instruction appear to occur during the instruction time of the current instruction. No label is equivalent to a time label of <b>I</b> . Sometimes effects of an instruction appear to occur either earlier or later — that is, during the instruction time, relative to the current instruction <b>I</b> , in which the effect of that pseudocode appears to occur. For example, an instruction may have a result that is not available until after the next instruction. Such an instruction has the portion of the instruction labelled <b>I+1</b> appears to occur "at the same time" as the effect of pseudocode statements for the current instruction. Within one pseudocode sequence, the effects of the statements take place in order. However, between sequences of statements for different instructions that occur "at the same time," there is no defined order. Programs must not depend on a particular order of evaluation between such sections |          |                                                  |  |  |
| PC                                | The <i>Program Counter</i> value. During the instruction time of an instruction, this is the address of the instruction word. The address of the instruction that occurs during the next instruction time is determined by assigning a value to <i>PC</i> during an instruction time. If no value is assigned to <i>PC</i> during an instruction time by any pseudocode statement, it is automatically incremented by either 2 (in the case of a 16-bit MIPS 16e instruction) or 4 before the next instruction time. A taken branch assigns the target address to the <i>PC</i> during the instruction time of the instruction in the branch delay slot. In the MIPS Architecture, the PC value is only visible indirectly, such as when the processor stores the restart address into a GPR on a jump-and-link or branch-and-link instruction, or into a Coprocessor 0 register on an exception. The PC value contains a full 32-bit address all of which are significant during a memory reference.                                                                                                                                                                                                |          |                                                  |  |  |
| ISA Mode                          | In processors that implement the MIPS16e Application Specific Extension or the microMIPS base architec-<br>tures, the <i>ISA Mode</i> is a single-bit register that determines in which mode the processor is executing, as fol-<br>lows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |                                                  |  |  |
|                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Encoding | Meaning                                          |  |  |
|                                   | 0 The processor is executing 32-bit MIPS instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |                                                  |  |  |
|                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1        | The processor is executing MIIPS16e instructions |  |  |
|                                   | In the MIPS Architecture, the ISA Mode value is only visible indirectly, such as when the processor stores a combined value of the upper bits of PC and the ISA Mode into a GPR on a jump-and-link or branch-and-link instruction, or into a Coprocessor 0 register on an exception.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |                                                  |  |  |
| PABITS                            | The number of physical address bits implemented is represented by the symbol PABITS. As such, if 36 physical address bits were implemented, the size of the physical address space would be $2^{\text{PABITS}} = 2^{36}$ bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |                                                  |  |  |
| FP32RegistersMode                 | Indicates whether the FPU has 32-bit or 64-bit floating point registers (FPRs). In MIPS32 Release 1, the FPU has 32 32-bit FPRs in which 64-bit data types are stored in even-odd pairs of FPRs. In MIPS64, (and optionally in MIPS32 Release2 and MIPSr3) the FPU has 32 64-bit FPRs in which 64-bit data types are stored in any FPR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                                                  |  |  |
|                                   | In MIPS32 Release 1 implementations, <b>FP32RegistersMode</b> is always a 0. MIPS64 implementations have a compatibility mode in which the processor references the FPRs as if it were a MIPS32 implementation. In such a case <b>FP32RegisterMode</b> is computed from the FR bit in the <i>Status</i> register. If this bit is a 0, the processor operates as if it had 32 32-bit FPRs. If this bit is a 1, the processor operates with 32 64-bit FPRs. The value of <b>FP32RegistersMode</b> is computed from the FR bit in the <i>Status</i> register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |                                                  |  |  |
| InstructionInBranchDe-<br>laySlot | Indicates whether the instruction at the Program Counter address was executed in the delay slot of a branch or jump. This condition reflects the <i>dynamic</i> state of the instruction, not the <i>static</i> state. That is, the value is false if a branch or jump occurs to an instruction whose PC immediately follows a branch or jump, but which is not executed in the delay slot of a branch or jump.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |                                                  |  |  |

### Table 1.1 Symbols Used in Instruction Operation Statements (Continued)

| Symbol                 | Meaning                                                                                                     |
|------------------------|-------------------------------------------------------------------------------------------------------------|
| SignalException(excep- | Causes an exception to be signaled, using the exception parameter as the type of exception and the argument |
| tion, argument)        | parameter as an exception-specific argument). Control does not return from this pseudocode function-the     |
|                        | exception is signaled at the point of the call.                                                             |

#### Table 1.1 Symbols Used in Instruction Operation Statements (Continued)

## **1.4 For More Information**

Various MIPS RISC processor manuals and additional information about MIPS products can be found at the MIPS URL: http://www.mips.com

For comments or questions on the MIPS32® Architecture or this document, send Email to support@mips.com.

Chapter 2

# **Guide to the Instruction Set**

This chapter provides a detailed guide to understanding the instruction descriptions, which are listed in alphabetical order in the tables at the beginning of the next chapter.

## 2.1 Understanding the Instruction Fields

Figure 2.1 shows an example instruction. Following the figure are descriptions of the fields listed below:

- "Instruction Fields" on page 19 •
- "Instruction Descriptive Name and Mnemonic" on page 19 •
- "Format Field" on page 19 •
- "Purpose Field" on page 20 •
- "Description Field" on page 20 •
- "Restrictions Field" on page 20 •
- "Operation Field" on page 21 •
- "Exceptions Field" on page 21 •
- "Programming Notes and Implementation Notes Fields" on page 22 •



#### Figure 2.1 Example of Instruction Description

## 2.1.1 Instruction Fields

Fields encoding the instruction word are shown in register form at the top of the instruction description. The following rules are followed:

- The values of constant fields and the *opcode* names are listed in uppercase (SPECIAL and ADD in Figure 2.2). Constant values in a field are shown in binary below the symbolic or hexadecimal value.
- All variable fields are listed with the lowercase names used in the instruction description (rs, rt, and rd in Figure 2.2).
- Fields that contain zeros but are not named are unused fields that are required to be zero (bits 10:6 in Figure 2.2). If such fields are set to non-zero values, the operation of the processor is **UNPREDICTABLE**.

| 31                | 26 25 | 21 20 | 16 15 | 11 | 10 6       | 5             |
|-------------------|-------|-------|-------|----|------------|---------------|
| SPECIAL<br>000000 | rs    | r     | t     | rd | 0<br>00000 | ADD<br>100000 |
| 6                 | 5     | 5     | 5     | 5  | 5          | 6             |

Figure 2.2 Example of Instruction Fields

### 2.1.2 Instruction Descriptive Name and Mnemonic

The instruction descriptive name and mnemonic are printed as page headings for each instruction, as shown in Figure 2.3.

#### Figure 2.3 Example of Instruction Descriptive Name and Mnemonic

| Add Word | ADD |  |
|----------|-----|--|
|----------|-----|--|

### 2.1.3 Format Field

The assembler formats for the instruction and the architecture level at which the instruction was originally defined are given in the Format field. If the instruction definition was later extended, the architecture levels at which it was extended and the assembler formats for the extended definition are shown in their order of extension (for an example, see C.cond.fmt). The MIPS architecture levels are inclusive; higher architecture levels include all instructions in previous levels. Extensions to instructions are backwards compatible. The original assembler formats are valid for the extended architecture.

#### Figure 2.4 Example of Instruction Format

| Format: | ADD fd,rs,rt | MIPS32 |
|---------|--------------|--------|
|         |              |        |

The assembler format is shown with literal parts of the assembler instruction printed in uppercase characters. The variable parts, the operands, are shown as the lowercase names of the appropriate fields. The architectural level at which the instruction was first defined, for example "MIPS32" is shown at the right side of the page.

There can be more than one assembler format for each architecture level. Floating point operations on formatted data show an assembly format with the actual assembler mnemonic for each valid value of the *fint* field. For example, the ADD.fmt instruction lists both ADD.S and ADD.D.

The assembler format lines sometimes include parenthetical comments to help explain variations in the formats (once again, see C.cond.fmt). These comments are not a part of the assembler format.

## 2.1.4 Purpose Field

The *Purpose* field gives a short description of the use of the instruction.

#### Figure 2.5 Example of Instruction Purpose

Purpose: Add Word

To add 32-bit integers. If an overflow occurs, then trap.

## 2.1.5 Description Field

If a one-line symbolic description of the instruction is feasible, it appears immediately to the right of the *Description* heading. The main purpose is to show how fields in the instruction are used in the arithmetic or logical operation.

| Figure 2.6 | Example of | Instruction | Description |
|------------|------------|-------------|-------------|
|------------|------------|-------------|-------------|

| D       | escription: GPR[rd] ← GPR[rs] + GPR[rt]                                                                                                                  |  |  |  |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| T<br>re | The 32-bit word value in GPR <i>rt</i> is added to the 32-bit value in GPR <i>rs</i> to produce a 32-bit result.                                         |  |  |  |
| •       | If the addition results in 32-bit 2's complement arithmetic overflow, the destination register is not modified and an Integer Overflow exception occurs. |  |  |  |
| •       | If the addition does not overflow, the 32-bit result is placed into GPR rd.                                                                              |  |  |  |

The body of the section is a description of the operation of the instruction in text, tables, and figures. This description complements the high-level language description in the *Operation* section.

This section uses acronyms for register descriptions. "GPR rt" is CPU general-purpose register specified by the instruction field rt. "FPR fs" is the floating point operand register specified by the instruction field fs. "CP1 register fd" is the coprocessor 1 general register specified by the instruction field fd. "FCSR" is the floating point Control /Status register.

## 2.1.6 Restrictions Field

The *Restrictions* field documents any possible restrictions that may affect the instruction. Most restrictions fall into one of the following six categories:

- Valid values for instruction fields (for example, see floating point ADD.fmt)
- ALIGNMENT requirements for memory addresses (for example, see LW)
- Valid values of operands (for example, see ALNV.PS)

20 MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00

- Valid operand formats (for example, see floating point ADD.fmt)
- Order of instructions necessary to guarantee correct execution. These ordering constraints avoid pipeline hazards for which some processors do not have hardware interlocks (for example, see MUL).
- Valid memory access types (for example, see LL/SC)

#### Figure 2.7 Example of Instruction Restrictions

| Res | strictions: |
|-----|-------------|
| Nor | ne          |
|     |             |
|     |             |

### 2.1.7 Operation Field

The Operation field describes the operation of the instruction as pseudocode in a high-level language notation resembling Pascal. This formal description complements the Description section; it is not complete in itself because many of the restrictions are either difficult to include in the pseudocode or are omitted for legibility.

#### Figure 2.8 Example of Instruction Operation

#### **Operation:**

```
temp \leftarrow (GPR[rs]_{31} | |GPR[rs]_{31..0}) + (GPR[rt]_{31} | |GPR[rt]_{31..0})
if temp_{32} \neq temp_{31} then
    SignalException(IntegerOverflow)
else
    GPR[rd] \leftarrow temp
endif
```

See 2.2 "Operation Section Notation and Functions" on page 22 for more information on the formal notation used here.

### 2.1.8 Exceptions Field

The *Exceptions* field lists the exceptions that can be caused by *Operation* of the instruction. It omits exceptions that can be caused by the instruction fetch, for instance, TLB Refill, and also omits exceptions that can be caused by asynchronous external events such as an Interrupt. Although a Bus Error exception may be caused by the operation of a load or store instruction, this section does not list Bus Error for load and store instructions because the relationship between load and store instructions and external error indications, like Bus Error, are dependent upon the implementation.

| Figure 2.9 | Exampl | le of li | nstruction | Exception |
|------------|--------|----------|------------|-----------|
|------------|--------|----------|------------|-----------|

| ] | Exceptions:     |
|---|-----------------|
| I | nteger Overflow |

An instruction may cause implementation-dependent exceptions that are not present in the Exceptions section.

## 2.1.9 Programming Notes and Implementation Notes Fields

The *Notes* sections contain material that is useful for programmers and implementors, respectively, but that is not necessary to describe the instruction and does not belong in the description sections.

```
Figure 2.10 Example of Instruction Programming Notes
```

**Programming Notes:** 

ADDU performs the same arithmetic operation but does not trap on overflow.

## 2.2 Operation Section Notation and Functions

In an instruction description, the *Operation* section uses a high-level language notation to describe the operation performed by each instruction. Special symbols used in the pseudocode are described in the previous chapter. Specific pseudocode functions are described below.

This section presents information about the following topics:

- "Instruction Execution Ordering" on page 22
- "Pseudocode Functions" on page 22

## 2.2.1 Instruction Execution Ordering

Each of the high-level language statements in the *Operations* section are executed sequentially (except as constrained by conditional and loop constructs).

## 2.2.2 Pseudocode Functions

There are several functions used in the pseudocode descriptions. These are used either to make the pseudocode more readable, to abstract implementation-specific behavior, or both. These functions are defined in this section, and include the following:

- "Coprocessor General Register Access Functions" on page 22
- "Memory Operation Functions" on page 24
- "Floating Point Functions" on page 27
- "Miscellaneous Functions" on page 30

#### 2.2.2.1 Coprocessor General Register Access Functions

Defined coprocessors, except for CP0, have instructions to exchange words and doublewords between coprocessor general registers and the rest of the system. What a coprocessor does with a word or doubleword supplied to it and how a coprocessor supplies a word or doubleword is defined by the coprocessor itself. This behavior is abstracted into the functions described in this section.

#### COP LW

The COP\_LW function defines the action taken by coprocessor z when supplied with a word from memory during a load word operation. The action is coprocessor-specific. The typical action would be to store the contents of memword in coprocessor general register rt.

#### Figure 2.11 COP LW Pseudocode Function

```
COP_LW (z, rt, memword)
   z: The coprocessor unit number
   rt: Coprocessor general register specifier
   memword: A 32-bit word value supplied to the coprocessor
   /* Coprocessor-dependent action */
endfunction COP_LW
```

#### COP LD

The COP\_LD function defines the action taken by coprocessor z when supplied with a doubleword from memory during a load doubleword operation. The action is coprocessor-specific. The typical action would be to store the contents of memdouble in coprocessor general register rt.

#### Figure 2.12 COP\_LD Pseudocode Function

```
COP_LD (z, rt, memdouble)
   z: The coprocessor unit number
   rt: Coprocessor general register specifier
   memdouble: 64-bit doubleword value supplied to the coprocessor.
   /* Coprocessor-dependent action */
endfunction COP_LD
```

#### COP SW

The COP\_SW function defines the action taken by coprocessor z to supply a word of data during a store word operation. The action is coprocessor-specific. The typical action would be to supply the contents of the low-order word in coprocessor general register rt.

#### Figure 2.13 COP\_SW Pseudocode Function

```
dataword \leftarrow COP_SW (z, rt)
   z: The coprocessor unit number
   rt: Coprocessor general register specifier
   dataword: 32-bit word value
   /* Coprocessor-dependent action */
```

endfunction COP\_SW

#### COP SD

The COP SD function defines the action taken by coprocessor z to supply a doubleword of data during a store doubleword operation. The action is coprocessor-specific. The typical action would be to supply the contents of the low-order doubleword in coprocessor general register rt.

MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00 23

#### Figure 2.14 COP\_SD Pseudocode Function

```
datadouble ← COP_SD (z, rt)
    z: The coprocessor unit number
    rt: Coprocessor general register specifier
    datadouble: 64-bit doubleword value
    /* Coprocessor-dependent action */
endfunction COP_SD
```

#### **CoprocessorOperation**

The CoprocessorOperation function performs the specified Coprocessor operation.

#### Figure 2.15 CoprocessorOperation Pseudocode Function

CoprocessorOperation (z, cop\_fun)

```
/* z: Coprocessor unit number */
/* cop_fun: Coprocessor function from function field of instruction */
/* Transmit the cop_fun value to coprocessor z */
endfunction CoprocessorOperation
```

#### 2.2.2.2 Memory Operation Functions

Regardless of byte ordering (big- or little-endian), the address of a halfword, word, or doubleword is the smallest byte address of the bytes that form the object. For big-endian ordering this is the most-significant byte; for a little-endian ordering this is the least-significant byte.

In the *Operation* pseudocode for load and store operations, the following functions summarize the handling of virtual addresses and the access of physical memory. The size of the data item to be loaded or stored is passed in the *AccessLength* field. The valid constant names and values are shown in Table 2.1. The bytes within the addressed unit of memory (word for 32-bit processors or doubleword for 64-bit processors) that are used can be determined directly from the *AccessLength* and the two or three low-order bits of the address.

#### AddressTranslation

The AddressTranslation function translates a virtual address to a physical address and its cacheability and coherency attribute, describing the mechanism used to resolve the memory reference.

Given the virtual address *vAddr*, and whether the reference is to Instructions or Data (*IorD*), find the corresponding physical address (*pAddr*) and the cacheability and coherency attribute (*CCA*) used to resolve the reference. If the virtual address is in one of the unmapped address spaces, the physical address and *CCA* are determined directly by the virtual address. If the virtual address is in one of the mapped address spaces then the TLB or fixed mapping MMU determines the physical address and access type; if the required translation is not present in the TLB or the desired access is not permitted, the function fails and an exception is taken.

#### Figure 2.16 AddressTranslation Pseudocode Function

```
(pAddr, CCA) ← AddressTranslation (vAddr, IorD, LorS)
    /* pAddr: physical address */
    /* CCA: Cacheability&Coherency Attribute,the method used to access caches*/
```

24 MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00

```
/*
         and memory and resolve the reference */
/* vAddr: virtual address */
/* IorD: Indicates whether access is for INSTRUCTION or DATA */
/* LorS: Indicates whether access is for LOAD or STORE */
/* See the address translation description for the appropriate MMU */
/* type in Volume III of this book for the exact translation mechanism */
```

endfunction AddressTranslation

#### LoadMemory

The LoadMemory function loads a value from memory.

This action uses cache and main memory as specified in both the Cacheability and Coherency Attribute (CCA) and the access (*IorD*) to find the contents of *AccessLength* memory bytes, starting at physical location pAddr. The data is returned in a fixed-width naturally aligned memory element (MemElem). The low-order 2 (or 3) bits of the address and the AccessLength indicate which of the bytes within MemElem need to be passed to the processor. If the memory access type of the reference is uncached, only the referenced bytes are read from memory and marked as valid within the memory element. If the access type is *cached* but the data is not present in cache, an implementation-specific *size* and *alignment* block of memory is read and loaded into the cache to satisfy a load reference. At a minimum, this block is the entire memory element.

#### Figure 2.17 LoadMemory Pseudocode Function

```
MemElem ← LoadMemory (CCA, AccessLength, pAddr, vAddr, IorD)
   /* MemElem:
                Data is returned in a fixed width with a natural alignment. The */
   /*
                 width is the same size as the CPU general-purpose register, */
   /*
                 32 or 64 bits, aligned on a 32- or 64-bit boundary, */
   /*
                respectively. */
   /* CCA:
                Cacheability&CoherencyAttribute=method used to access caches */
   /*
                 and memory and resolve the reference */
   /* AccessLength: Length, in bytes, of access */
   /* pAddr:
                physical address */
   /* vAddr:
                virtual address */
   /* IorD:
                Indicates whether access is for Instructions or Data */
```

endfunction LoadMemory

#### StoreMemory

The StoreMemory function stores a value to memory.

The specified data is stored into the physical location pAddr using the memory hierarchy (data caches and main memory) as specified by the Cacheability and Coherency Attribute (CCA). The MemElem contains the data for an aligned, fixed-width memory element (a word for 32-bit processors, a doubleword for 64-bit processors), though only the bytes that are actually stored to memory need be valid. The low-order two (or three) bits of pAddr and the AccessLength field indicate which of the bytes within the MemElem data should be stored; only these bytes in memory will actually be changed.

#### Figure 2.18 StoreMemory Pseudocode Function

StoreMemory (CCA, AccessLength, MemElem, pAddr, vAddr)

MIPS® Architecture for Programmers Volume IV-d: The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00 25

```
/* CCA:
            Cacheability&Coherency Attribute, the method used to access */
/*
            caches and memory and resolve the reference. */
/* AccessLength: Length, in bytes, of access */
/* MemElem: Data in the width and alignment of a memory element. */
/*
            The width is the same size as the CPU general */
/*
            purpose register, either 4 or 8 bytes, */
/*
            aligned on a 4- or 8-byte boundary. For a */
/*
            partial-memory-element store, only the bytes that will be*/
/*
            stored must be valid.*/
/* pAddr: physical address */
/* vAddr: virtual address */
```

```
endfunction StoreMemory
```

#### Prefetch

The Prefetch function prefetches data from memory.

Prefetch is an advisory instruction for which an implementation-specific action is taken. The action taken may increase performance but must not change the meaning of the program or alter architecturally visible state.

#### Figure 2.19 Prefetch Pseudocode Function

```
Prefetch (CCA, pAddr, vAddr, DATA, hint)
```

```
/* CCA: Cacheability&Coherency Attribute, the method used to access */
/* caches and memory and resolve the reference. */
/* pAddr: physical address */
/* vAddr: virtual address */
/* DATA: Indicates that access is for DATA */
/* hint: hint that indicates the possible use of the data */
```

```
endfunction Prefetch
```

Table 2.1 lists the data access lengths and their labels for loads and stores.

| AccessLength Name | Value | Meaning           |
|-------------------|-------|-------------------|
| DOUBLEWORD        | 7     | 8 bytes (64 bits) |
| SEPTIBYTE         | 6     | 7 bytes (56 bits) |
| SEXTIBYTE         | 5     | 6 bytes (48 bits) |
| QUINTIBYTE        | 4     | 5 bytes (40 bits) |
| WORD              | 3     | 4 bytes (32 bits) |
| TRIPLEBYTE        | 2     | 3 bytes (24 bits) |
| HALFWORD          | 1     | 2 bytes (16 bits) |
| BYTE              | 0     | 1 byte (8 bits)   |

| Table 2.1 | AccessL | _ength | Specif | ications | for | Loads/ | Stores |
|-----------|---------|--------|--------|----------|-----|--------|--------|
|-----------|---------|--------|--------|----------|-----|--------|--------|

#### SyncOperation

The SyncOperation function orders loads and stores to synchronize shared memory.

This action makes the effects of the synchronizable loads and stores indicated by stype occur in the same order for all processors.

#### Figure 2.20 SyncOperation Pseudocode Function

SyncOperation(stype)

/\* stype: Type of load/store ordering to perform. \*/

```
/* Perform implementation-dependent operation to complete the */
```

/\* required synchronization operation \*/

endfunction SyncOperation

#### 2.2.2.3 Floating Point Functions

The pseudocode shown in below specifies how the unformatted contents loaded or moved to CP1 registers are interpreted to form a formatted value. If an FPR contains a value in some format, rather than unformatted contents from a load (uninterpreted), it is valid to interpret the value in that format (but not to interpret it in a different format).

#### ValueFPR

The ValueFPR function returns a formatted value from the floating point registers.

#### Figure 2.21 ValueFPR Pseudocode Function

```
value ← ValueFPR(fpr, fmt)
   /* value: The formattted value from the FPR */
   /* fpr:
              The FPR number */
   /* fmt:
             The format of the data, one of: */
   /*
              S, D, W, L, PS, */
   /*
              OB, QH, */
   /*
             UNINTERPRETED_WORD, */
   /*
              UNINTERPRETED DOUBLEWORD */
   /* The UNINTERPRETED values are used to indicate that the datatype */
   /* is not known as, for example, in SWC1 and SDC1 */
   case fmt of
       S, W, UNINTERPRETED_WORD:
          valueFPR \leftarrow FPR[fpr]
      D, UNINTERPRETED_DOUBLEWORD:
          if (FP32RegistersMode = 0)
              if (fpr_0 \neq 0) then
                 else
                 valueFPR \leftarrow FPR[fpr+1]<sub>31..0</sub> || FPR[fpr]<sub>31..0</sub>
              endif
          else
              valueFPR \leftarrow FPR[fpr]
          endif
      L, PS:
          if (FP32RegistersMode = 0) then
              valueFPR ← UNPREDICTABLE
```

MIPS® Architecture for Programmers Volume IV-d: The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00 27

```
else
valueFPR ← FPR[fpr]
endif
DEFAULT:
valueFPR ← UNPREDICTABLE
endcase
endfunction ValueFPR
```

The pseudocode shown below specifies the way a binary encoding representing a formatted value is stored into CP1 registers by a computational or move operation. This binary representation is visible to store or move-from instructions. Once an FPR receives a value from the StoreFPR(), it is not valid to interpret the value with ValueFPR() in a different format.

#### **StoreFPR**

#### Figure 2.22 StoreFPR Pseudocode Function

```
StoreFPR (fpr, fmt, value)
   /* fpr:
              The FPR number */
   /* fmt:
              The format of the data, one of: ^{\star/}
   /*
              S, D, W, L, PS, */
   /*
              OB, QH, */
   /*
              UNINTERPRETED_WORD, */
   /*
              UNINTERPRETED_DOUBLEWORD */
   /* value: The formattted value to be stored into the FPR */
   /* The UNINTERPRETED values are used to indicate that the datatype ^{\ast/}
   /* is not known as, for example, in LWC1 and LDC1 */
   case fmt of
       S, W, UNINTERPRETED_WORD:
           FPR[fpr] \leftarrow value
       D, UNINTERPRETED_DOUBLEWORD:
           if (FP32RegistersMode = 0)
               if (fpr_0 \neq 0) then
                  UNPREDICTABLE
               else
                  FPR[fpr] \leftarrow UNPREDICTABLE^{32} \parallel value_{31}
                  FPR[fpr+1] \leftarrow UNPREDICTABLE^{32} \parallel value_{63...32}
               endif
           else
               FPR[fpr] \leftarrow value
           endif
       L, PS:
           if (FP32RegistersMode = 0) then
               UNPREDICTABLE
           else
               FPR[fpr] \leftarrow value
           endif
```

endcase

28 MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00

endfunction StoreFPR

The pseudocode shown below checks for an enabled floating point exception and conditionally signals the exception.

#### CheckFPException

#### Figure 2.23 CheckFPException Pseudocode Function

```
CheckFPException()
```

```
/* A floating point exception is signaled if the E bit of the Cause field is a 1 */
/* (Unimplemented Operations have no enable) or if any bit in the Cause field */
/* and the corresponding bit in the Enable field are both 1 */
   if ( (FCSR_{17} = 1) or
          ((FCSR_{16..12} \text{ and } FCSR_{11..7}) \neq 0)) ) then
       SignalException (FloatingPointException)
   endif
```

endfunction CheckFPException

#### **FPConditionCode**

The FPConditionCode function returns the value of a specific floating point condition code.

#### Figure 2.24 FPConditionCode Pseudocode Function

```
tf ← FPConditionCode(cc)
```

```
/* tf: The value of the specified condition code */
/* cc: The Condition code number in the range 0..7 */
if cc = 0 then
    FPConditionCode \leftarrow FCSR<sub>23</sub>
else
    FPConditionCode \leftarrow FCSR<sub>24+cc</sub>
endif
```

endfunction FPConditionCode

#### SetFPConditionCode

The SetFPConditionCode function writes a new value to a specific floating point condition code.

#### Figure 2.25 SetFPConditionCode Pseudocode Function

```
SetFPConditionCode(cc, tf)
    if cc = 0 then
        FCSR \leftarrow FCSR_{31..24} \mid \mid tf \mid \mid FCSR_{22..0}
    else
        FCSR \leftarrow FCSR_{31,..25+cc} || tf || FCSR_{23+cc...0}
endif
endfunction SetFPConditionCode
```

#### 2.2.2.4 Miscellaneous Functions

This section lists miscellaneous functions not covered in previous sections.

#### SignalException

The SignalException function signals an exception condition.

This action results in an exception that aborts the instruction. The instruction operation pseudocode never sees a return from this function call.

#### Figure 2.26 SignalException Pseudocode Function

```
SignalException(Exception, argument)
```

/\* Exception: The exception condition that exists. \*/
/\* argument: A exception-dependent argument, if any \*/

endfunction SignalException

### SignalDebugBreakpointException

The SignalDebugBreakpointException function signals a condition that causes entry into Debug Mode from non-Debug Mode.

This action results in an exception that aborts the instruction. The instruction operation pseudocode never sees a return from this function call.

#### Figure 2.27 SignalDebugBreakpointException Pseudocode Function

SignalDebugBreakpointException()

endfunction SignalDebugBreakpointException

#### SignalDebugModeBreakpointException

The SignalDebugModeBreakpointException function signals a condition that causes entry into Debug Mode from Debug Mode (i.e., an exception generated while already running in Debug Mode).

This action results in an exception that aborts the instruction. The instruction operation pseudocode never sees a return from this function call.

#### Figure 2.28 SignalDebugModeBreakpointException Pseudocode Function

SignalDebugModeBreakpointException()

endfunction SignalDebugModeBreakpointException

#### NullifyCurrentInstruction

The NullifyCurrentInstruction function nullifies the current instruction.

The instruction is aborted, inhibiting not only the functional effect of the instruction, but also inhibiting all exceptions detected during fetch, decode, or execution of the instruction in question. For branch-likely instructions, nullification kills the instruction in the delay slot of the branch likely instruction.

30 MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00

#### Figure 2.29 NullifyCurrentInstruction PseudoCode Function

```
NullifyCurrentInstruction()
```

endfunction NullifyCurrentInstruction

#### JumpDelaySlot

The JumpDelaySlot function is used in the pseudocode for the PC-relative instructions in the MIPS16e ASE. The function returns TRUE if the instruction at vAddr is executed in a jump delay slot. A jump delay slot always immediately follows a JR, JAL, JALR, or JALX instruction.

#### Figure 2.30 JumpDelaySlot Pseudocode Function

```
JumpDelaySlot(vAddr)
```

```
/* vAddr:Virtual address */
```

endfunction JumpDelaySlot

#### **PolyMult**

The PolyMult function multiplies two binary polynomial coefficients.

#### Figure 2.31 PolyMult Pseudocode Function

```
PolyMult(x, y)
    temp \leftarrow 0
    for i in 0 .. 31
        if x_i = 1 then
            temp \leftarrow temp xor (y_{(31-i)..0} || 0^i)
        endif
    endfor
    PolyMult \leftarrow temp
endfunction PolyMult
```

## 2.3 Op and Function Subfield Notation

In some instructions, the instruction subfields op and *function* can have constant 5- or 6-bit values. When reference is made to these instructions, uppercase mnemonics are used. For instance, in the floating point ADD instruction, op=COP1 and function=ADD. In other cases, a single field has both fixed and variable subfields, so the name contains both upper- and lowercase characters.

## 2.4 FPU Instructions

In the detailed description of each FPU instruction, all variable subfields in an instruction format (such as fs, ft, immediate, and so on) are shown in lowercase. The instruction name (such as ADD, SUB, and so on) is shown in uppercase.

For the sake of clarity, an alias is sometimes used for a variable subfield in the formats of specific instructions. For example, rs=base in the format for load and store instructions. Such an alias is always lowercase since it refers to a variable subfield.

MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00 31

Bit encodings for mnemonics are given in Volume I, in the chapters describing the CPU, FPU, MDMX, and MIPS16e instructions.

See "Op and Function Subfield Notation" on page 31 for a description of the op and function subfields.

# The SmartMIPS® Application-Specific Extension to the **MIPS32®** Architecture

## 3.1 Base Architecture Requirements

The SmartMIPS® ASE requires the following base architecture support:

- The MIPS32 Architecture: The SmartMIPS ASE requires a compliant implementation of the MIPS Architecture.
- For Release 2 (and subsequent) of the MIPS® Architecture, the following COP0 register field settings and implementation of features are required:
  - 1. Config3<sub>SP</sub> must be clear to denote that the Release 2 definition of 1KB Virtual pages is not implemented.
- For Release 3 of the MIPS® Architecture, the following COP0 register field settings and implementation of features are required:
  - 1. Config $3_{RXI}$  must be set to denote that the RI/XI protection feature is implemented in the TLB.
  - 2. Both PageGrain<sub>RIE</sub> and PageGrain<sub>XIE</sub> bits must be writeable to denote that both protection bits are implemented.
  - 3. Config3<sub>CTXTC</sub> must be set to denote that the ContextConfig register is implemented.

Software can use the asserted values of Config3<sub>RXI</sub> or Config3<sub>CTXTC</sub> to denote that the Privileged Architecture is at Release 3.

## 3.2 Software Detection of the ASE

Software may determine if the SmartMIPS ASE is implemented by checking the state of the SM bit in the Config3 CP0 register.

## 3.3 Compliance and Subsetting

There are no instruction subsets of the SmartMIPS ASE to the MIPS32 Architecture - all SmartMIPS instructions must be implemented.

## 3.4 Overview of the SmartMIPS ASE

The SmartMIPS ASE extends the MIPS32® Architecture with set of new instructions combined with a set of backward-compatible modifications to existing MIPS32 instructions, designed to improve the performance and reduce the memory consumption of MIPS-based smart card or "smart object" systems. The SmartMIPS ASE contains enhancements in several distinct areas: cryptographic processing, code density, and virtual machine performance.

## 3.4.1 Support for Cryptographic Algorithms in the SmartMIPS ASE

The SmartMIPS ASE includes a package of extensions to MIPS32 to enhance the performance of cryptographic algorithms. Cryptographic algorithms can be generally divided into two categories - public key algorithms and secret key algorithms. Secret key algorithms, also known as symmetric algorithms, encrypt and decrypt with the same key, while public key algorithms operate in terms of key pairs, one for encryption and the other for decryption.

### 3.4.1.1 Secret Key Cryptography

Secret key algorithms are generally computationally relatively simple and frequently reducible to simple hardware solutions performing sequences of XORs, rotations, and permutations on blocks of data.

The SmartMIPS ASE contains the following elements for accelerating software implementations of secret key cryptography:

- A partial permutation instruction, capable of permuting 6 bits per instruction.
- A single-instruction bitwise rotate capability.

#### 3.4.1.2 Public Key Cryptography

Public key cryptosystems are mathematically more subtle and computationally more difficult than private-key systems. While different schemes have different bases in mathematics, they tend to have a common need for integer computation across very large ranges of values, on the order of 1024 bits. This extended precision arithmetic is often modular (operating modulo the value range), and in some cases polynomial instead of twos-complement. Research conducted with industry partners has led us to conclude that accelerating extended-precision modular arithmetic provides a significant improvement in performance across a range of public key cryptography schemes.

The SmartMIPS ASE contains the following elements for accelerating public key cryptography:

- Additional architecturally visible accumulator state containing extended carry information.
- Instructions to allow the extended carry state to be initialized, extracted, saved, and restored.
- Extension of the definition of the MIPS32 MADDU instruction to generate and use the extended carry state.
- Instructions which allow multiplication and accumulation of polynomial-basis values.

### 3.4.2 Code Density Optimization

Note: For Release 3 of the MIPS32 Architecture, the microMIPS instruction set is the preferred solution for small code-sizes. The rest of this section is meant for implementations using Release 2 or Release 1 of the MIPS32 Architecture.

The SmartMIPS ASE is meant to be used with the MIPS16e<sup>TM</sup> ASE. This ASE is fully documented in Volume IV-a of the MIPS Architecture reference, and is outside the scope of this document. Relative to the earlier version of MIPS16, there are enhancements in the following areas:

#### 3.4.2.1 Data Type Conversion

In virtual machines and other software that very frequently handles data elements smaller than a 32-bit word, sign and zero extension operations must be performed on those data elements before they can be used computationally. In MIPS16, these operations require relatively large instruction sequences, on the order of 8 bytes per conversion. The MIPS16e ASE provides a set of specific instructions to perform zero and sign-extension of bytes and 16-bit halfwords, bringing the footprint down to 2 bytes per conversion.

#### 3.4.2.2 Jump Delay Slot Suppression

The MIPS16 ASE preserved the "delay slot" following the jump instructions used for subroutine call and return. The compiler can frequently, but by no means always, fill these delay slots with a useful instruction. Where it cannot, the MIPS16 ASE required that a no-op instruction be inserted into the instruction stream, at a cost of 2 bytes of footprint. The MIPS16e ASE provides variant jump-via-register instructions that suppress these visible delay slots and eliminate the need for those no-ops.

#### 3.4.2.3 Stack Frame Set-up and Tear-down

In generating code compatible with the MIPS Application Binary Interface (ABI) calling conventions, the compiler must assure that each subroutine set up and tear down a stack frame on which register values are saved and where local variables can be stored. The process of storing register values and updating the stack pointer on subroutine entry, and of restoring the values of the registers and the stack pointer on subroutine exit, can consume a significant amount of code, particularly in system composed of many small subroutines.

While a convention exists for trapping into the operating system from MIPS16 code, and having the operating system perform the necessary stack frame maintenance, this imposes a significant burden on small operating systems and has a significant impact on performance. The MIPS16e ISA provides instructions that allow stack frame setup and restoration each to be done in a single compressed instruction.

## 3.4.3 Other ISA Enhancements

In order to accelerate the interpretation of JavaCard bytecodes and similar interpretive languages, SmartMIPS introduces a scaled, indexed 32-bit load instruction.

## 3.4.4 Privileged Resource Architecture Enhancements

In addition to an augmented instruction set, SmartMIPS defines an augmented privileged resource architecture with augmented memory management capabilities.

- True Read-only, Write-only, and Execute-only page protection are supported.<sup>1</sup>
- 2K or 1K virtual memory pages can be supported.
- A more flexible CP0 Context register is provided to accelerate TLB lookups in small memory systems.<sup>1</sup>

<sup>1</sup> For Release 3 of the MIPS Architecture, this feature is an available option in the standard Privileged Architecture. For Smart-MIPS implementations, these features are required to be implemented.
### 3.5 Instruction Bit Encoding

Table 3.2 through Table 3.11 describe the encoding used for the SmartMIPS ASE. Table 3.1 describes the meaning of the symbols used in the tables. These tables only list the instruction encodings for the SmartMIPS instructions. See Volume I-A of this multi-volume set for a full encoding of all instructions.

| Symbol | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| *      | Operation or field codes marked with this symbol are reserved for future use. Executing such an instruction must cause a Reserved Instruction Exception.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| δ      | (Also <i>italic</i> field name.) Operation or field codes marked with this symbol denotes a field class.<br>The instruction word must be further decoded by examining additional tables that show values for another instruction field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| β      | Operation or field codes marked with this symbol represent a valid encoding for a higher-order MIPS ISA level. Executing such an instruction must cause a Reserved Instruction Exception.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| θ      | Operation or field codes marked with this symbol are available to licensed MIPS partners. To avoid multiple conflicting instruction definitions, MIPS Technologies will assist the partner in selecting appropriate encodings if requested by the partner. The partner is not required to consult with MIPS Technologies when one of these encodings is used. If no instruction is encoded with this value, executing such an instruction must cause a Reserved Instruction Exception ( <i>SPECIAL2</i> encodings or coprocessor instruction encodings for a coprocessor to which access is allowed) or a Coprocessor Unusable Exception (coprocessor instruction encodings for a coprocessor to which access is not allowed). |
| σ      | Field codes marked with this symbol represent an EJTAG support instruction and implementation of this encoding is optional for each implementation. If the encoding is not implemented, executing such an instruction must cause a Reserved Instruction Exception. If the encoding is implemented, it must match the instruction encoding as shown in the table.                                                                                                                                                                                                                                                                                                                                                               |
| ε      | Operation or field codes marked with this symbol are reserved for MIPS Application Specific Extensions. If the ASE is not implemented, executing such an instruction must cause a Reserved Instruction Exception.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| φ      | Operation or field codes marked with this symbol are obsolete and will be removed from a future revision of the MIPS32 ISA. Software should avoid using these operation or field codes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

Table 3.1 Symbols Used in the Instruction Encoding Tables

| Table | 3.2 | <b>SmartMIPS</b> | ASE | Encoding | of the | Opcode | Field |
|-------|-----|------------------|-----|----------|--------|--------|-------|
|       | ••• |                  |     |          | •      |        |       |

| op   | code | bits 2826        |     |     |     |                   |     |     |     |
|------|------|------------------|-----|-----|-----|-------------------|-----|-----|-----|
|      |      | 0                | 1   | 2   | 3   | 4                 | 5   | 6   | 7   |
| bits | 3129 | 000              | 001 | 010 | 011 | 100               | 101 | 110 | 111 |
| 0    | 000  | SPECIAL <b>δ</b> |     |     |     |                   |     |     |     |
| 1    | 001  |                  |     |     |     |                   |     |     |     |
| 2    | 010  |                  |     |     |     |                   |     |     |     |
| 3    | 011  |                  |     |     |     | SPECIAL2 <b>δ</b> |     |     |     |
| 4    | 100  |                  |     |     |     |                   |     |     |     |
| 5    | 101  |                  |     |     |     |                   |     |     |     |
| 6    | 110  |                  |     |     |     |                   |     |     |     |
| 7    | 111  |                  |     |     |     |                   |     |     |     |

| fu  | nction | bits 20 |         |       |       |     |     |        |     |
|-----|--------|---------|---------|-------|-------|-----|-----|--------|-----|
|     |        | 0       | 1       | 2     | 3     | 4   | 5   | 6      | 7   |
| bit | s 53   | 000     | 001     | 010   | 011   | 100 | 101 | 110    | 111 |
| 0   | 000    |         |         | SRL δ |       |     |     | SRLV δ |     |
| 1   | 001    |         |         |       |       |     |     |        |     |
| 2   | 010    |         |         | MFLOδ | MTLOδ |     |     |        |     |
| 3   | 011    |         | MULTU δ |       |       |     |     |        |     |
| 4   | 100    |         |         |       |       |     |     |        |     |
| 5   | 101    |         |         |       |       |     |     |        |     |
| 6   | 110    |         |         |       |       |     |     |        |     |
| 7   | 111    |         |         |       |       |     |     |        |     |

#### Table 3.3 SmartMIPS ASE SPECIAL Opcode Encoding of Function Field

#### Table 3.4 SmartMIPS ASE SPECIAL2 Encoding of Function Field

| fur | nction | bits 20 |        |     |     |     |     |     |     |
|-----|--------|---------|--------|-----|-----|-----|-----|-----|-----|
|     |        | 0       | 1      | 2   | 3   | 4   | 5   | 6   | 7   |
| bit | s 53   | 000     | 001    | 010 | 011 | 100 | 101 | 110 | 111 |
| 0   | 000    |         | MADDUδ |     |     |     |     |     |     |
| 1   | 001    | LXSδ    |        |     |     |     |     |     |     |
| 2   | 010    |         |        |     |     |     |     |     |     |
| 3   | 011    |         |        |     |     |     |     |     |     |
| 4   | 100    |         |        |     |     |     |     |     |     |
| 5   | 101    |         |        |     |     |     |     |     |     |
| 6   | 110    |         |        |     |     |     |     |     |     |
| 7   | 111    |         |        |     |     |     |     |     |     |

#### Table 3.5 SmartMIPS ASE SRL Encoding of Shift/Rotate

| R | bit 21 |      |  |
|---|--------|------|--|
|   | 0      | 1    |  |
|   | SRL    | ROTR |  |

#### Table 3.6 SmartMIPS ASE SRLV Encoding of Shift/Rotate

| R | bit 6 |       |  |  |
|---|-------|-------|--|--|
|   | 0     | 1     |  |  |
|   | SRLV  | ROTRV |  |  |

#### Table 3.7 SmartMIPS ASE MFLO Encoding of MFLO/MFLHXU

| sa | bits 106 |         |
|----|----------|---------|
|    | 0b00000  | 0b00001 |
|    | MFLO     | MFLHXU  |

#### Table 3.8 SmartMIPS ASE MTLO Encoding of MTLO/MTLHX

| sa | bits 106 |         |
|----|----------|---------|
|    | 0b00000  | 0b00001 |
|    | MTLO     | MTLHX   |

#### Table 3.9 SmartMIPS ASE MULTU Encoding of MULTU/MULTP

| sa | bits 106 |         |
|----|----------|---------|
|    | 0b00000  | 0b10001 |
|    | MULTU    | MULTP   |

#### Table 3.10 SmartMIPS ASE MADDU Encoding of MADDU/MADDP/PPERM

| sa | bits 106 |         |         |
|----|----------|---------|---------|
|    | 0b00000  | 0b10001 | 0b10010 |
|    | MADDU    | MADDP   | PPERM   |

#### Table 3.11 SmartMIPS ASE LXS Encoding of LWXS

| sa | bits 106 |
|----|----------|
|    | 0b00001  |
|    | LWXS     |

The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture

Chapter 4

## The SmartMIPS® Cryptographic Feature Set

The SmartMIPS ASE includes a set of features that form a cryptographic extension to the MIPS32 Architecture. This adds the following new architecturally visible state:

A special accumulator extension register, ACX.

It modifies the following MIPS32/MIPS64 instructions to generate and consume the new ACX state:

- MADDU
- MULTU

It adds the following new instructions to extract and restore the new ACX state:

- MFLHXU
- MTLHX

It adds the following new instructions to implement efficient binary polynomial arithmetic in the multiply/divide unit:

- MADDP
- MULTP

It adds a partial permutation instruction to accelerate bit-permutation of data.

PPERM

And it adds bitwise rotate instructions that operate on the general register set:

- ROTR
- ROTRV

### 4.1 The Special Register ACX

The special register ACX contains some number of bits of additional integer precision beyond those contained in the HI/LO special register pair. The precise number of bits is implementation dependent, but can be trivially determined at run-time by software. The minimum architectural size of the ACX register is 8 bits. The maximum architectural size of the ACX register is 64 bits for a MIPS64 processor and 32 bits for a MIPS32 processor. The currently recommended implementation size of the ACX register is 8 bits.

### 4.2 Change to MADDU Semantics

Whereas the MIPS32 MADDU instruction is defined to produce a 64-bit result, the SmartMIPS ASE MADDU instruction produces a higher-precision result, with the carry out of the *HI* register propagating into the ACX register. The behavior of the instruction as seen by the MIPS32 ISA is unchanged.

### 4.3 Change to MULTU Semantics

The definition of the MIPS32 MULTU instruction is extended to clear the ACX register to all zeroes.

### 4.4 Possible Changes to other Multiply/Accumulate Semantics

While only MADDU, MULTU, MADDP, and MULTP need affect the ACX register to implement the extended-precision modular arithmetic algorithms targeted by the ASE, in the interests of consistency and design simplicity, it is possible that the MADD instruction will also generate ACX bits should the *HI* register overflow, and that the MULT, DIV, and DIVU instructions will clear the ACX bits. *Code written to the SmartMIPS ASE should make no assumptions about the behavior of the ACX bits during the execution of any instruction that writes both the HI and LO special registers, other than MULTU, MADDU, MULTP, and MADDP as described in this document.* 

### 4.5 New Instructions

### 4.5.1 MFLHXU

The MFLHXU, or Move-from-LO-HI-ACX-Unsigned instruction, in effect shifts the extended precision accumulator formed by the ACX, HI, and LO registers to the right by one register position: the LO register is copied into the specified GPR, the HI register is copied into the LO register, and the ACX register is zero-extended and copied into the HI register. The instruction is designated as "unsigned" because the ACX bits are zero-extended and not sign-extended when they are transferred to a HI register of higher precision.

### 4.5.2 MTLHX

The MTLHXI, or Move-to-LO-HI-ACX instruction, is the inverse operation from MFLHXU. It effectively shifts the extended-precision accumulator formed by the ACX, *HI*, and *LO* registers to the left by one register position: The *HI* register is truncated to the width of the ACX register and the remaining lower bits are copied to the ACX register, the *LO* register is copied to the *HI* register, and the specified GPR is copied to the *LO* register.

### 4.5.3 MADDP

Binary polynomial addition and multiplication form the basis for an important family of elliptical curve (EC) cryptosystems. The MADDP instruction performs a polynomial basis multiply of a pair of general registers, and then performs a polynomial basis add of the resulting product to the contents of the H/LO register pair.

### 4.5.4 MULTP

The MULTP instruction performs a binary polynomial basis multiply of a pair of general registers, placing the result in the H/LO register pair.

### 4.5.5 PPERM

The PPERM instruction performs a partial permutation of a value in a general register into the ACX-HI-LO registers. The ACX-HI-LO registers are shifted left by six bit positions, and the least significant six bits of LO are set to the values of arbitrary bits in an input register, based on a set of six, 5-bit bit specifiers in the second general-purpose input register. This allows for an arbitrary permutation of 32 bits of a GPR in 7 instructions: 6 PPERMS and a MFLO or MFLHX.

### 4.5.6 ROTR

DES and the candidate AES secret-key block ciphers all require rotations of 32-bit quantities. In the MIPS32 ISA, this requires a sequence of 3 instructions to perform. The ROTR instruction performs a bitwise rotation of a general purpose register of up to 31 bits in a single instruction. The definition and encoding of the ROTR instruction in the SmartMIPS ASE is identical to that of the same instruction in Release 2 of the MIPS Architecture.

#### 4.5.7 ROTRV

The ROTRV instruction performs a variable-length rotation of a general purpose register, with the number of bits to be rotated determined at run-time by the value of another general purpose register. The definition and encoding of the ROTRV instruction in the SmartMIPS ASE is identical to that of the same instruction in Release 2 of the MIPS Architecture.

The SmartMIPS® Cryptographic Feature Set

Chapter 5

## **Other ISA Elements of the SmartMIPS® ASE**

In addition to the cryptography feature set and the enhanced MIPS16 ASE, the SmartMIPS ASE contains the following instruction:

LWXS - Scaled, indexed word load. •

### 5.1 LWXS Instruction

The inner-loop function of interpreters for JavaCard bytecodes and similar interpretive languages requires a dispatch to a function based on an integer value. The LWXS instruction reduces and accelerates such loops, by integrating a scaling of an integer operand into a word offset and an address generation based on using the scaled value as an offset relative to a base register.

| 31                 | 26 | 25   | 21 | 20    | 16 | 15 |    | 11 | 10 |               | 6 | 5           | 0       |
|--------------------|----|------|----|-------|----|----|----|----|----|---------------|---|-------------|---------|
| SPECIAL2<br>011100 |    | base |    | index |    |    | rd |    |    | LWXS<br>00010 |   | LX:<br>0010 | S<br>00 |
| 6                  |    | 5    |    | 5     |    |    | 5  |    |    | 5             |   | 6           |         |

Format: LWXS rd, index(base)

Purpose: Load Word Indexed, Scaled

To load a word from memory as a signed value, using scaled indexed addressing.

**Description:** GPR[rd] ← memory[GPR[base] + (GPR[index] × 4)]

The contents of GPR *index* is multiplied by 4 and the result is added to the contents of GPR *base* to form an effective address. The contents of the 32-bit word at the memory location specified by the aligned effective address are fetched, sign-extended to the GPR register length if necessary, and placed in GPR *rd*.

#### **Restrictions:**

The effective address must be naturally-aligned. If either of the 2 least-significant bits of the address is non-zero, an Address Error exception occurs.

#### **Operation:**

```
vAddr ← (GPR[index]<sub>29..0</sub> || 0<sup>2</sup>) + GPR[base]
if vAddr<sub>1..0</sub> ≠ 0<sup>2</sup> then
   SignalException(AddressError)
endif
(pAddr, CCA) ← AddressTranslation (vAddr, DATA, LOAD)
memword ← LoadMemory (CCA, WORD, pAddr, vAddr, DATA)
GPR[rd] ← memword
```

#### **Exceptions:**

TLB Refill, TLB Invalid, Bus Error, Address Error

SmartMIPS

| 31       | 26              | 6 25     | 21 | 20 1 | 16 | 15 1       | 11 1 | 10 6           | 6 | 5 0             |        |
|----------|-----------------|----------|----|------|----|------------|------|----------------|---|-----------------|--------|
| SPI<br>0 | ECIAL2<br>11100 | rs       |    | rt   |    | 0<br>00000 |      | MADDP<br>10001 |   | MADDU<br>000001 |        |
|          | 6               | 5        |    | 5    |    | 5          |      | 5              |   | 6               |        |
| Form     | nat: MADD       | P rs, rt |    |      |    |            |      |                |   | SmartMIPS (     | Crypto |

Purpose: Multiply and Add Polynomial Basis Word to Hi,Lo

To multiply two 32-bit binary polynomial values and polynomial-basis add the result to Hi, Lo.

**Description:** (LO, HI, ACX) ← PolyMult(GPR[rs], GPR[rt]) xor (LO, HI, ACX)

The 32-bit word value in GPR rs is polynomial-basis multiplied by the 32-bit value in GPR rt, treating both operands as binary polynomial values, to produce a 64-bit result. The product is polynomial-basis added (XORed) to the 64-bit concatenated value of HI and LO, and the zero-extended result is written back into HI and LO. Although MADDP is formally defined to operate on special register ACX as well, its value can never be changed by the operation, nor can its input value affect the result. No arithmetic exception occurs under any circumstances.

#### **Restrictions:**

This instruction does not provide the capability of writing directly to a target GPR.

#### **Operation:**

```
\begin{array}{l} \texttt{temp} \leftarrow (\texttt{HI}_{31..0} \parallel \texttt{LO}_{31..0}) \text{ xor PolyMult}(\texttt{GPR}[\texttt{rs}]_{31..0},\texttt{GPR}[\texttt{rt}]_{31..0}) \\ \texttt{HI} \leftarrow \texttt{sign}\_\texttt{extend}(\texttt{temp}_{63..32}) \\ \texttt{LO} \leftarrow \texttt{sign}\_\texttt{extend}(\texttt{temp}_{31..0}) \\ \texttt{ACX} \leftarrow \texttt{ACX} \end{array}
```

#### **Exceptions**:

None

| 31 |                    | 26  | 25     | 21 | 20 | 16 | 15  | 11  | 10 |                | 6 | 5               | 0        |
|----|--------------------|-----|--------|----|----|----|-----|-----|----|----------------|---|-----------------|----------|
|    | SPECIAL2<br>011100 |     | rs     |    | rt |    | 000 | 000 |    | MADDU<br>00000 |   | MADDU<br>000001 |          |
|    | 6                  |     | 5      |    | 5  |    | 5   |     |    | 5              |   | 6               |          |
| I  | Format: MAI        | DDU | rs, rt |    |    |    |     |     |    |                |   | SmartMIP        | S Crypto |

Purpose: Multiply and Add Unsigned Word to Hi,Lo

To multiply two unsigned words and add the result to ACX, HI, LO.

**Description:** (LO, HI, ACX) ← (GPR[rs] × GPR[rt]) + (LO, HI, ACX)

The 32-bit word value in GPR *rs* is multiplied by the 32-bit value in GPR *rt*, treating both operands as unsigned values, to produce a 64-bit result. The product is added to the 72-or-more-bit concatenated value of ACX, *HI*, and *LO*, and the carry-extended result is written back into ACX, *HI*, and *LO*. No arithmetic exception occurs under any circumstances.

#### **Restrictions:**

This instruction does not provide the capability of writing directly to a target GPR.

#### **Operation:**

```
\begin{split} & \mathsf{temp} \leftarrow (\mathsf{ACX}_{\mathsf{ACXMSB..0}} \parallel \mathsf{HI}_{31..0} \parallel \mathsf{LO}_{31..0}) + (\mathsf{GPR}[\mathsf{rs}]_{31..0} \times \mathsf{GPR}[\mathsf{rt}]_{31..0}) \\ & \mathsf{ACX} \leftarrow \mathsf{zero\_extend}(\mathsf{temp}_{\mathsf{ACXMSB+64..64}}) \\ & \mathsf{HI} \leftarrow \mathsf{sign\_extend}(\mathsf{temp}_{63..32}) \\ & \mathsf{LO} \leftarrow \mathsf{sign\_extend}(\mathsf{temp}_{31..0}) \end{split}
```

#### **Exceptions**:

None

Format: MFLHXU rd

SmartMIPS Crypto

Purpose: Move from Extended Carry, Hi and Lo (Unsigned)

Extract extended Hi/Lo state.

**Description:**  $GPR[rd] \leftarrow LO; LO \leftarrow HI; HI \leftarrow ACX; ACX \leftarrow 0;$ 

The value in special register LO is written to GPR rd. The value in special register HI is then written to special register LO, the extended accumulator bits ACX are zero-extended and copied to HI, and the extended accumulator bits ACX are cleared

- The number of ACX extended accumulator bits is implementation dependent, ranging from 8 to 64 bits.
- If 64-bit operations are not available and enabled, at most the least-significant 32 bits of ACX will be copied to • HI, but the whole ACX field will then be cleared.

#### **Restrictions:**

None

#### **Operation:**

```
newHI ← zero_extend(ACX)
newLO \leftarrow HI
GPR[rd] \leftarrow LO
L0 \leftarrow newL0
\text{HI} \leftarrow \text{newHI}
ACX \leftarrow 0
```

#### **Exceptions:**

None

| 31 | 26                | 25 21 | 20 11              | 10 6           | 5 0            |
|----|-------------------|-------|--------------------|----------------|----------------|
|    | SPECIAL<br>000000 | rs    | 0<br>0 0000 0000 0 | MTLHX<br>00001 | MTLO<br>010011 |
|    | 6                 | 5     | 10                 | 5              | 6              |

Format: MTLHX rs

Purpose: Move to Lo, Hi, and Extended Carry

Set extended Hi/Lo state.

**Description:** ACX  $\leftarrow$  HI; HI  $\leftarrow$  LO; LO  $\leftarrow$  GPR[rs];

The value special register HI is written to the extended accumulator bits ACX. The value in special register LO is then written to special register HI, and the value in GPR rs is written to special register LO. This is the reverse of the operation of the MFLHXU instruction.

- The number of ACX extended accumulator bits is implementation-dependent, ranging from 8 to 64 bits. If the *HI* register contains more significant bits than the number of implemented ACX bits, that information is discarded without raising an exception.
- If 64-bit operations are not enabled, at most the least-significant 32 bits of HI will be copied to ACX.

#### **Restrictions:**

None

#### **Operation:**

```
\begin{array}{l} \texttt{newLO} \leftarrow \texttt{GPR}[\texttt{rs}] \\ \texttt{newHI} \leftarrow \texttt{LO} \\ \texttt{ACX} \leftarrow \texttt{HI}_{\texttt{ACXMSB..0}} \\ \texttt{HI} \leftarrow \texttt{newHI} \\ \texttt{LO} \leftarrow \texttt{newLO} \end{array}
```

#### **Exceptions:**

None

SmartMIPS Crypto

| 31 | 2                 | 6 25     | 21 | 20 16 | 15 1 <sup>7</sup> | 10 6           | 5 0             |       |
|----|-------------------|----------|----|-------|-------------------|----------------|-----------------|-------|
|    | SPECIAL<br>000000 | :        | rs | rt    | 0                 | MULTP<br>10001 | MULTU<br>011001 |       |
|    | 6                 |          | 5  | 5     | 5                 | 5              | 6               | -     |
|    | Format: MULT      | 'P rs, r | t  |       |                   |                | SmartMIPS C     | rypto |

Purpose: Multiply Binary Polynomial Basis Word

To multiply two 32-bit binary polynomial values

**Description:** (LO, HI) ← BinPolyMult(GPR[rs], GPR[rt])

The 32-bit word value in GPR rt is polynomial-basis multiplied by the 32-bit value in GPR rs, treating both operands as binary polynomial values, to produce a 64-bit result. The low-order 32-bit word of the result is placed into special register LO, and the high-order 32-bit word is placed into special register HI. The special register ACX is cleared.

No arithmetic exception occurs under any circumstances.

#### **Restrictions:**

None

#### **Operation:**

```
prod \leftarrow PolyMult(GPR[rs]<sub>31..0</sub>, GPR[rt]<sub>31..0</sub>)
L0 \leftarrow sign\_extend(prod_{31..0})
\text{HI} \leftarrow \text{sign\_extend}(\text{prod}_{63,..32})
ACX \leftarrow 0
```

#### **Exceptions:**

None

MIPS® Architecture for Programmers Volume IV-d: The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00 51

MULTP

| 31 |                   | 26  | 25     | 21 | 20 16 | 6 15 | 11 | 10             | 6 | 5 0             |        |
|----|-------------------|-----|--------|----|-------|------|----|----------------|---|-----------------|--------|
|    | SPECIAL<br>000000 |     | rs     |    | rt    | 0    |    | MULTU<br>00000 |   | MULTU<br>011001 |        |
|    | 6                 |     | 5      |    | 5     | 5    |    | 5              |   | 6               | -      |
| Fo | ormat: MUI        | LTU | rs, rt |    |       |      |    |                |   | SmartMIPS C     | Crypto |

Purpose: Multiply Unsigned Word

To multiply 32-bit unsigned integers

**Description:** (LO, HI) ← GPR[rs] × GPR[rt]

The 32-bit word value in GPR *rt* is multiplied by the 32-bit value in GPR *rs*, treating both operands as unsigned values, to produce a 64-bit result. The low-order 32-bit word of the result is placed into special register *LO*, and the high-order 32-bit word is placed into special register *HI*. The special register ACX is cleared.

No arithmetic exception occurs under any circumstances.

#### **Restrictions:**

None

#### **Operation:**

```
\begin{array}{l} \texttt{prod} \leftarrow (0 \parallel \texttt{GPR[rs]}_{31..0}) \times (0 \parallel \texttt{GPR[rt]}_{31..0}) \\ \texttt{LO} \leftarrow \texttt{sign\_extend}(\texttt{prod}_{31..0}) \\ \texttt{HI} \leftarrow \texttt{sign\_extend}(\texttt{prod}_{63..32}) \\ \texttt{ACX} \leftarrow 0 \end{array}
```

#### **Exceptions:**

None

| 31                 | 26 25 | 21 2 | 20 16 | 15 11 | 10 6           | 5               | 0 |
|--------------------|-------|------|-------|-------|----------------|-----------------|---|
| SPECIAL2<br>011100 | r     | s    | rt    | 0     | PPERM<br>10010 | MADDU<br>000001 |   |
| 6                  | Ę     | 5    | 5     | 5     | 5              | 6               |   |

Format: PPERM rs, rt

**Purpose:** Partial Permutation of Word Data into ACX-Hi-Lo Accumulator

Perform a partial permutation of a 32-bit value into the ACX/Hi/Lo registers

**Description:** (LO, HI, ACX)  $\leftarrow$  (LO, HI, ACX) << 6 | GPR[rs] bits specified by contents of GPR[rt]

The extended accumulator formed by the ACX, *HI*, and *LO* registers is shifted left by six bits, and 32-bit word value in GPR *rt* is used as a permutation descriptor to select a set of six bits from GPR *rs*, to be written into the least significant six bits of the *LO* register.

The contents of the *rt* register are interpreted as follows:

| 31 30 | 29 25           | 24 20           | 19 15           | 14 10           | 9 5             | 4 0             |
|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| 0     | Source of bit 5 | Source of bit 4 | Source of bit 3 | Source of bit 2 | Source of bit 1 | Source of bit 0 |
| 2     | 5               | 5               | 5               | 5               | 5               | 5               |

No arithmetic exception occurs under any circumstances.

#### **Restrictions:**

None

#### **Operation:**

```
\texttt{TEMP} \leftarrow \texttt{ACX}(_{\texttt{ACXBITS-6}}) \dots 0 \parallel \texttt{HI}_{\texttt{31..26}}
ACX ← TEMP<sub>ACXBITS..0</sub>
TEMP \leftarrow HI<sub>25..0</sub> || LO<sub>31..26</sub>
HI ← sign_extend(TEMP)
\text{TEMP}_{31\ldots 6} \leftarrow \text{LO}_{25\ldots 0}
BITSEL ← GPR[rt]<sub>29..25</sub>
\text{TEMP}_5 \leftarrow \text{GPR[rs]}_{\text{BITSEL}}
BITSEL \leftarrow GPR[rt]<sub>24..20</sub>
\text{TEMP}_4 \leftarrow \text{GPR[rs]}_{\text{BITSEL}}
BITSEL ← GPR[rt]<sub>19..15</sub>
\text{TEMP}_3 \leftarrow \text{GPR[rs]}_{\text{BITSEL}}
BITSEL \leftarrow GPR[rt]<sub>14..10</sub>
TEMP<sub>2</sub> ← GPR[rs]<sub>BITSEL</sub>
BITSEL \leftarrow GPR[rt]_{9..5}
\text{TEMP}_1 \leftarrow \text{GPR[rs]}_{\text{BITSEL}}
BITSEL \leftarrow GPR[rt]<sub>4..0</sub>
\text{TEMP}_0 \leftarrow \text{GPR[rs]}_{\text{BITSEL}}
LO \leftarrow sign\_extend(TEMP)
```

#### **Exceptions:**

None

MIPS® Architecture for Programmers Volume IV-d: The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00 53

SmartMIPS Crypto

| 31 |                   | 26 | 25  |       | 22 | 21            | 20 | 16 | 15 |    | 11 | 10 |    | 6 | 5 |               | 0       |    |
|----|-------------------|----|-----|-------|----|---------------|----|----|----|----|----|----|----|---|---|---------------|---------|----|
|    | SPECIAL<br>000000 |    |     | 0000  |    | <b>R</b><br>1 | rt |    |    | rd |    |    | sa |   |   | SRL<br>000010 |         |    |
|    | 6                 |    |     | 4     |    | 1             | 5  |    |    | 5  |    |    | 5  |   |   | 6             |         |    |
| l  | Format: RO'       | TR | rd, | rt, s | sa |               |    |    |    |    |    |    |    |   |   | SmartMI       | PS Cryp | to |

Purpose: Rotate Word Right

To execute a logical right-rotate of a word by a fixed number of bits

**Description:**  $GPR[rd] \leftarrow GPR[rt] \leftrightarrow (right)$  sa

The contents of the low-order 32-bit word of GPR *rt* are rotated right; the word result is placed in GPR *rd*. The bit-rotate amount is specified by *sa*.

#### **Restrictions:**

#### **Operation:**

```
if ((ArchitectureRevision() < 2) and (Config3<sub>SM</sub> = 0)) then

UNPREDICTABLE

endif

s \leftarrow sa

temp \leftarrow GPR[rt]_{s-1..0} \parallel GPR[rt]_{31..s}

GPR[rd] \leftarrow temp
```

#### **Exceptions:**

**Reserved Instruction** 

| 31                | 26 | 25 | 21 | 20 | 16 | 15 | 11 | 10 |      | 7 | 6      | 5 |                | 0 |
|-------------------|----|----|----|----|----|----|----|----|------|---|--------|---|----------------|---|
| SPECIAL<br>000000 |    | rs |    | rt |    | rd |    |    | 0000 |   | R<br>1 |   | SRLV<br>000110 |   |
| 6                 |    | 5  |    | 5  |    | 5  |    |    | 4    |   | 1      |   | 6              |   |

Format: ROTRV rd, rt, rs

Purpose: Rotate Word Right Variable

To execute a logical right-rotate of a word by a variable number of bits

**Description:** GPR[rd] ← GPR[rt] ↔ (right) GPR[rs]

The contents of the low-order 32-bit word of GPR *rt* are rotated right; the word result is placed in GPR *rd*. The bit-rotate amount is specified by the low-order 5 bits of GPR *rs*.

#### **Restrictions:**

#### **Operation:**

```
if ((ArchitectureRevision() < 2) and (Config3<sub>SM</sub> = 0)) then

UNPREDICTABLE

endif

s \leftarrow GPR[rs]_{4..0}

temp \leftarrow GPR[rt]_{s-1..0} \parallel GPR[rt]_{31..s}

GPR[rd] \leftarrow temp
```

#### **Exceptions:**

**Reserved Instruction** 

SmartMIPS Crypto

# The SmartMIPS® Release 3 Privileged Resource **Architecture**

### 6.1 Introduction

The MIPS Privileged Resource Architecture (PRA) defines a set of environments and capabilities on which the Instruction Set Architecture operates. This includes definitions of the programming interface and operation of the system coprocessor, CP0. SmartMIPS defines extensions to the MIPS PRA that are desirable in a smart card environment. This document describes these extensions. It is not intended to be a stand-alone PRA specification, and must be read in the context of the MIPS Architecture specification.

This chapter describes how the SmartMIPS ASE interacts with the Release 3 of the MIPS PRA.

An Appendix describes how the SmartMIPS ASE interacts with Release 2 and Release 1 of the MIPS PRA.

### 6.2 Overview

The SmartMIPS PRA extends the standard MIPS PRA in these specific regards:

- Virtual Memory Page Size
- Detection of SmartMIPS Features

The minimum virtual memory page size supported by the standard MIPS PRA is 4K (4096) bytes. SmartMIPS allows for the TLB to be configured to optimally support 4K, 2K, and 1K virtual memory pages, and to accelerate lookups of multilevel page tables.

The presence of SmartMIPS features is indicated in the CP0 Config3<sub>SM</sub> register field.

### 6.3 Compliance

Features described as Required in this document are required of all processors claiming compatibility with Smart-MIPS. Any features described as *Recommended* should be implemented unless there is an overriding need not to do so. Features described as *Optional* provide a standardization of features that may or may not be appropriate for a particular SmartMIPS processor implementation. If such a feature is implemented, it must be implemented as described in this document if a processor is to claim compatibility with SmartMIPS.

In some cases, there are features within features that have different levels of compliance. For example, if there is an *Optional* field within a *Required* register, this means that the register must be implemented, but the field may or may not be, depending on the needs of the implementation. Similarly, if there is a Required field within an Optional register, this means that if the register is implemented, it must have the specified field.

# 6.4 Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture

Some features that are included in the SmartMIPS ASE (e.g., 1KB page support) were implemented in Release 2 of the MIPS32 Architecture in such a way that there is conflict between the specifications. In such a case, the conflict is resolved in favor of the SmartMIPS ASE specification. That is, an implementation of the SmartMIPS ASE in a processor that also implements Release 2 of the MIPS32 Architecture obeys the rules of the SmartMIPS ASE whenever the specifications have a conflict.

For the 1KB page support, this means the Release 2 definition of that feature must not be implemented ( $Config3_{SP} = 0$ ) in an device that also implements SmartMIPS.

### 6.5 The SmartMIPS System Coprocessor

Except as defined below, the SmartMIPS system coprocessor interface and functionality is identical to MIPS32.

### 6.5.1 CP0 Register Summary

Table 6.1 lists the CP0 registers affected by the SmartMIPS specification, in numerical order. The individual registers are described later in this document. Otherwise the definition reverts to the standard MIPS PRA specification. The *Sel* column indicates the value to be used in the field of the same name in the MFC0 and MTC0 instructions.

| Register<br>Number | Sel | Register Name | Modification                                                                          | Reference     | Compliance<br>Level |
|--------------------|-----|---------------|---------------------------------------------------------------------------------------|---------------|---------------------|
| 5                  | 0   | PageMask      | Qualified by PageGrain register.                                                      | Section 6.7.1 | Required            |
| 5                  | 1   | PageGrain     | Controls granularity of virtual pages in EntryLo,<br>PageMask, and EntryHi registers. | Section 6.7.2 | Required            |
| 10                 | 0   | EntryHi       | Qualified by PageGrain register.                                                      | Section 6.7.3 | Required            |
| 16                 | 2   | Config3       | Identifies SmartMIPS feature set.                                                     | Section 6.7.4 | Required            |

Table 6.1 SmartMIPS Changes to Coprocessor 0 Registers in Numerical Order

### 6.6 Virtual Memory

### 6.6.1 TLB-Based Virtual Address Translation

This section describes the SmartMIPS changes and additions to the standard MIPS PRA TLB-based virtual address translation mechanism.

#### 6.6.1.1 Address Translation

The address translation process in SmartMIPS varies from the standard MIPS PRA address translation process in this regard:

• The number and position of the bits that form the virtual page number, physical page frame number, and page mask may vary from the standard MIPS PRA definition and provide 4K, 2K or 1K page granularity, depending on the state of the PageGrain register.

The modified TLB lookup process can be described as follows:

58 MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00

Copyright © 2004-2005, 2008, 2010 MIPS Technologies Inc. All rights reserved.

```
found \leftarrow 0
for i in 0...TLBEntries-1
             if((TLB[i]<sub>VPN2</sub> and not (TLB[i]<sub>Mask</sub>)) = (va_{31..11} and not (TLB[i]<sub>Mask</sub>))) and
               (\text{TLB[i]}_{G} \text{ or } (\text{TLB[i]}_{ASID} = \text{EntryHi}_{ASID})) then
                  # EvenOddBit selects between even and odd halves of the TLB as
                  # a function of the page size in the matching TLB entry
                  effective_mask = TLB[i]<sub>Mask</sub> OR (0 || PageGrain<sub>Mask</sub>)
                  case effective_mask
                      0000000000000000_2: EvenOddBit \leftarrow 10
                      000000000001_2: EvenOddBit \leftarrow 11
                      0000000000011_2: EvenOddBit \leftarrow 12
                      0000000001111<sub>2</sub>: EvenOddBit \leftarrow 14
                      00000000111111<sub>2</sub>: EvenOddBit \leftarrow 16
                      00000011111111_2: EvenOddBit \leftarrow 18
                      000011111111112: EvenOddBit \leftarrow 20
                      001111111111112: EvenOddBit \leftarrow 22
                      1111111111111112: EvenOddBit \leftarrow 24
                      otherwise: UNDEFINED
                  endcase
                  if va_{EvenOddBit} = 0 then
                      pfn ← TLB[i]<sub>PFN0</sub>
                      v ← TLB[i]<sub>V0</sub>
                      c \leftarrow TLB[i]_{C0}
                      d \leftarrow TLB[i]_{D0}
                      ri \leftarrow TLB[i]_{RTO}
                      xi \leftarrow TLB[i]_{XTO}
                  else
                      pfn \leftarrow TLB[i]<sub>PFN1</sub>
                      v \leftarrow \text{TLB[i]}_{V1}
                      c \leftarrow TLB[i]_{C1}
                      d \leftarrow TLB[i]_{D1}
                      ri \leftarrow TLB[i]_{RT1}
                      xi \leftarrow TLB[i]_{XT1}
                  endif
                  if v = 0 then
                      SignalException(TLBInvalid, reftype)
                  endif
                  if (ri = 1) and (reftype = load) then
                      if (xi = 0) and (IsPCRelativeLoad(PC))
                           # PC relative loads are allowed where execute is allowed
                      else
                           SignalException(TLBInvalid, reftype)
                      endif
                  endif
                  if (xi = 1) and (reftype = fetch) then
                      SignalException(TLBInvalid, reftype)
                  endif
                  if (d = 0) and (reftype = store) then
                      SignalException(TLBModified)
                  endif
                  case PageGrain_{Mask}
                      00<sub>2</sub>: pa_pfn ← 00<sub>2</sub> || pfn
                      01_2: pa_pfn \leftarrow 0_2 \parallel pfn \parallel 0_2
                      11<sub>2</sub>: pa_pfn \leftarrow pfn || 00<sub>2</sub>
                  endcase
                  # pa_pfn_{(PABITS-1)-10..0} corresponds to pa_{PABITS-1..10}
                  pa ← pa_pfn<sub>(PABITS-1)-10..EvenOddBit-10</sub> || va<sub>EvenOddBit-1..0</sub>
                  found \leftarrow 1
```

```
MIPS® Architecture for Programmers Volume IV-d: The SmartMIPS® Application-Specific Extension to the MIPS32® Architec-
ture, Revision 3.00 59
```

```
break
endif
endfor
if found = 0 then
SignalException(TLBMiss, reftype)
endif
```

Table 6.2 shows how the physical address is generated as a function of the page size of the TLB entry matching the virtual address. The "Even/Odd Select" column of the table indicates which virtual address bit is used to select between the even (*EntryLo0*) or odd (*EntryLo1*) entry in the matching TLB entry. The "PA generated from" column specifies how the physical address is generated from the selected PFN and the offset-in-page bits in the virtual address. PFN is the physical page number as loaded into the TLB from the *EntryLo0* or *EntryLo1* registers, and has the bit range PFN<sub>(PABITS-1)-12..0</sub>, corresponding to PA<sub>PABITS-1..12</sub>, PA<sub>PABITS-2..11</sub>, or PA<sub>PABITS-3..10</sub>, depending on the value of *PageGrain*<sub>Mask</sub>. Note that there are multiple combinations of *PageMask* and *PageGrain* that result in the same effective virtual page size.

The standard MIPS PRA might support page sizes larger than listed in Table 6.2. Those larger page sizes are allowed on SmartMIPS implementations as long as they don't interfere with support for 1KB, 2KB and 4KB pages.

| Page Size  | Even/Odd<br>Select | PageGrain<br>Mask value | PA <sub>(PABITS-1)0</sub> generated from                                      |
|------------|--------------------|-------------------------|-------------------------------------------------------------------------------|
| 1K Bytes   | VA <sub>10</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-120</sub>    VA <sub>090</sub>         |
| 2K Bytes   | VA <sub>11</sub>   | 002                     | $00_2 \parallel \text{PFN}_{(\text{PABITS-1})-121} \parallel \text{VA}_{100}$ |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-120} \parallel \text{VA}_{100}$  |
| 4K Bytes   | VA <sub>12</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-122</sub>    VA <sub>110</sub>         |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-121} \parallel \text{VA}_{110}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-120</sub>    VA <sub>110</sub>                            |
| 16K Bytes  | VA <sub>14</sub>   | 002                     | $00_2 \parallel \text{PFN}_{(\text{PABITS-1})-124} \parallel \text{VA}_{130}$ |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-123} \parallel \text{VA}_{130}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-122</sub>    VA <sub>130</sub>                            |
| 64K Bytes  | VA <sub>16</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-126</sub>    VA <sub>150</sub>         |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-125} \parallel \text{VA}_{150}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-124</sub>    VA <sub>150</sub>                            |
| 256K Bytes | VA <sub>18</sub>   | 002                     | $00_2 \parallel \text{PFN}_{(\text{PABITS-1})-128} \parallel \text{VA}_{170}$ |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{\text{(PABITS-1)-127}} \parallel \text{VA}_{170}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-126</sub>    VA <sub>170</sub>                            |
| 1M Bytes   | VA <sub>20</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-1210</sub>    VA <sub>190</sub>        |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{\text{(PABITS-1)-129}} \parallel \text{VA}_{190}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-128</sub>    VA <sub>190</sub>                            |

**Table 6.2 Physical Address Generation** 

| Page Size | Even/Odd<br>Select | PageGrain<br>Mask value | PA <sub>(PABITS-1)0</sub> generated from                                      |
|-----------|--------------------|-------------------------|-------------------------------------------------------------------------------|
| 4M Bytes  | VA <sub>22</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-1212</sub>    VA <sub>210</sub>        |
|           |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-1211} \parallel \text{VA}_{210}$ |
|           |                    | 112                     | PFN <sub>(PABITS-1)-1210</sub>    VA <sub>210</sub>                           |
| 16M Bytes | VA <sub>24</sub>   | 112                     | PFN <sub>(PABITS-1)-1212</sub>    VA <sub>230</sub>                           |

#### **Table 6.2 Physical Address Generation**

### 6.6.2 General Exception Processing

The SmartMIPS ASE modifies the exception processing in the following ways:

• The EntryHi contents varies according to the page granularity specified by the PageGrain register.

### 6.6.3 TLB Refill Exception

As in the standard MIPS PRA, a TLB refill exception occurs in a TLB-based MMU when no TLB entry matches a reference to a mapped address space and the EXL bit is zero in the Status register. SmartMIPS CPUs can differ from the standard MIPS PRA in the information provided on a TLB Refill exception in the EntryHi registers, depending on the page granularity supported.

|  | Table 6.3 | <b>TLB Refill</b> | Exception | <b>State Saved</b> | in Addition t | to the | Cause Register |
|--|-----------|-------------------|-----------|--------------------|---------------|--------|----------------|
|--|-----------|-------------------|-----------|--------------------|---------------|--------|----------------|

| Register State | Value                                                                                                                                                                                                                            |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BadVAddr       | Failing address                                                                                                                                                                                                                  |
| EntryHi        | Bits 31:13 contain $VA_{31:13}$ of the failing address. Bits 12:11 contain $VA_{12:11}$ ANDed with the compliment (logical negation) of <i>PageGrain<sub>Mask</sub></i> ; ASID field contains ASID of the reference that missed. |
| EntryLo0       | UNPREDICTABLE                                                                                                                                                                                                                    |
| EntryLo1       | UNPREDICTABLE                                                                                                                                                                                                                    |

### 6.6.4 TLB Invalid Exception

As in standard MIPS PRA, a TLB invalid exception occurs when a TLB entry matches a reference to a mapped address space, but the matched entry has the V (valid) bit off. SmartMIPS can differ from the standard MIPS PRA in the information provided on a TLB Invalid exception in the EntryHi register.

#### Table 6.4 TLB Invalid Exception State Saved in Addition to the Cause Register

| Register State | Value                                                                                                                                                                                                                        |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BadVAddr       | Failing address                                                                                                                                                                                                              |
| EntryHi        | Bits 31:13 contain $VA_{31:13}$ of the failing address. Bits 12:11 contain $VA_{12:11}$ ANDed with the compliment (logical negation) of <i>PageGrain<sub>Mask</sub></i> ; ASID field contains ASID of the invalid reference. |
| EntryLo0       | UNPREDICTABLE                                                                                                                                                                                                                |
| EntryLo1       | UNPREDICTABLE                                                                                                                                                                                                                |

### 6.6.5 TLB Modified Exception

As in standard MIPS PRA, TLB modified exception occurs on a *store* reference to a mapped address when the matching TLB entry is valid, but the entry's D bit is zero, indicating that the page is not writable. SmartMIPS CPUs can differ from the standard MIPS PRA in the information provided on a TLB Refill exception in the *EntryHi* register.

| Register State | Value                                                                                                                                                                                                                          |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BadVAddr       | Failing address                                                                                                                                                                                                                |
| EntryHi        | Bits 31:13 contain $VA_{31:13}$ of the failing address. Bits 12:11 contain $VA_{12:11}$ ANDed with the compliment (logical negation) of <i>PageGrain<sub>Mask</sub></i> ; ASID field contains ASID of the modifying reference. |
| EntryLo0       | UNPREDICTABLE                                                                                                                                                                                                                  |
| EntryLo1       | UNPREDICTABLE                                                                                                                                                                                                                  |

Table 6.5 TLB Modified Exception State Saved in Addition to the Cause Register

### 6.7 CP0 Registers

The CP0 registers provide the interface between the ISA and the Privileged Resource Architecture. Those CP0 registers that are extended or redefined for SmartMIPS relative to the MIPS Privileged Architecture reference are discussed below, with the registers presented in numerical order, first by register number, then by select field number.

### 6.7.1 PageMask Register (CP0 Register 5, Select 0)

Compliance Level: PageMask register modifications are Required for SmartMIPS MMUs.

As in the standard MIPS PRA, the *PageMask* register is a read/write register used for reading from and writing to the TLB. SmartMIPS allows implementation of page sizes smaller than 4K bytes, and the *PageMask* register must be extended to accommodate them, as shown in Table 6.7. To assure backward compatibility with the standard MIPS PRA, the *Mask* field extension bits 12 ad 11 can be inhibited and overridden by the corresponding bits of the *PageGrain* register. Inhibited *PageMask* bits are treated as 1 bits for the purposes of virtual address translation - the corresponding virtual address bits are not used for TLB match comparisons - but read as zeroes to software to preserve backward compatibility.

Figure 6.1 shows the format of the PageMask register; Table 6.6 describes the PageMask register fields.

| rigure 0.1 Sinartimir 5 Pagemask Register i Ormat |         |      |  |  |  |  |  |
|---------------------------------------------------|---------|------|--|--|--|--|--|
| 31 23                                             | 5 24 11 | 10 0 |  |  |  |  |  |
| 0                                                 | Mask    | 0    |  |  |  |  |  |

#### Figure 6.1 SmartMIPS PageMask Register Format

| Fields |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Read / |                                                    |            |  |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------|------------|--|
| Name   | Bits           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Write  | Reset State                                        | Compliance |  |
| Mask   | 24:11          | The <i>Mask</i> field is a bit mask in which a "1" bit indicates<br>that the corresponding bit of the virtual address should not<br>participate in the TLB match.<br>Bits 12 and 11 of the <i>Mask</i> field can be overridden by the<br><i>Mask</i> field of the <i>PageGrain</i> register: If set in the<br><i>PageGrain</i> register, the corresponding bit in the<br><i>PageMask</i> register is unwritable and reads as a zero to<br>software, but the corresponding bit is excluded from<br>address comparison as if it were set in the <i>PageMask</i><br><i>Mask</i> field. | R/W    | 0 for bits<br>121; Unde-<br>fined for bits<br>2413 | Required   |  |
| 0      | 31:25,<br>10:0 | Must be written as zero; return zero on read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0      | 0                                                  | Reserved   |  |

#### Table 6.6 PageMask Register Field Descriptions

Table 6.7 Values for the Mask Field of the PageMask Register

|            | Bit |    |    |    |    |    |    |    |    |    |    |    |     |     |
|------------|-----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|
| Page Size  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12* | 11* |
| 1 KBytes   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   |
| 2 KBytes   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 1   |
| 4 KBytes   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1   | 1   |
| 16 KBytes  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1   | 1   |
| 64 KBytes  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1   | 1   |
| 256 KBytes | 0   | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1   |
| 1 MByte    | 0   | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1   |
| 4 MByte    | 0   | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1   |
| 16 Mbyte   | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1   |

The columns marked with an asterix (\*) are those which can be disabled and overridden by the PageGrain register.

It is implementation-dependent how many of the encodings described in Table 6.7 are implemented. All processors must implement the 4KB page size, and the implemented Mask bits must span the contiguous range of values from 4KB to the smallest page granularity that can be specified by the implemented PageGrain register. If a particular page size encoding is not implemented by a processor, a read of the *PageMask* register must return zeros in all bits that correspond to encodings that are not implemented. Software can determine which page sizes are supported by writing the encoding for a 16MB page to the PageMask register, then examine the value returned from a read of the PageMask register. If a pair of bits reads back as ones, the processor implements that page size. The operation of the processor is UNDEFINED if software loads the PageMask register with a value other than one of those listed in Table 6.7.

The standard MIPS PRA might support page sizes larger than listed in Table 6.7. Those larger page sizes are allowed on SmartMIPS implementations as long as they don't interfere with support for 1KB, 2KB and 4KB pages.

The value of the *PageMask* register is **UNPREDICTABLE** following a modification of the contents of the *PageGrain* register.

### 6.7.2 PageGrain Register (CP0 Register 5, Select 1)

**Compliance Level:** *Required* for SmartMIPS MMUs. Optional for Release 2 (and subsequent) of the standard MIPS PRA.

The *PageGrain* register is a read/write register used to configure the SmartMIPS MMU to operate on pages smaller than 4K bytes. It's value is used when reading from and writing to the TLB. SmartMIPS allows implementation of page sizes smaller than 4K bytes, and in those implementations, the *PageMask* register must be extended to accommodate them, as shown in Table 6.7. The *PageGrain* register also contains enable bits for the read-inhibit (*RI*) and execute-inhibit (*XI*) bits of the *EntryLo* registers.

It is not required that the contents of the *PageGrain* register be reflected in the contents of the TLB. Therefore, the TLB must be flushed before any change to the *PageGrain* register is made. The operation of the processor is **UNDE-FINED** if software modifies any field of the *PageGrain* register while valid entries are present in the TLB.

Figure 6.2 shows the format of the PageGrain register; Table 6.6 describes the PageGrain register fields.

#### Figure 6.2 SmartMIPS PageGrain Register Format

| 31  | 30  | 29 | 13 | 12 11 | 10 8 | 7 | 0 |
|-----|-----|----|----|-------|------|---|---|
| RIE | XIE | 0  |    | Mask  | 111  | 0 |   |

| Fields |      |                                                                                                                                                                                                                 | Read / | Reset |            |  |
|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|------------|--|
| Name   | Bits | Description                                                                                                                                                                                                     | Write  | State | Compliance |  |
| RIE    | 31   | Read Inhibit Enable. If this bit is set, the <i>RI</i> bit of the <i>EntryLoO</i> and <i>EntryLo1</i> registers is enabled. If the bit is clear, the <i>RI</i> bit is disabled and not writable by software.    | R/W    | 0     | Required   |  |
| XIE    | 30   | Execute Inhibit Enable. If this bit is set, the <i>XI</i> bit of the <i>EntryLo0</i> and <i>EntryLo1</i> registers is enabled. If the bit is clear, the <i>XI</i> bit is disabled and not writable by software. | R/W    | 0     | Required   |  |

#### Table 6.8 SmartMIPS PageGrain Register Field Descriptions

| Fields |               |                                                                                                                                                                                                                                                                                                                 | Read / | Reset |            |
|--------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|------------|
| Name   | Bits          | Description                                                                                                                                                                                                                                                                                                     | Write  | State | Compliance |
| Mask   | 12:11         | Determines whether the corresponding bits of a virtual address<br>are to be used for address translation purposes. This affects the<br>behavior of the <i>EntryLo0/EntryLo1</i> , <i>EntryHi</i> , and <i>PageMask</i><br>registers according to the following scheme:                                          | R/W    | 11    | Required   |
|        |               | 00 Bits 12 and 11 of <i>PageMask</i> and <i>EntryHi</i> are R/W to software and used in address translation. <i>PFN</i> field of <i>EntryLo0/EntryLo1</i> is treated as PA <sub>PABITS-310</sub>                                                                                                                |        |       |            |
|        |               | <ul> <li>0 1 Bit 12 of PageMask and EntryHi is R/W to software and used in address translation. Bit 11 of PageMask and EntryHi reads as zero, and is not used in address translation.</li> <li>PFN field of EntryLo0/EntryLo1 is treated as PA<sub>PABITS-211</sub></li> </ul>                                  |        |       |            |
|        |               | <ul> <li>Bits 12 and 11 of <i>PageMask</i> and <i>EntryHi</i> read as zero, and are not used in address translation. <i>PFN</i> field of <i>EntryLo0/EntryLo1</i> is treated as PA<sub>PABITS-112</sub>. In this setting, virtual address translation is identical to that of the standard MIPS PRA.</li> </ul> |        |       |            |
|        |               | 10 UNDEFINED                                                                                                                                                                                                                                                                                                    |        |       |            |
| 1      | 10:8          | Reserved bits for future <i>Mask</i> expansion. Must be written as one, return one on read.                                                                                                                                                                                                                     |        |       |            |
| 0      | 29:13,<br>7:0 | Must be written as zero; return zero on read.                                                                                                                                                                                                                                                                   | 0      | 0     | Reserved   |

#### Table 6.8 SmartMIPS PageGrain Register Field Descriptions

It is not required that all bits of the PageGrain Mask field be fully implemented. Unimplemented low-order bits must be read-only, and must read and function as having a value of 1. Unimplemented high-order bits must read and function as having the same value as the highest-order implemented bit. Table 6.9 shows some the read/write and functional behavior of the possible SmartMIPS PageGrain subsets.

#### Table 6.9 PageGrain Implementation Subset Behavior

| Subset                              | Mask Value<br>Written | Mask Value Read<br>Back | Page<br>Granularity |
|-------------------------------------|-----------------------|-------------------------|---------------------|
| 2K Byte Page                        | 0 0                   | 0 1                     | 2K Bytes            |
| Grain but not 1K<br>Byte Page Grain | 0 1                   | 0 1                     | 2K Bytes            |
| byte ruge Grunn                     | 1 0                   | 11                      | 4K Bytes            |
|                                     | 11                    | 11                      | 4K Bytes            |
| 1K Byte Page                        | 0 0                   | 0 0                     | 1K Bytes            |
| Grain but not 2K<br>Byte Page Grain | 0 1                   | 11                      | 4K Bytes            |
| 2 j të 1 ugë Gruin                  | 1 0                   | 0 0                     | 1K Bytes            |
|                                     | 1 1                   | 11                      | 4K Bytes            |

### 6.7.3 EntryHi Register (CP0 Register 10, Select 0

**Compliance Level:** *EntryHi* register modifications are *Required* for SmartMIPS MMUs. Modifications optional in Release 2 (and subsequent) of the standard MIPS PRA.

As in the standard MIPS PRA, the *EntryHi* register contains the virtual address match information used for TLB read, write, and access operations.

For SmartMIPS implementations supporting pages sizes smaller than 4K, the *VPN2* field of *EntryHi* must be extended to allow for the greater number of VPNs in an address space divided into smaller pages. A similar optional feature was added to Release 2 (and subsequent) of the standard MIPS Privileged Resource Architecture.

Figure 6.3 shows the format of the modified SmartMIPS *EntryHi* register; Table 6.10 describes the *EntryHi* register fields.

#### Figure 6.3 SmartMIPS EntryHi Register Format

| 31   | 11 | 10 | 8 | 7 0  |
|------|----|----|---|------|
| VPN2 |    | 0  |   | ASID |

#### Table 6.10 EntryHi Register Field Descriptions

| Fields |       |                                                                                                                                                                                                                                                                                                                          | Read / |                                               |            |
|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------|------------|
| Name   | Bits  | Description                                                                                                                                                                                                                                                                                                              | Write  | Reset State                                   | Compliance |
| VPN2   | 31:11 | $VA_{31:11}$ of the virtual address (virtual page number / 2).<br>This field is written by hardware on a TLB exception or<br>on a TLB read, and is written by software before a TLB<br>write. Bits 12 and 11 can take a non-zero value only if<br>the corresponding bits of the <i>PageGrain</i> register are<br>zeroes. | R/W    | 0 for bits 121;<br>Undefined for<br>bits 3113 | Required   |
| ASID   | 7:0   | ASID. Unchanged from the standard MIPS PRA                                                                                                                                                                                                                                                                               | R/W    | Undefined                                     | Required   |
| 0      | 10:8  | Must be written as zero; returns zero on read.                                                                                                                                                                                                                                                                           | 0      | 0                                             | Reserved   |

The value of the *EntryHi* register is **UNPREDICTABLE** following a modification of the contents of the *PageGrain* register.

### 6.7.4 Configuration Register 3 (CP0 Register 16, Select 3)

Compliance Level: *Required* for SmartMIPS.

The *Config3* register is fully defined in Volume III of this multi-volume set. Bit 1 (named *SM*) of the *Config3* register denotes the presence of the SmartMIPS ASE.

# The SmartMIPS® Release 2 Privileged Resource **Architecture**

### A.1 Introduction

This appendix describes how the SmartMIPS ASE interacts with the older Release 2 and Release 1 of the MIPS PRA.

The MIPS Privileged Resource Architecture (PRA) defines a set of environments and capabilities on which the Instruction Set Architecture operates. This includes definitions of the programming interface and operation of the system coprocessor, CP0. SmartMIPS defines extensions to the MIPS PRA that are desirable in a smart card environment. This document describes these extensions. It is not intended to be a stand-alone PRA specification, and must be read in the context of the MIPS Architecture specification.

### A.2 Overview

The SmartMIPS PRA extends the standard MIPS PRA in these specific regards:

- Protection of Virtual Memory Pages
- Virtual Memory Page Size
- Increase the usability of the Context Register as a pointer to Page Tables ٠
- Detection of SmartMIPS Features

The standard MIPS PRA provides for Virtual memory pages to be invalid, readable and executable, or readable, executable, and writable. SmartMIPS extends this to allow true read-only, execute-only, and write-only pages.

The minimum virtual memory page size supported by the standard MIPS PRA is 4K (4096) bytes. SmartMIPS allows for the TLB to be configured to optimally support 4K, 2K, and 1K virtual memory pages, and to accelerate lookups of multilevel page tables.

The presence of SmartMIPS features is indicated in the CP0 Config3<sub>SM</sub> register field.

### A.3 Compliance

Features described as *Required* in this document are required of all processors claiming compatibility with Smart-MIPS. Any features described as *Recommended* should be implemented unless there is an overriding need not to do so. Features described as Optional provide a standardization of features that may or may not be appropriate for a particular SmartMIPS processor implementation. If such a feature is implemented, it must be implemented as described in this document if a processor is to claim compatibility with SmartMIPS.

MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00 67

Copyright © 2004-2005, 2008, 2010 MIPS Technologies Inc. All rights reserved.

In some cases, there are features within features that have different levels of compliance. For example, if there is an *Optional* field within a *Required* register, this means that the register must be implemented, but the field may or may not be, depending on the needs of the implementation. Similarly, if there is a *Required* field within an *Optional* register, this means that if the register is implemented, it must have the specified field.

# A.4 Interaction between the SmartMIPS ASE and Release 2 of the MIPS32 Architecture

Some features that are included in the SmartMIPS ASE (e.g., the ROTR and ROTRV) were subsequently added to Release 2 of the MIPS32 Architecture. In such cases, the features are implemented identically.

Some features that are included in the SmartMIPS ASE (e.g., 1KB page support) were implemented in Release 2 of the MIPS32 Architecture in such a way that there is conflict between the specifications. In such a case, the conflict is resolved in favor of the SmartMIPS ASE specification. That is, an implementation of the SmartMIPS ASE in a processor that also implements Release 2 of the MIPS32 Architecture obeys the rules of the SmartMIPS ASE whenever the specifications have a conflict.

For the 1KB page support, this means the Release 2 definition of that feature must not be implemented ( $Config3_{SP} = 0$ ) in an device that also implements SmartMIPS.

### A.5 The SmartMIPS System Coprocessor

Except as defined below, the SmartMIPS system coprocessor interface and functionality is identical to MIPS32.

### A.5.1 CP0 Register Summary

Table A.1 lists the CP0 registers affected by the SmartMIPS specification, in numerical order. The individual registers are described later in this document. Otherwise the definition reverts to the standard MIPS PRA specification. The *Sel* column indicates the value to be used in the field of the same name in the MFC0 and MTC0 instructions.

| Register<br>Number | Sel | Register Name | Modification                                                                                                                          | Reference     | Compliance<br>Level |
|--------------------|-----|---------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------------|
| 2                  | 0   | EntryLo0      | Two additional bits per page to provide greater vari-<br>ety of access modes. PFN field definition modified<br>by PageGrain register. | Section A.7.1 | Required            |
| 3                  | 0   | EntryLo1      | Two additional bits per page to provide greater vari-<br>ety of access modes.PFN field definition modified by<br>PageGrain register.  | Section A.7.1 | Required            |
| 4                  | 0   | Context       | Layout controlled by ContextConfig. Only applies to PRA Release 2 and older.                                                          | Section A.7.2 | Required            |
| 4                  | 1   | ContextConfig | New Register. Controls layout of Context register.<br>Only applies to PRA Release 2 and older.                                        | Section A.7.3 | Required            |
| 5                  | 0   | PageMask      | Qualified by PageGrain register.                                                                                                      | Section A.7.4 | Required            |
| 5                  | 1   | PageGrain     | New register. Controls granularity of virtual pages in EntryLo, PageMask, and EntryHi registers.                                      | Section A.7.5 | Required            |
| 10                 | 0   | EntryHi       | Qualified by PageGrain register.                                                                                                      | Section A.7.6 | Required            |

Table A.1 SmartMIPS Changes to Coprocessor 0 Registers in Numerical Order

| Register<br>Number | Sel | Register Name | Modification                      | Reference     | Compliance<br>Level |
|--------------------|-----|---------------|-----------------------------------|---------------|---------------------|
| 16                 | 2   | Config3       | Identifies SmartMIPS feature set. | Section A.7.7 | Required            |

#### Table A.1 SmartMIPS Changes to Coprocessor 0 Registers in Numerical Order

### A.6 Virtual Memory

### A.6.1 TLB-Based Virtual Address Translation

This section describes the SmartMIPS changes and additions to the standard MIPS PRA TLB-based virtual address translation mechanism.

#### A.6.1.1 TLB Organization

SmartMIPS extends the TLB organization defined by the standard MIPS Privileged Resource Architecture. The size of the field containing the virtual page number in the comparison section must accommodate a wider range of virtual page sizes. In all profiles, the translation section is augmented by two additional bits, RI (Read Inhibit) and XI (Execute Inhibit), which can be thought of as qualifiers for the existing V (Valid) bit. There are still two entries in the translation section for each TLB entry, because each TLB entry maps an aligned pair of virtual pages, and the pair of physical translation entries corresponds to the even and odd pages of the pair. Figure A.1 shows the logical arrangement of a TLB entry.



Figure A.1 Contents of a TLB Entry

The fields of the TLB entry still correspond exactly to the fields in the CPO PageMask, EntryHo, EntryLo0 and EntryLo1 registers. The even page entries in the TLB (e.g., PFN0) come from EntryLo0. Similarly, odd page entries come from EntryLo1.

#### A.6.1.2 Address Translation

The address translation process in SmartMIPS varies from the standard MIPS PRA address translation process in two specific regards:

- The number and position of the bits that form the virtual page number, physical page frame number, and page mask may vary from the standard MIPS PRA definition and provide 4K, 2K or 1K page granularity, depending on the state of the PageGrain register.
- The RI and XI bits serve to inhibit the V (Valid) bit for Read and Instruction Fetch accesses respectively. Fetching instructions from a page with the XI bit set will generate a TLB Invalid exception even if the V bit is set. Similarly, attempting to load data from a page with the RI bit set will generate a TLB Invalid exception even if

the V bit is set. The set of the RI, XI, D, and V bits allows for any combination of read/write/execute protections to be enforced by hardware.

The modified TLB lookup process can be described as follows:

```
found \leftarrow 0
for i in 0...TLBEntries-1
             if((TLB[i]<sub>VPN2</sub> and not (TLB[i]<sub>Mask</sub>)) = (va_{31..11} and not (TLB[i]<sub>Mask</sub>))) and
               (\text{TLB[i]}_{G} \text{ or } (\text{TLB[i]}_{ASID} = \text{EntryHi}_{ASID})) then
                 # EvenOddBit selects between even and odd halves of the TLB as
                 # a function of the page size in the matching TLB entry
                 effective_mask = TLB[i]<sub>Mask</sub> OR (0 || PageGrain<sub>Mask</sub>)
                 case effective_mask
                      0000000000000000_2: EvenOddBit \leftarrow 10
                      000000000001_2: EvenOddBit \leftarrow 11
                      000000000011_2: EvenOddBit \leftarrow 12
                      0000000001111<sub>2</sub>: EvenOddBit \leftarrow 14
                      0000000111111_2: EvenOddBit \leftarrow 16
                      000000111111112: EvenOddBit ← 18
                      00001111111111_2: EvenOddBit \leftarrow 20
                      001111111111112: EvenOddBit \leftarrow 22
                      1111111111111112: EvenOddBit \leftarrow 24
                      otherwise: UNDEFINED
                 endcase
                 if va_{EvenOddBit} = 0 then
                     pfn ← TLB[i]<sub>PFN0</sub>
                     v \leftarrow TLB[i]_{v0}
                     c \leftarrow TLB[i]_{C0}
                     d \leftarrow TLB[i]_{D0}
                     ri \leftarrow TLB[i]_{RTO}
                     xi \leftarrow TLB[i]_{XI0}
                 else
                     pfn \leftarrow TLB[i]<sub>PFN1</sub>
                     v \leftarrow \texttt{TLB[i]}_{V1}
                     c \leftarrow TLB[i]_{C1}
                     d \leftarrow TLB[i]_{D1}
                     ri \leftarrow TLB[i]_{RI1}
                     xi \leftarrow TLB[i]_{XI1}
                 endif
                 if v = 0 then
                      SignalException(TLBInvalid, reftype)
                 endif
                 if (ri = 1) and (reftype = load) then
                      if (xi = 0) and (IsPCRelativeLoad(PC))
                          # PC relative loads are allowed where execute is allowed
                      else
                          SignalException(TLBInvalid, reftype)
                      endif
                 endif
                 if (xi = 1) and (reftype = fetch) then
                      SignalException(TLBInvalid, reftype)
                 endif
                 if (d = 0) and (reftype = store) then
                      SignalException (TLBModified)
                 endif
                 case PageGrain_{Mask}
                      00_2: pa_pfn \leftarrow 00_2 \parallel pfn
                      01_2: pa_pfn \leftarrow 0_2 \parallel pfn \parallel 0_2
```

```
11<sub>2</sub>: pa_pfn ← pfn || 00<sub>2</sub>
                  endcase
                  # pa_pfn_{(PABITS-1)-10..0} corresponds to pa_{PABITS-1..10}
                  pa ← pa_pfn<sub>(PABITS-1)-10..EvenOddBit-10</sub> || va<sub>EvenOddBit-1..0</sub>
                  found \leftarrow 1
                 break
             endif
endfor
if found = 0 then
             SignalException(TLBMiss, reftype)
endif
```

Table A.2 shows how the physical address is generated as a function of the page size of the TLB entry matching the virtual address. The "Even/Odd Select" column of the table indicates which virtual address bit is used to select between the even (EntryLo0) or odd (EntryLo1) entry in the matching TLB entry. The "PA generated from" column specifies how the physical address is generated from the selected PFN and the offset-in-page bits in the virtual address. PFN is the physical page number as loaded into the TLB from the EntryLo0 or EntryLo1 registers, and has the bit range PFN(PABITS-1)-12..0, corresponding to PAPABITS-1..12, PAPABITS-2..11, or PAPABITS-3..10, depending on the value of PageGrainMask. Note that there are multiple combinations of PageMask and PageGrain that result in the same effective virtual page size.

| Page Size  | Even/Odd<br>Select | PageGrain<br>Mask value | PA <sub>(PABITS-1)0</sub> generated from                                      |
|------------|--------------------|-------------------------|-------------------------------------------------------------------------------|
| 1K Bytes   | VA <sub>10</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-120</sub>    VA <sub>090</sub>         |
| 2K Bytes   | VA <sub>11</sub>   | 002                     | $00_2 \parallel \text{PFN}_{(\text{PABITS-1})-121} \parallel \text{VA}_{100}$ |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-120} \parallel \text{VA}_{100}$  |
| 4K Bytes   | VA <sub>12</sub>   | 002                     | $00_2 \parallel \text{PFN}_{(\text{PABITS-1})-122} \parallel \text{VA}_{110}$ |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-121} \parallel \text{VA}_{110}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-120</sub>    VA <sub>110</sub>                            |
| 16K Bytes  | VA <sub>14</sub>   | 002                     | $00_2 \parallel \text{PFN}_{(\text{PABITS-1})-124} \parallel \text{VA}_{130}$ |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-123} \parallel \text{VA}_{130}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-122</sub>    VA <sub>130</sub>                            |
| 64K Bytes  | VA <sub>16</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-126</sub>    VA <sub>150</sub>         |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-125} \parallel \text{VA}_{150}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-124</sub>    VA <sub>150</sub>                            |
| 256K Bytes | VA <sub>18</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-128</sub>    VA <sub>170</sub>         |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{\text{(PABITS-1)-127}} \parallel \text{VA}_{170}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-126</sub>    VA <sub>170</sub>                            |
| 1M Bytes   | VA <sub>20</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-1210</sub>    VA <sub>190</sub>        |
|            |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-129} \parallel \text{VA}_{190}$  |
|            |                    | 112                     | PFN <sub>(PABITS-1)-128</sub>    VA <sub>190</sub>                            |

**Table A.2 Physical Address Generation** 

| Page Size | Even/Odd<br>Select | PageGrain<br>Mask value | PA <sub>(PABITS-1)0</sub> generated from                                      |
|-----------|--------------------|-------------------------|-------------------------------------------------------------------------------|
| 4M Bytes  | VA <sub>22</sub>   | 002                     | 00 <sub>2</sub>    PFN <sub>(PABITS-1)-1212</sub>    VA <sub>210</sub>        |
|           |                    | 012                     | $0_2 \parallel \text{PFN}_{(\text{PABITS-1})-1211} \parallel \text{VA}_{210}$ |
|           |                    | 112                     | PFN <sub>(PABITS-1)-1210</sub>    VA <sub>210</sub>                           |
| 16M Bytes | VA <sub>24</sub>   | 112                     | PFN <sub>(PABITS-1)-1212</sub>    VA <sub>230</sub>                           |

#### Table A.2 Physical Address Generation

### A.6.2 General Exception Processing

The SmartMIPS ASE modifies the exception processing in the following ways:

- TLB Refill, TLB Invalid, and TLB Modified exceptions, where new qualifying conditions exist for virtual pages to be considered to be valid.
- The setup of the Context register is now configurable by the ContextConfig register.
- The EntryHi contents varies according to the page granularity specified by the PageGrain register.

### A.6.3 TLB Refill Exception

As in the standard MIPS PRA, a TLB refill exception occurs in a TLB-based MMU when no TLB entry matches a reference to a mapped address space and the *EXL* bit is zero in the *Status* register. SmartMIPS CPUs can differ from the standard MIPS PRA in the information provided on a TLB Refill exception in the *Context* and *EntryHi* registers, depending on the *Context* register configuration and the page granularity supported.

| Register State | Value                                                                                                                                                                                                                            |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BadVAddr       | Failing address                                                                                                                                                                                                                  |
| Context        | The bits of the <i>Context</i> register corresponding to the set bits of the <i>VirtualIndex</i> field of the <i>ContextConfig</i> register are loaded with the high-order bits of the virtual address that missed.              |
| EntryHi        | Bits 31:13 contain $VA_{31:13}$ of the failing address. Bits 12:11 contain $VA_{12:11}$ ANDed with the compliment (logical negation) of <i>PageGrain<sub>Mask</sub></i> ; ASID field contains ASID of the reference that missed. |
| EntryLo0       | UNPREDICTABLE                                                                                                                                                                                                                    |
| EntryLo1       | UNPREDICTABLE                                                                                                                                                                                                                    |

### A.6.4 TLB Invalid Exception

As in standard MIPS PRA, a TLB invalid exception occurs when a TLB entry matches a reference to a mapped address space, but the matched entry has the V (valid) bit off. On a SmartMIPS CPU, however, if a valid, matching TLB entry is found with the RI (Read Inhibit) set on a read reference, or with XI (Execute Inhibit) set on an instruction fetch reference, a TLB Invalid exception will occur despite the presence of the valid bit. MIPS16 PC-relative
loads are a special case, and are not affected by the RI bit. In addition, SmartMIPS can differ fro the standard MIPS PRA in the information provided on a TLB Invalid exception in the Context and EntryHi registers.

| Register State | Value                                                                                                                                                                                                                        |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BadVAddr       | Failing address                                                                                                                                                                                                              |
| Context        | The bits of the <i>Context</i> register corresponding to the set bits of the <i>VirtualIndex</i> field of the <i>ContextConfig</i> register are loaded with the high-order bits of the invalid virtual address.              |
| EntryHi        | Bits 31:13 contain $VA_{31:13}$ of the failing address. Bits 12:11 contain $VA_{12:11}$ ANDed with the compliment (logical negation) of <i>PageGrain<sub>Mask</sub></i> ; ASID field contains ASID of the invalid reference. |
| EntryLo0       | UNPREDICTABLE                                                                                                                                                                                                                |
| EntryLo1       | UNPREDICTABLE                                                                                                                                                                                                                |

Table A.4 TLB Invalid Exception State Saved in Addition to the Cause Register

## A.6.5 TLB Modified Exception

As in standard MIPS PRA, TLB modified exception occurs on a store reference to a mapped address when the matching TLB entry is valid, but the entry's D bit is zero, indicating that the page is not writable. SmartMIPS CPUs can differ from the standard MIPS PRA in the information provided on a TLB Refill exception in the Context and EntryHi registers.

| Table A.5 | TLB Modified | Exception | State Saved in | Addition to the | e Cause Register |
|-----------|--------------|-----------|----------------|-----------------|------------------|
|-----------|--------------|-----------|----------------|-----------------|------------------|

| Register State | Value                                                                                                                                                                                                                          |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BadVAddr       | Failing address                                                                                                                                                                                                                |
| Context        | The bits of the <i>Context</i> register corresponding to the set bits of the <i>VirtualIndex</i> field of the <i>ContextConfig</i> register are loaded with the high-order bits of the virtual address being written.          |
| EntryHi        | Bits 31:13 contain $VA_{31:13}$ of the failing address. Bits 12:11 contain $VA_{12:11}$ ANDed with the compliment (logical negation) of <i>PageGrain<sub>Mask</sub></i> ; ASID field contains ASID of the modifying reference. |
| EntryLo0       | UNPREDICTABLE                                                                                                                                                                                                                  |
| EntryLo1       | UNPREDICTABLE                                                                                                                                                                                                                  |

## A.7 CP0 Registers

The CP0 registers provide the interface between the ISA and the Privileged Resource Architecture. Those CP0 registers that are extended or redefined for SmartMIPS relative to the MIPS Privileged Architecture reference are discussed below, with the registers presented in numerical order, first by register number, then by select field number.

## A.7.1 EntryLo0, EntryLo1 (CP0 Registers 2 and 3, Select 0)

Compliance Level: EntryLo0 modifications are Required for a SmartMIPS MMU.

**Compliance Level:** *EntryLo1* modifications are *Required* for a SmartMIPS MMU.

As in the standard MIPS PRA, the pair of *EntryLo* registers act as the interface between the TLB and the TLBR, TLBWI, and TLBWR instructions. EntryLo0 holds the entries for even pages and EntryLo1 holds the entries for odd pages.

In a SmartMIPS MMU, the previously reserved bits 31 and 30 are defined for further access control.

The interpretation, though not the size or location, of the PFN field in a SmartMIPS MMU varies with the content of the PageGrain register.

Figure A.2 shows the format of the *EntryLo0* and *EntryLo1* registers; Table A.6 describes the *EntryLo0* and *EntryLo1* register fields.

### Figure A.2 SmartMIPS EntryLo0, EntryLo1 Register Format

| 31 | 30 | 29 6 | 5 | 3 | 2 | 1 | 0 |
|----|----|------|---|---|---|---|---|
| RI | XI | PFN  |   | С | D | v | G |

### Table A.6 SmartMIPS EntryLo0, EntryLo1 Register Field Descriptions

| Fields |      | Poad /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Posot |       |            |
|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|------------|
| Name   | Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Write | State | Compliance |
| RI     | 31   | Read Inhibit. If this bit is set in a TLB entry, an attempt,<br>other than a MIPS16 PC-relative load, to read data on the<br>virtual page causes a TLB Invalid exception, even if the V<br>(Valid) bit is set. The <i>RI</i> bit is writable only if the <i>RIE</i> bit of<br>the <i>PageGrain</i> register is set. If the <i>RIE</i> bit of <i>PageGrain</i> is<br>not set, the <i>RI</i> bit of <i>EntryLOO/EntryLO1</i> is set to zero on any<br>write to the register, regardless of the value written. | R/W   | 0     | Required   |
| XI     | 30   | Execute Inhibit. If this bit is set in a TLB entry, an attempt to fetch an instruction or to load MIPS16 PC-relative data from the virtual page causes a TLB Invalid exception, even if the V (Valid) bit is set. The XI bit is writable only if the XIE bit of the PageGrain register is set. If the XIE bit of PageGrain is not set, the XI bit of EntryLo0/EntryLo1 is set to zero on any write to the register, regardless of the value written.                                                        | R/W   | 0     | Required   |

| Fields |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Poad / | Posot     |            |
|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|------------|
| Name   | Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Write  | State     | Compliance |
| PFN    | 29:6 | Up to 24 bits of the physical address associated with the page.<br>The binding of <i>PFN</i> bits to physical address bits depends on<br>the value of the <i>Mask</i> field of the <i>PageGrain</i> register:<br><i>PageGrain</i> <sub>Mask</sub> = 0 0: PFN corresponds to $PA_{PABITS-310}$<br><i>PageGrain</i> <sub>Mask</sub> = 0 1: PFN corresponds to $PA_{PABITS-211}$<br><i>PageGrain</i> <sub>Mask</sub> = 1 1: PFN corresponds to $PA_{PABITS-112}$<br><i>PageGrain</i> <sub>Mask</sub> = 1 0: <b>UNDEFINED</b><br>The width of this field implicitly limits the range of physical<br>addresses to 36 bits, 35 bits, or 34 bits for minimum page<br>sizes of 4K, 2K, and 1K bytes respectively. If the processor<br>implements fewer physical address bits than this limit, the<br>unimplemented bits must be written as zero, and return zero<br>on read. If the processor implements more physical address<br>bits than are defined by <i>PFN</i> , given a non-zero value of<br><i>PageGrain</i> <sub>Mask</sub> , the bits to the left of the MSB of <i>PFN</i> are<br>zero in the generated physical address.<br>Starting with Release 2, the standard MIPS Privileged<br>Resource Architecture supports the above meanings of<br><i>PageGrain</i> <sub>Mask</sub> = 0 0 and <i>PageGrain</i> <sub>Mask</sub> = 1 1. | R/W    | Undefined | Required   |
| C      | 5:3  | Coherency attribute. Unchanged from MIPS32.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |           |            |
| D      | 2    | "Dirty" bit. Unchanged from MIPS32.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |           |            |
| V      | 1    | Valid bit, indicating that the TLB entry, and thus the virtual page mapping are valid. If this bit is a one, accesses to the page are permitted. If this bit is a zero, accesses to the page cause a TLB Invalid exception. In SmartMIPS this bit is further qualified by the <i>RI</i> and <i>XI</i> bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R/W    | Undefined | Required   |
| G      | 0    | Global bit. Unchanged from MIPS32.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |           |            |

## Table A.6 SmartMIPS EntryLo0, EntryLo1 Register Field Descriptions

## A.7.2 Context Register (CP0 Register 4, Select 0)

Compliance Level: Context register modifications are Required for a SmartMIPS MMU.

In SmartMIPS, the Context register is a read/write register containing a pointer to an arbitrary power-of-two aligned data structure in memory, such as an entry in the page table entry (PTE) array. Unlike the standard MIPS PRA, where this pointer was defined to reference a 16-byte structure in memory within a linear array containing an entry for each even/odd virtual page pair, the SmartMIPS Context register can be used far more generally. Depending on the value in the ContextConfig register, it may point to an 8-byte pair of 32-bit PTEs within a single-level page table scheme, or to a first level page directory entry in a two-level lookup scheme.

A TLB exception (Refill, Invalid, or Modified) causes bits VA<sub>31:31-((X-Y)-1)</sub> to be written to a variable range of bits "(X-1):Y" of the Context register, where this range corresponds to the contiguous range of set bits in the

MIPS® Architecture for Programmers Volume IV-d:The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00 75

Copyright © 2004-2005, 2008, 2010 MIPS Technologies Inc. All rights reserved.

*ContextConfig* register. Bits 31:X are R/W to software, and are unaffected by the exception. Bits Y-1:0 will always read as 0. If X = 23 and Y = 4, i.e. bits 22:4 are set in *ContextConfig*, the behavior is identical to the standard MIPS PRA *Context* register. Although the fields have been made variable in size and interpretation, the standard MIPS PRA nomenclature is retained. Bits 31:X are referred to as the *PTEBase* field, and bits X:Y-1 are referred to as *BadVPN2*.

The value of the *Context* register is **UNPREDICTABLE** following a modification of the contents of the *ContextConfig* register.

Figure A.3 shows the format of the Context Register; Table A.7 describes the Context register fields.

#### Figure A.3 SmartMIPS Context Register Format

| 31 | х       | X-1 Y   | Y-1 |   | 0 |
|----|---------|---------|-----|---|---|
|    | PTEBase | BadVPN2 |     | 0 |   |

#### Table A.7 SmartMIPS Context Register Field Descriptions

| Fields  |                                                                             |                                                                                                                                                                                                                                                                                                                               | Read / | Reset     |            |
|---------|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|------------|
| Name    | Bits                                                                        | Description                                                                                                                                                                                                                                                                                                                   | Write  | State     | Compliance |
| PTEBase | Variable, 31:X where<br>X in {31.0}.<br>May be null.                        | This field is for use by the operating system<br>and is normally written with a value that<br>allows the operating system to use the<br><i>Context</i> Register as a pointer to an array of<br>data structures in memory corresponding to<br>the address region containing the virtual<br>address which caused the exception. | R/W    | Undefined | Required   |
| BadVPN2 | Variable, (X-1):Y<br>where<br>X in {321} and<br>Y in {310}.<br>May be null. | This field is written by hardware on a TLB exception. It contains bits $VA_{31:31-((X-Y)-1)}$ of the virtual address that caused the exception.                                                                                                                                                                               | R      | Undefined | Required   |
| 0       | Variable, (Y-1):0<br>where<br>Y in {31:1}.<br>May be null.                  | Must be written as zero; returns zero on read.                                                                                                                                                                                                                                                                                | 0      | 0         | Reserved   |

## A.7.3 ContextConfig Register (CP0 Register 4, Select 1)

Compliance Level: Required for a SmartMIPS MMU.

The *ContextConfig* register defines the bits of the *Context* register into which the high order bits of the virtual address causing a TLB exception will be written, and how many bits of that virtual address will be extracted. Bits above the selected field of the *Context* register are R/W to software and serve as the *PTEBase* field. Bits below the selected field of the *Context* register will read as zeroes.

The field to contain the virtual address index is defined by a single block of contiguous non-zero bits within the *ContextConfig* register's *VirtualIndex* field. Any zero bits to the right of the least significant one bit cause the corresponding *Context* register bits to read as zero. Any zero bits to the left of the most significant one bit cause the corresponding *Context* register bits to be R/W to software and unaffected by TLB exceptions.

A value of all ones in the *ContextConfig* register means that the full 32 bits of the faulting virtual address will be copied into the context register, making it duplicate the *BadVAddr* register. A value of all zeroes means that the full 32 bits of the *Context* register are R/W for software and unaffected by TLB exceptions.

Figure A.4 shows the SmartMIPS formats of the *ContextConfig* Register; Table A.8 describes the *ContextConfig* register fields.

## Figure A.4 SmartMIPS ContextConfig Register Format

| 31 |              | 0 |
|----|--------------|---|
|    | VirtualIndex |   |

## Table A.8 SmartMIPS ContextConfig Register Field Descriptions

| Field        | S    |                                                                                                                                                                                                                                                                                                                                      | Read /      | Reset      |            |
|--------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------|------------|
| Name         | Bits | Description                                                                                                                                                                                                                                                                                                                          | Write State |            | Compliance |
| VirtualIndex | 31:0 | A mask of 0 to 32 contiguous 1 bits in this field causes<br>the corresponding bits of the <i>Context</i> register to be writ-<br>ten with the high-order bits of the virtual address causing<br>a TLB exception.<br>Behavior of the processor is <b>UNDEFINED</b> if non-con-<br>tiguous 1 bits are written into the register field. | R/W         | 0x007ffff0 | Required   |

It is permissible to implement a subset of the *ContextConfig* register, in which some number of bits are read-only and set to one or zero as appropriate. It is possible for software to determine which bits are implemented by alternately writing all zeroes and all ones to the register, and reading back the resulting values. All implementations of the *ContextConfig* register must allow for the emulation of the standard MIPS PRA fixed *Context* register configuration. Table A.9 describes some useful *ContextConfig* values.

## Table A.9 Recommended ContextConfig Values for SmartMIPS

| Value      | Page Table<br>Organization | Page Size | PTE Size     | Compliance  |
|------------|----------------------------|-----------|--------------|-------------|
| 0x007ffff0 | Single Level               | 4K        | 64 bits/page | REQUIRED    |
| 0x003ffff8 | Single Level               | 4K        | 32 bits/page | RECOMMENDED |
| 0x007ffff8 | Single Level               | 2K        | 32 bits/page | RECOMMENDED |
| 0x00fffff8 | Single Level               | 1K        | 32 bits/page | RECOMMENDED |

## A.7.4 PageMask Register (CP0 Register 5, Select 0)

Compliance Level: PageMask register modifications are Required for SmartMIPS MMUs.

As in the standard MIPS PRA, the *PageMask* register is a read/write register used for reading from and writing to the TLB. SmartMIPS allows implementation of page sizes smaller than 4K bytes, and the *PageMask* register must be extended to accommodate them, as shown in Table A.11. To assure backward compatibility with the standard MIPS PRA, the *Mask* field extension bits 12 ad 11 can be inhibited and overridden by the corresponding bits of the *PageGrain* register. Inhibited *PageMask* bits are treated as 1 bits for the purposes of virtual address translation - the corresponding virtual address bits are not used for TLB match comparisons - but read as zeroes to software to preserve backward compatibility.

MIPS® Architecture for Programmers Volume IV-d: The SmartMIPS® Application-Specific Extension to the MIPS32® Architecture, Revision 3.00 77

Copyright © 2004-2005, 2008, 2010 MIPS Technologies Inc. All rights reserved.

Figure A.5 shows the format of the PageMask register; Table A.10 describes the PageMask register fields.

# Figure A.5 SmartMIPS PageMask Register Format 31 25 24 11 10 0 0 Mask 0 0 0

| Fie  | lds            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Read / |                                                    |            |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------|------------|
| Name | Bits           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Write  | Reset State                                        | Compliance |
| Mask | 24:11          | The <i>Mask</i> field is a bit mask in which a "1" bit indicates<br>that the corresponding bit of the virtual address should not<br>participate in the TLB match.<br>Bits 12 and 11 of the <i>Mask</i> field can be overridden by the<br><i>Mask</i> field of the <i>PageGrain</i> register: If set in the<br><i>PageGrain</i> register, the corresponding bit in the<br><i>PageMask</i> register is unwritable and reads as a zero to<br>software, but the corresponding bit is excluded from<br>address comparison as if it were set in the <i>PageMask</i><br><i>Mask</i> field. | R/W    | 0 for bits<br>121; Unde-<br>fined for bits<br>2413 | Required   |
| 0    | 31:25,<br>10:0 | Must be written as zero; return zero on read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0      | 0                                                  | Reserved   |

#### Table A.10 PageMask Register Field Descriptions

| Table A 11  | Values | for the | Maek   | Field ( | of tha | DagoMask | Pogistor |
|-------------|--------|---------|--------|---------|--------|----------|----------|
| Table A.I.I | values | ior the | iviask | Field 6 | or the | rayewask | Register |

|            |    | Bit |    |    |    |    |    |    |    |    |    |    |     |     |
|------------|----|-----|----|----|----|----|----|----|----|----|----|----|-----|-----|
| Page Size  | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12* | 11* |
| 1 KBytes   | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   |
| 2 KBytes   | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 1   |
| 4 KBytes   | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1   | 1   |
| 16 KBytes  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1   | 1   |
| 64 KBytes  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1   | 1   |
| 256 KBytes | 0  | 0   | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1   |
| 1 MByte    | 0  | 0   | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1   |
| 4 MByte    | 0  | 0   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1   |
| 16 Mbyte   | 1  | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1   | 1   |

The columns marked with an asterix (\*) are those which can be disabled and overridden by the PageGrain register.

It is implementation-dependent how many of the encodings described in Table A.11 are implemented. All processors must implement the 4KB page size, and the implemented Mask bits must span the contiguous range of values from 4KB to the smallest page granularity that can be specified by the implemented *PageGrain* register. If a particular page size encoding is not implemented by a processor, a read of the *PageMask* register must return zeros in all bits that correspond to encodings that are not implemented. Software can determine which page sizes are supported by writing the encoding for a 16MB page to the *PageMask* register, then examine the value returned from a read of the

PageMask register. If a pair of bits reads back as ones, the processor implements that page size. The operation of the processor is **UNDEFINED** if software loads the *PageMask* register with a value other than one of those listed in Table A.11.

The standard MIPS PRA might support page sizes larger than listed in Table A.11. Those larger page sizes are allowed on SmartMIPS implementations as long as they don't interfere with support for 1KB, 2KB and 4KB pages.

The value of the PageMask register is UNPREDICTABLE following a modification of the contents of the PageGrain register.

## A.7.5 PageGrain Register (CP0 Register 5, Select 1)

**Compliance Level:** Required for SmartMIPS MMUs. Optional for Release 2 (and subsequent) of the standard MIPS PRA.

The PageGrain register is a read/write register used to configure the SmartMIPS MMU to operate on pages smaller than 4K bytes. It's value is used when reading from and writing to the TLB. SmartMIPS allows implementation of page sizes smaller than 4K bytes, and in those implementations, the PageMask register must be extended to accommodate them, as shown in Table A.11. The PageGrain register also contains enable bits for the read-inhibit (RI) and execute-inhibit (XI) bits of the EntryLo registers.

It is not required that the contents of the PageGrain register be reflected in the contents of the TLB. Therefore, the TLB must be flushed before any change to the PageGrain register is made. The operation of the processor is UNDE-**FINED** if software modifies any field of the *PageGrain* register while valid entries are present in the TLB.

Figure A.6 shows the format of the PageGrain register; Table A.10 describes the PageGrain register fields.

## Figure A.6 SmartMIPS PageGrain Register Format

| 31  | 30  | 29 | 13 12 11 10 | 0 8 | 7 0 |
|-----|-----|----|-------------|-----|-----|
| RIE | XIE | 0  | Mask        | 111 | 0   |

| Fie  | lds  |                                                                                                                                                                                                                                            | Poad / | Posot |            |
|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|------------|
| Name | Bits | Description                                                                                                                                                                                                                                | Write  | State | Compliance |
| RIE  | 31   | Read Inhibit Enable. If this bit is set, the <i>RI</i> bit of the <i>EntryLoO</i> and <i>EntryLo1</i> registers is enabled. If the bit is clear, the <i>RI</i> bit is disabled and not writable by software. See section A.7.1.            | R/W    | 0     | Required   |
| XIE  | 30   | Execute Inhibit Enable. If this bit is set, the <i>XI</i> bit of the <i>EntryLo0</i> and <i>EntryLo1</i> registers is enabled. If the bit is clear, the <i>XI</i> bit is disabled and not writable by software. See section <b>A.7.1</b> . | R/W    | 0     | Required   |

## Table A.12 SmartMIPS PageGrain Register Field Descriptions

| Fields |               |                                                                                                                                                                                                                                                                                     | Read / | Rosof |            |
|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|------------|
| Name   | Bits          | Description                                                                                                                                                                                                                                                                         | Write  | State | Compliance |
| Mask   | 12:11         | Determines whether the corresponding bits of a virtual address<br>are to be used for address translation purposes. This affects the<br>behavior of the <i>EntryLoO/EntryLo1</i> , <i>EntryHi</i> , and <i>PageMask</i><br>registers according to the following scheme:              |        | 11    | Required   |
|        |               | 00 Bits 12 and 11 of <i>PageMask</i> and <i>EntryHi</i> are R/W to software and used in address translation. <i>PFN</i> field of <i>EntryLo0/EntryLo1</i> is treated as PA <sub>PABITS-310</sub>                                                                                    |        |       |            |
|        |               | <ul> <li>0 1 Bit 12 of PageMask and EntryHi is R/W to software and used in address translation. Bit 11 of PageMask and EntryHi reads as zero, and is not used in address translation.</li> <li>PFN field of EntryLo0/EntryLo1 is treated as PA<sub>PABITS-211</sub></li> </ul>      |        |       |            |
|        |               | <ul> <li>Bits 12 and 11 of PageMask and EntryHi read as zero, and are not used in address translation. PFN field of EntryLo0/EntryLo1 is treated as PA<sub>PABITS-112</sub>. In this setting, virtual address translation is identical to that of the standard MIPS PRA.</li> </ul> |        |       |            |
|        |               | 10 UNDEFINED                                                                                                                                                                                                                                                                        |        |       |            |
| 1      | 10:8          | Reserved bits for future <i>Mask</i> expansion. Must be written as one, return one on read.                                                                                                                                                                                         |        |       |            |
| 0      | 29:13,<br>7:0 | Must be written as zero; return zero on read.                                                                                                                                                                                                                                       | 0      | 0     | Reserved   |

Table A.12 SmartMIPS PageGrain Register Field Descriptions

It is not required that all bits of the *PageGrain* Mask field be fully implemented. Unimplemented low-order bits must be read-only, and must read and function as having a value of 1. Unimplemented high-order bits must read and function as having the same value as the highest-order implemented bit. Table A.13 shows some the read/write and functional behavior of the possible SmartMIPS *PageGrain* subsets.

| Subset                              | Mask Value<br>Written | Mask Value Read<br>Back | Page<br>Granularity |
|-------------------------------------|-----------------------|-------------------------|---------------------|
| 2K Byte Page                        | 0 0                   | 0 1                     | 2K Bytes            |
| Grain but not 1K<br>Byte Page Grain | 0 1                   | 0 1                     | 2K Bytes            |
| 2 jee 1 age Chain                   | 1 0                   | 11                      | 4K Bytes            |
|                                     | 11                    | 11                      | 4K Bytes            |
| 1K Byte Page                        | 0 0                   | 0 0                     | 1K Bytes            |
| Grain but not 2K<br>Byte Page Grain | 0 1                   | 11                      | 4K Bytes            |
| 2 jee 1 age Chain                   | 1 0                   | 0 0                     | 1K Bytes            |
|                                     | 1 1                   | 11                      | 4K Bytes            |

## A.7.6 EntryHi Register (CP0 Register 10, Select 0

Compliance Level: EntryHi register modifications are Required for SmartMIPS MMUs. Modifications optional in Release 2 (and subsequent) of the standard MIPS PRA.

As in the standard MIPS PRA, the EntryHi register contains the virtual address match information used for TLB read, write, and access operations.

For SmartMIPS implementations supporting pages sizes smaller than 4K, the VPN2 field of EntryHi must be extended to allow for the greater number of VPNs in an address space divided into smaller pages. A similar optional feature was added to Release 2 (and subsequent) of the standard MIPS Privileged Resource Architecture.

Figure A.7 shows the format of the modified SmartMIPS EntryHi register; Table A.14 describes the EntryHi register fields.

## Figure A.7 SmartMIPS EntryHi Register Format

| 31 11 | 10 8 | 7 0  |
|-------|------|------|
| VPN2  | 0    | ASID |

## Table A.14 EntryHi Register Field Descriptions

| Fields |       |                                                                                                                                                                                                                                                                                                                          | Read / |                                               |            |
|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------|------------|
| Name   | Bits  | Description                                                                                                                                                                                                                                                                                                              | Write  | Reset State                                   | Compliance |
| VPN2   | 31:11 | $VA_{31:11}$ of the virtual address (virtual page number / 2).<br>This field is written by hardware on a TLB exception or<br>on a TLB read, and is written by software before a TLB<br>write. Bits 12 and 11 can take a non-zero value only if<br>the corresponding bits of the <i>PageGrain</i> register are<br>zeroes. | R/W    | 0 for bits 121;<br>Undefined for<br>bits 3113 | Required   |
| ASID   | 7:0   | ASID. Unchanged from the standard MIPS PRA                                                                                                                                                                                                                                                                               | R/W    | Undefined                                     | Required   |
| 0      | 10:8  | Must be written as zero; returns zero on read.                                                                                                                                                                                                                                                                           | 0      | 0                                             | Reserved   |

The value of the EntryHi register is UNPREDICTABLE following a modification of the contents of the PageGrain register.

## A.7.7 Configuration Register 3 (CP0 Register 16, Select 3)

Compliance Level: Required for SmartMIPS.

The Config3 register is fully defined in Volume III of this multi-volume set. Bit 1 (named SM) of the Config3 register denotes the presence of the SmartMIPS ASE.

The SmartMIPS® Release 2 Privileged Resource Architecture

## **Revision History**

In the left hand page margins of this document you may find vertical change bars to note the location of significant changes to this document since its last release. Significant changes are defined as those which you should take note of as you use the MIPS IP. Changes to correct grammar, spelling errors or similar may or may not be noted with change bars. Change bars will be removed for changes which are more than one revision old.

Please note: Limitations on the authoring tools make it difficult to place change bars on changes to figures. Change bars on figure titles are used to denote a potential change in the figure itself.

| Version | Date              | Comments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0.10    | 27 September 2000 | Initial review draft.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0.20    | 27 October 2000   | PRA section added, MIPS16 instructions migrated to Volume IV of MIPS Archi-<br>tecture specification. SmartMIPS no longer referred to as an "ASE" in the text.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0.90    | 1 November 2000   | Conversion to new specification format. First external review draft.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0.91    | December 15, 2000 | <ul> <li>Changes in this revision:</li> <li>Correct temp variable indexing in the pseudo code for MADDU.</li> <li>Features listed in the Config2 register should have been included in the Config3 register instead.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0.92    | December 21, 2000 | <ul> <li>Changes in this revision:</li> <li>Make effects of MULTP and MADDP on ACX explicit and mandatory.</li> <li>Reduce size of reserved 1's field in PageGrain register to align with EntryHi ASID field as intended.</li> <li>Clarification of "binary polynomial basis" nomenclature.</li> </ul>                                                                                                                                                                                                                                                                                                                                    |
| 0.93    | January 30, 2001  | Elimination of references to a "MIPS Crypto" ASE as a subset of SmartMIPS.<br>Clarify UNPREDICTABLE state of PageMask and EntryHi registers following<br>modification of PageGrain register.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0.94    | February 28, 2001 | Addition of RIE and XIE bits to PageGrain register as enables for the RI and XI bits in the EntryLo registers, to enhance backward compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0.95    | March 12, 2001    | Update for next external review revision.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1.00    | August 1, 2001    | Update based on all feedback received from external distribution.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1.01    | April 23, 2002    | Create and release an External Confidential version of the Architecture for Pro-<br>grammers manual.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1.20    | August 29, 2002   | Add bit encoding tables to describe the SmartMIPS instructions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2.00    | May 15, 2003      | <ul> <li>Changes in this revision:</li> <li>Add base architecture requirements, software detection of the ASE, and compliance and subsetting sections to the introduction.</li> <li>Update the ROTR and ROTRV instruction encoding to specify a 1-bit difference between shift and rotate, and to align with the Release 2 instruction descriptions.</li> <li>Note that conflicts between the SmartMIPS ASE specification and Release 2 of the MIPS32 Architecture are resolved in favor of the SmartMIPS ASE.</li> <li>Remove the register description of the Config3 register, as this is now fully described in Volume III.</li> </ul> |

| Version | Date           | Comments                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.50    | July 1, 2005   | <ul> <li>Changes in this revision:</li> <li>Update all files to FrameMaker 7.1.</li> <li>Replace the use of the BinPolyMult function in MULTP with PolyMult, and define that function as pseudo code.</li> <li>Change reset state of bits 1211 of the <i>PageMask</i> and <i>EntryHi</i> registers to 0 from Undefined. This is simply a clarification because the reset state of <i>PageGrain</i> forces those bits of <i>PageMask</i> and <i>EntryHi</i> to be 0.</li> </ul>        |
| 2.51    | July 15, 2008  | <ul><li>Changes in this revision:</li><li>Update copyrights.</li><li>Update contact information.</li></ul>                                                                                                                                                                                                                                                                                                                                                                            |
| 3.00    | April 30, 2010 | <ul> <li>Edit for microMIPS and Release 3:</li> <li>Similar RI/XI TLB bits feature added to Release 3 base Architecture</li> <li>ContextConfig added to Release 3 base Architecture</li> <li>PRA chapter now pertains relationship of SmartMIPS to Release 3 of the standard PRA.</li> <li>Appendix A added to show historical relationship of SmartMIPS with Release 2 and older of the standard PRA.</li> <li>Document title updated to match other Release 3 documents.</li> </ul> |