

## OVP Guide to Using Processor Models

# Model specific information for MIPS\_M6250

Imperas Software Limited Imperas Buildings, North Weston Thame, Oxfordshire, OX9 2HA, U.K. docs@imperas.com



| Author   | Imperas Software Limited                        |
|----------|-------------------------------------------------|
| Version  | 20211118.0                                      |
| Filename | OVP_Model_Specific_Information_mips32_M6250.pdf |
| Created  | 31 December 2021                                |
| Status   | OVP Standard Release                            |

### Copyright Notice

Copyright (c) 2021 Imperas Software Limited. All rights reserved. This software and documentation contain information that is the property of Imperas Software Limited. The software and documentation are furnished under a license agreement and may be used or copied only in accordance with the terms of the license agreement. No part of the software and documentation may be reproduced, transmitted, or translated, in any form or by any means, electronic, mechanical, manual, optical, or otherwise, without prior written permission of Imperas Software Limited, or as expressly provided by the license agreement.

### Right to Copy Documentation

The license agreement with Imperas permits licensee to make copies of the documentation for its internal use only. Each copy shall include all copyrights, trademarks, service marks, and proprietary rights notices, if any.

### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the readers responsibility to determine the applicable regulations and to comply with them.

### Disclaimer

IMPERAS SOFTWARE LIMITED, AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

### Model Release Status

This model is released as part of OVP releases and is included in OVPworld packages. Please visit OVPworld.org.

# Contents

| 1         | Overview                   | 1  |
|-----------|----------------------------|----|
|           | 1.1 Description            | 1  |
|           | 1.2 Licensing              | 1  |
|           | 1.3 Limitations            | 2  |
|           | 1.4 Verification           | 2  |
|           | 1.5 Features               | 2  |
| <b>2</b>  | Configuration              | 3  |
|           | 2.1 Location               | 3  |
|           | 2.2 GDB Path               | 3  |
|           | 2.3 Semi-Host Library      |    |
|           | 2.4 Processor Endian-ness  | 3  |
|           | 2.5 QuantumLeap Support    | 3  |
|           | 2.6 Processor ELF code     | 3  |
| 3         | All Variants in this model | 4  |
| 4         | Bus Master Ports           | 5  |
| 5         | Bus Slave Ports            | 6  |
| 6         | Net Ports                  | 7  |
| 7         | FIFO Ports                 | 8  |
| 8         | Formal Parameters          | 9  |
|           | 8.1 Parameter values       | 15 |
| 9         | Execution Modes            | 21 |
| 10        | Exceptions                 | 22 |
| 11        | Hierarchy of the model     | 23 |
|           | 11.1 Level 1: CPU          | 23 |
| <b>12</b> | Model Commands             | 24 |
|           | 12.1 Level 1: CPU          | 24 |
|           | 12.1.1 isync               | 24 |
|           | 19.1.9 itms co             | 24 |

### Imperas OVP Fast Processor Model Documentation for MIPS\_M6250

|        | 12.1.3 mipsCOP0                          | 25         |
|--------|------------------------------------------|------------|
|        | 12.1.4 mipsCacheDisable                  | 25         |
|        | 12.1.4.1 Argument description            | 25         |
|        | 12.1.5 mipsCacheEnable                   | 25         |
|        | 12.1.6 mipsCacheRatio                    | 25         |
|        | 12.1.7 mipsCacheReport                   | 25         |
|        | 12.1.7.1 Argument description            | 25         |
|        | 12.1.8 mipsCacheReset                    | 25         |
|        | 12.1.8.1 Argument description            | 25         |
|        | 12.1.9 mipsCacheTrace                    | 25         |
|        | $12.1.10\mathrm{mipsDebugFlags}$         | 26         |
|        | 12.1.11 mipsReadRegister                 | 26         |
|        | 12.1.12 mipsReadTLBEntry                 | 26         |
|        | * *                                      | 26         |
|        | S. S | 26         |
|        | 1 v                                      | 26         |
|        | 12.1.15 mipsWriteRegister                | 27         |
|        | 12.1.16 mipsWriteTLBEntry                | 27         |
| 13 Reg | isters                                   | <b>2</b> 8 |
| 13.1   | Level 1: CPU                             | 28         |
|        | 13.1.1 Core                              | 28         |
|        | 13.1.2 DSP                               | 29         |
|        | 13.1.3 Shadow                            | 29         |
|        | 13.1.4 COP0                              | 32         |
|        | 13.1.5 SPRAM                             | 33         |
|        | 13.1.6 Integration support               | 34         |

## Overview

This document provides the details of an OVP Fast Processor Model variant.

OVP Fast Processor Models are written in C and provide a C API for use in C based platforms. The models also provide a native interface for use in SystemC TLM2 platforms.

The models are written using the OVP VMI API that provides a Virtual Machine Interface that defines the behavior of the processor. The VMI API makes a clear line between model and simulator allowing very good optimization and world class high speed performance. Most models are provided as a binary shared object and also as source. This allows the download and use of the model binary or the use of the source to explore and modify the model.

The models are run through an extensive QA and regression testing process and most model families are validated using technology provided by the processor IP owners. There is a companion document (OVP Guide to Using Processor Models) which explains the general concepts of OVP Fast Processor Models and their use. It is downloadable from the OVPworld website documentation pages.

## 1.1 Description

MIPS32 Configurable Processor Model

If you need other variants, these models can be obtained from www.OVPworld.org/ip-vendor-mips.

## 1.2 Licensing

Usage of binary model under license governing simulator usage. Source of model available under Imperas Software License Agreement.

### 1.3 Limitations

If this model is not part of your installation, then it is available for download from www.OVPworld.org/ip-vendor-mips.

### 1.4 Verification

Models have been validated correct as part of the MIPS Verified program and run through the MIPS AVP test programs

### 1.5 Features

Both MIPS32 and microMIPS32 Instruction sets implemented. MIPS32 used when coming out of reset

MMU Type: Standard TLB

L1 I and D cache model in either full or tag-only mode implemented (disabled by default)

Vectored interrupts implemented

MCU ASE implemented

DSP ASE Rev 2 implemented

## Configuration

### 2.1 Location

This model's VLNV is mips.ovpworld.org/processor/mips32/1.0.

The model source is usually at:

\$IMPERAS\_HOME/ImperasLib/source/mips.ovpworld.org/processor/mips32/1.0

The model binary is usually at:

\$IMPERAS\_HOME/lib/\$IMPERAS\_ARCH/ImperasLib/mips.ovpworld.org/processor/mips32/1.0

### 2.2 GDB Path

The default GDB for this model is: \$IMPERAS\_HOME/lib/\$IMPERAS\_ARCH/gdb/mips-sde-elf-gdb.

### 2.3 Semi-Host Library

The default semi-host library file is mips.ovpworld.org/semihosting/mips32Newlib/1.0

### 2.4 Processor Endian-ness

This model can be set to either endian-ness (normally by a pin, or the ELF code).

### 2.5 QuantumLeap Support

This processor is qualified to run in a QuantumLeap enabled simulator.

### 2.6 Processor ELF code

The ELF code supported by this model is: 0x8.

## All Variants in this model

This model has these variants

| Variant  | Description                  |
|----------|------------------------------|
| I7200    |                              |
| M5100    |                              |
| M5150    |                              |
| M6200    |                              |
| M6250    | (described in this document) |
| MIPS32R6 |                              |
| P5600    |                              |

Table 3.1: All Variants in this model

# **Bus Master Ports**

This model has these bus master ports.

| Name        | min | max | Connect?  | Description                |
|-------------|-----|-----|-----------|----------------------------|
| ISPRAM      | 32  | 32  | optional  | instruction scratchpad RAM |
| DSPRAM      | 32  | 32  | optional  | data scratchpad RAM        |
| INSTRUCTION | 12  | 36  | mandatory |                            |
| DATA        | 12  | 36  | optional  |                            |

Table 4.1: Bus Master Ports

# **Bus Slave Ports**

This model has no bus slave ports.

# Net Ports

This model has these net ports.

| Name             | Type   | Connect? | Description                                 |
|------------------|--------|----------|---------------------------------------------|
| reset            | input  | optional | Core reset                                  |
| softreset        | input  | optional | Core soft reset                             |
| dint             | input  | optional | Debug external interrupt                    |
| hwint0           | input  | optional | External interrupt                          |
| hwint1           | input  | optional | External interrupt                          |
| hwint2           | input  | optional | External interrupt                          |
| hwint3           | input  | optional | External interrupt                          |
| hwint4           | input  | optional | External interrupt                          |
| hwint5           | input  | optional | External interrupt                          |
| hwint6           | input  | optional | External interrupt                          |
| hwint7           | input  | optional | External interrupt                          |
| nmi              | input  | optional | Non-maskable external interrupt             |
| EICPresent       | input  | optional | Input signal SI_EICPresent per VPE          |
| EIC_RIPL         | input  | optional | External interrupt controller RIPL (alias   |
|                  |        |          | of hwint0 - 5 or 7)                         |
| EIC_EICSS        | input  | optional | External interrupt controller EICSS         |
| EIC_VectorNum    | input  | optional | External interrupt controller vector num-   |
|                  |        |          | ber                                         |
| EIC_VectorOffset | input  | optional | External interrupt controller vector offset |
| intISS           | output | optional | True when interrupt request is serviced     |
| causeTI          | output | optional | True when timer interrupt expires           |
| causeIP0         | output | optional | Raised for software interrupt request IP0   |
| causeIP1         | output | optional | Raised for software interrupt request IP1   |
| si_sleep         | output | optional | True when the VPE is in WAIT state          |
| vc_run           | input  | optional | Set to force stop of execution on processor |
|                  |        |          | VPE (simulation control only)               |

Table 6.1: Net Ports

# FIFO Ports

This model has no FIFO ports.

## Formal Parameters

| Name                     | Type        | Description                                                |
|--------------------------|-------------|------------------------------------------------------------|
| variant                  | Enumeration | Processor variant                                          |
| endian                   | Endian      | Model endian                                               |
| cacheenable              | Enumeration | Select cache model mode (default, tag or full)             |
| cachedebug               | Uns32       | Cache debug flags                                          |
| cacheextbiuinfo          | Pointer     | Pointer to platform-provided BIU cache info structure      |
| mipsHexFile              | String      | Load a MIPS hex file (test-mode)                           |
| IMPERAS_MIPS_AVP_OPCODES | Boolean     | Enable MIPS-specific magic Pass/Fail opcodes (specific for |
|                          |             | AVP test termination)                                      |
| cacheIndexBypassTLB      | Boolean     | When set, cache index ops do not generate TLB exceptions   |
| MIPS_TRACE               | Boolean     | Enable MIPS-format trace output                            |
| gprNames                 | Boolean     | Disassemble the register names from the default ABI in-    |
|                          |             | stead of register numbers for MIPS-format trace output     |
| supervisorMode           | Boolean     | Override whether processor implements supervisor mode      |
| busErrors                | Boolean     | Override bus error exception behavior. When true, ac-      |
|                          |             | cesses of memory not defined by platform will cause bus    |
|                          |             | error exceptions                                           |
| fixedMMU                 | Boolean     | Override the MMU type to fixed mapping when                |
|                          |             | true (sets Config.MT=3, Config.KU/K23=2 and Con-           |
|                          |             | fig1.MMUSizeM1=0)                                          |
| fixedDbgRegSize          | Boolean     | Enable applications to debug on P5600 with GDB version     |
|                          |             | 2015.06-05 and prior                                       |
| removeDSP                | Boolean     | Override the DSP-present configuration when true (sets     |
|                          |             | Config3.DSPP/DSP2P=0)                                      |
| removeCMP                | Boolean     | Override the CMP-Present configuration when true (sets     |
|                          |             | Config3.CMGCR and GCR_BASE to 0)                           |
| removeFP                 | Boolean     | Override the FP-Present configuration when true (sets      |
|                          |             | Config1.FP to 0)                                           |
| removeFTLB               | Boolean     | Override the FTLBEn configuration when true (disable       |
|                          |             | FTLB)                                                      |
| isISA                    | Boolean     | Enable to specify ISA model (reset address from ELF, all   |
|                          |             | coprocessors enabled)                                      |
| hiddenTLBentries         | Boolean     | Deprecated - Instead set config1MMUSizeM1 to maximum       |
| 20                       | ** 00       | value to improve performance                               |
| perfCounters             | Uns32       | Performance Counters                                       |
| MTFPU                    | Uns32       | Enable multi-threaded FPU (1:old mttc1 behavior, 2:new     |
| (D)                      | D 1         | mttc1 behavior)                                            |
| supportDenormals         | Boolean     | Enable to specify that the FPU supports denormal           |
| VDDOM TO                 | 11 20       | operands and results                                       |
| VPE0MaxTC                | Uns32       | Specifies the maximum TCs initially on VPE0. Ignored if    |
|                          |             | less than two VPEs configured.                             |

| VPE1MaxTC                      | Uns32   | Specifies the maximum TCs initially on VPE1. Ignored if                                              |
|--------------------------------|---------|------------------------------------------------------------------------------------------------------|
|                                |         | less than three VPEs configured.                                                                     |
| mpuRegions                     | Uns32   | Number of regions for memory protection unit                                                         |
| mpuType                        | Uns32   | Type of MPU implementation                                                                           |
| mpuEnable                      | Boolean | Enable MPU2 segment control at reset                                                                 |
| mpuSegment0                    | Uns32   | Attributes for segment 0 in MPU2 SegmentControl_0 register                                           |
| mpuSegment1                    | Uns32   | Attributes for segment 1 in MPU2 SegmentControl_0 register                                           |
| mpuSegment2                    | Uns32   | Attributes for segment 2 in MPU2 SegmentControl_0 register                                           |
| mpuSegment3                    | Uns32   | Attributes for segment 3 in MPU2 SegmentControl_0 register                                           |
| mpuSegment4                    | Uns32   | Attributes for segment 4 in MPU2 SegmentControl_1 register                                           |
| mpuSegment5                    | Uns32   | Attributes for segment 5 in MPU2 SegmentControl_1 register                                           |
| mpuSegment6                    | Uns32   | Attributes for segment 6 in MPU2 SegmentControl_1 register                                           |
| mpuSegment7                    | Uns32   | Attributes for segment 7 in MPU2 SegmentControl_1 register                                           |
| mpuSegment8                    | Uns32   | Attributes for segment 8 in MPU2 SegmentControl_2 register                                           |
| mpuSegment9                    | Uns32   | Attributes for segment 9 in MPU2 SegmentControl_2 register                                           |
| mpuSegment10                   | Uns32   | Attributes for segment 10 in MPU2 SegmentControl_2 register                                          |
| mpuSegment11                   | Uns32   | Attributes for segment 11 in MPU2 SegmentControl_2 register                                          |
| mpuSegment12                   | Uns32   | Attributes for segment 12 in MPU2 SegmentControl_3 register                                          |
| mpuSegment13                   | Uns32   | Attributes for segment 13 in MPU2 SegmentControl_3 register                                          |
| mpuSegment14                   | Uns32   | Attributes for segment 14 in MPU2 SegmentControl_3 register                                          |
| mpuSegment15                   | Uns32   | Attributes for segment 15 in MPU2 SegmentControl_3 register                                          |
| mvpconf0vpe                    | Uns32   | Override MVPConf0.PVPE                                                                               |
| tcDisable                      | Uns32   | Number of disabled TCs                                                                               |
| vpeDisable                     | Uns32   | Number of disabled VPEs                                                                              |
| mvpconf0tc                     | Uns32   | Override MVPConf0.PTC                                                                                |
| mvpconf0pcp                    | Boolean | Override MVPConf0.PCP                                                                                |
| mvpconf0tcp                    | Boolean | Override MVPConf0.TCP                                                                                |
| mvpconf1c1f                    | Boolean | Override MVPConf.C1F                                                                                 |
| ${\bf mvpcontrol Policy Mode}$ | Boolean | Override MVPControl.POLICY_MODE                                                                      |
| hasFDC                         | Uns32   | Specify the size of Fast Debug Channel register block                                                |
| licenseWarningDays             | Uns32   | Specify the number of days before a license expires to start issuing a warning. 0 disables warnings. |
| MIPS_UHI                       | Boolean | Enable MIPS-Unified Hosting interface                                                                |
| mipsUhiArgs                    | String  | Specifies UHI arguments string separated by spaces                                                   |
| mipsUhiJail                    | String  | Specifies UHI jailroot                                                                               |
| MIPS_DV_MODE                   | Boolean | Enable Design Verification mode                                                                      |
| MIPS_MAGIC_OPCODES             | Boolean | Enable MIPS-specific magic Pass/Fail opcodes                                                         |
| enableTrickbox                 | Boolean | Enable trickbox addresses (specific for AVP)                                                         |
| fpuexcdisable                  | Boolean | Disable FPU exceptions                                                                               |

| TRU_PRESENT                                                                                                                       | Boolean                                                                                                     | Disable or Enable based on TRU presence to control cer-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                   | Boolowii                                                                                                    | tain fields (e.x.perfCtl.PCTD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ucLLwordsLocked                                                                                                                   | Uns32                                                                                                       | Numbers of words (4 byte) an uncached LL is locking.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                   |                                                                                                             | Maximum: 4K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| FUSA                                                                                                                              | Boolean                                                                                                     | Enable Functional Safety                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CPC_FAULT_SUPPORTED                                                                                                               | Uns32                                                                                                       | Specify the value for Functional Safety Supported register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| CPC_FAULT_ENABLE                                                                                                                  | Uns32                                                                                                       | Specify the value for Functional Safety Enable register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| cop2Bits                                                                                                                          | Uns32                                                                                                       | Specifies width in bits of COP2 registers (32 or 64)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| cop2FileName                                                                                                                      | String                                                                                                      | Specifies COP2 dynamically-loaded object (.so/.dll) defin-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| cop21 hervaine                                                                                                                    | String                                                                                                      | ing COP2 instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| udiConfig                                                                                                                         | Int32                                                                                                       | Specifies UDI configuration attribute                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| udiFileName                                                                                                                       | String                                                                                                      | Specifies UDI dynamically-loaded object (.so/.dll) defining                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| udii nervame                                                                                                                      | String                                                                                                      | UDI instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| vectoredinterrupt                                                                                                                 | Boolean                                                                                                     | Enables vectored interrupts (sets Config3 VInt)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| externalinterrupt                                                                                                                 | Boolean                                                                                                     | Enables the use of an external interrupt controller (sets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| externamiterrupt                                                                                                                  | Doolean                                                                                                     | Config3 VEIC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| rootFixedMMU                                                                                                                      | Dooloon                                                                                                     | Override the root MMU type to fixed mapping when true                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TOOLFIXEGIVINIU                                                                                                                   | Boolean                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| rootMMUSizeM1                                                                                                                     | Uns32                                                                                                       | (sets Config.MT=3 and Config.KU/K23=2)  Override the root MMUSizeM1 field in Config1 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TOOUNINIOSIZEMI                                                                                                                   | Uns32                                                                                                       | (number of MMU entries-1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                   | II20                                                                                                        | Override the HSS field in SRSCtl register (number of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| srsctlHSS                                                                                                                         | Uns32                                                                                                       | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| C-DC                                                                                                                              | Uns32                                                                                                       | shadow register sets)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| firPS                                                                                                                             | 0 0 -                                                                                                       | Override the PS field in FIR register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| firHas2008                                                                                                                        | Uns32                                                                                                       | Override the Has2008 field in FIR register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| usePreciseFpu                                                                                                                     | Uns32                                                                                                       | Use the precise Floating Point emulation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| simulateLite                                                                                                                      | Enumeration                                                                                                 | Run Simulation with optimization. There are several op-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                   |                                                                                                             | timizations which coule be combined (NONE, FS, MA or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                   | ***                                                                                                         | FSMA)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| pridCompanyOptions                                                                                                                | Uns32                                                                                                       | Override the Company Options field in PRId register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| pridRevision                                                                                                                      | Uns32                                                                                                       | Override the Revision field in PRId register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| globalClusterNum                                                                                                                  | Uns32                                                                                                       | Override the ClusterNum field in GlobalNumber register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| intctlIPTI                                                                                                                        | Uns32                                                                                                       | Override the IPTI field in IntCtl register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| intctlIPFDC                                                                                                                       | Uns32                                                                                                       | Override the IPFDC field in IntCtl register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| intctlIPPCI                                                                                                                       | Uns32                                                                                                       | Override the IPPCI field in IntCtl register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| numWatch                                                                                                                          | Uns32                                                                                                       | Specify number of WatchLo/WatchHi register pairs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| xconfigSpecified                                                                                                                  | Boolean                                                                                                     | True if the configuration comes from a valid xconfig file                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| segcfg0PA                                                                                                                         | Uns32                                                                                                       | Set CFG0.PA field of SegCtl0 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| segcfg1PA                                                                                                                         | Uns32                                                                                                       | Set CFG1.PA field of SegCtl0 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| segcfg2PA                                                                                                                         | Uns32                                                                                                       | Set CFG2.PA field of SegCtl1 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| segcfg3PA                                                                                                                         | Uns32                                                                                                       | C-+ CEC2 DA C-11 - f C C+11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                                   |                                                                                                             | Set CFG3.PA field of SegCtl1 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| segcfg4PA                                                                                                                         | Uns32                                                                                                       | Set CFG4.PA field of SegCtl2 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                   | Uns32<br>Uns32                                                                                              | Set CFG4.PA field of SegCtl2 register Set CFG5.PA field of SegCtl2 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| segcfg4PA                                                                                                                         | Uns32                                                                                                       | Set CFG4.PA field of SegCtl2 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| segcfg4PA<br>segcfg5PA                                                                                                            | Uns32<br>Uns32                                                                                              | Set CFG4.PA field of SegCtl2 register Set CFG5.PA field of SegCtl2 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| segcfg4PA<br>segcfg5PA<br>segcfg0AM                                                                                               | Uns32<br>Uns32<br>Uns32                                                                                     | Set CFG4.PA field of SegCtl2 register Set CFG5.PA field of SegCtl2 register Set CFG0.AM field of SegCtl0 register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| segcfg4PA<br>segcfg5PA<br>segcfg0AM<br>segcfg1AM                                                                                  | Uns32<br>Uns32<br>Uns32<br>Uns32                                                                            | Set CFG4.PA field of SegCtl2 register Set CFG5.PA field of SegCtl2 register Set CFG0.AM field of SegCtl0 register Set CFG1.AM field of SegCtl0 register                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| segcfg4PA segcfg5PA segcfg0AM segcfg1AM segcfg2AM                                                                                 | Uns32<br>Uns32<br>Uns32<br>Uns32<br>Uns32                                                                   | Set CFG4.PA field of SegCtl2 register Set CFG5.PA field of SegCtl2 register Set CFG0.AM field of SegCtl0 register Set CFG1.AM field of SegCtl0 register Set CFG2.AM field of SegCtl1 register                                                                                                                                                                                                                                                                                                                                                                                                           |
| segcfg4PA segcfg5PA segcfg0AM segcfg1AM segcfg2AM segcfg3AM                                                                       | Uns32<br>Uns32<br>Uns32<br>Uns32<br>Uns32<br>Uns32                                                          | Set CFG4.PA field of SegCtl2 register Set CFG5.PA field of SegCtl2 register Set CFG0.AM field of SegCtl0 register Set CFG1.AM field of SegCtl0 register Set CFG2.AM field of SegCtl1 register Set CFG3.AM field of SegCtl1 register                                                                                                                                                                                                                                                                                                                                                                     |
| segcfg4PA segcfg5PA segcfg0AM segcfg1AM segcfg2AM segcfg3AM                                                                       | Uns32<br>Uns32<br>Uns32<br>Uns32<br>Uns32<br>Uns32<br>Uns32                                                 | Set CFG4.PA field of SegCtl2 register  Set CFG5.PA field of SegCtl2 register  Set CFG0.AM field of SegCtl0 register  Set CFG1.AM field of SegCtl0 register  Set CFG2.AM field of SegCtl1 register  Set CFG3.AM field of SegCtl1 register  Set CFG3.AM field of SegCtl2 register                                                                                                                                                                                                                                                                                                                         |
| segcfg4PA segcfg5PA segcfg0AM segcfg1AM segcfg2AM segcfg3AM segcfg4AM segcfg5AM                                                   | Uns32 Uns32 Uns32 Uns32 Uns32 Uns32 Uns32 Uns32 Uns32                                                       | Set CFG4.PA field of SegCtl2 register  Set CFG5.PA field of SegCtl2 register  Set CFG0.AM field of SegCtl0 register  Set CFG1.AM field of SegCtl0 register  Set CFG2.AM field of SegCtl1 register  Set CFG3.AM field of SegCtl1 register  Set CFG4.AM field of SegCtl2 register  Set CFG5.AM field of SegCtl2 register                                                                                                                                                                                                                                                                                  |
| segcfg4PA segcfg5PA segcfg0AM segcfg1AM segcfg2AM segcfg3AM segcfg4AM segcfg5AM segcfg5EU                                         | Uns32                                           | Set CFG4.PA field of SegCtl2 register  Set CFG5.PA field of SegCtl2 register  Set CFG0.AM field of SegCtl0 register  Set CFG1.AM field of SegCtl0 register  Set CFG2.AM field of SegCtl1 register  Set CFG3.AM field of SegCtl1 register  Set CFG4.AM field of SegCtl2 register  Set CFG5.AM field of SegCtl2 register  Set CFG5.AM field of SegCtl2 register  Set CFG0.EU field of SegCtl0 register  Set CFG1.EU field of SegCtl0 register                                                                                                                                                             |
| segcfg4PA segcfg5PA segcfg0AM segcfg1AM segcfg2AM segcfg3AM segcfg4AM segcfg5AM segcfg5EU segcfg1EU segcfg2EU                     | Uns32                         | Set CFG4.PA field of SegCtl2 register  Set CFG5.PA field of SegCtl2 register  Set CFG0.AM field of SegCtl0 register  Set CFG1.AM field of SegCtl0 register  Set CFG2.AM field of SegCtl1 register  Set CFG3.AM field of SegCtl1 register  Set CFG4.AM field of SegCtl2 register  Set CFG5.AM field of SegCtl2 register  Set CFG0.EU field of SegCtl0 register  Set CFG1.EU field of SegCtl0 register  Set CFG2.EU field of SegCtl1 register                                                                                                                                                             |
| segcfg4PA segcfg5PA segcfg0AM segcfg1AM segcfg2AM segcfg3AM segcfg4AM segcfg5AM segcfg5EU segcfg1EU segcfg2EU segcfg3EU           | Uns32             | Set CFG4.PA field of SegCtl2 register  Set CFG5.PA field of SegCtl2 register  Set CFG0.AM field of SegCtl0 register  Set CFG1.AM field of SegCtl0 register  Set CFG2.AM field of SegCtl1 register  Set CFG3.AM field of SegCtl1 register  Set CFG4.AM field of SegCtl2 register  Set CFG5.AM field of SegCtl2 register  Set CFG5.EU field of SegCtl0 register  Set CFG1.EU field of SegCtl0 register  Set CFG2.EU field of SegCtl1 register  Set CFG3.EU field of SegCtl1 register  Set CFG3.EU field of SegCtl1 register                                                                               |
| segcfg4PA segcfg5PA segcfg0AM segcfg1AM segcfg2AM segcfg3AM segcfg4AM segcfg5AU segcfg1EU segcfg1EU segcfg2EU segcfg3EU segcfg4EU | Uns32 | Set CFG4.PA field of SegCtl2 register  Set CFG5.PA field of SegCtl2 register  Set CFG0.AM field of SegCtl0 register  Set CFG1.AM field of SegCtl0 register  Set CFG2.AM field of SegCtl1 register  Set CFG3.AM field of SegCtl1 register  Set CFG4.AM field of SegCtl2 register  Set CFG5.AM field of SegCtl2 register  Set CFG5.EU field of SegCtl0 register  Set CFG1.EU field of SegCtl0 register  Set CFG2.EU field of SegCtl1 register  Set CFG3.EU field of SegCtl1 register |
| segcfg4PA segcfg5PA segcfg0AM segcfg1AM segcfg2AM segcfg3AM segcfg4AM segcfg5AM segcfg5EU segcfg1EU segcfg2EU segcfg3EU           | Uns32             | Set CFG4.PA field of SegCtl2 register  Set CFG5.PA field of SegCtl0 register  Set CFG0.AM field of SegCtl0 register  Set CFG1.AM field of SegCtl0 register  Set CFG2.AM field of SegCtl1 register  Set CFG3.AM field of SegCtl1 register  Set CFG4.AM field of SegCtl2 register  Set CFG5.AM field of SegCtl2 register  Set CFG5.EU field of SegCtl0 register  Set CFG1.EU field of SegCtl0 register  Set CFG1.EU field of SegCtl1 register  Set CFG3.EU field of SegCtl1 register  Set CFG3.EU field of SegCtl1 register                                                                               |

| f ac                     | 11 20   |                                                            |
|--------------------------|---------|------------------------------------------------------------|
| segcfg2C                 | Uns32   | Set CFG2.C field of SegCtl1 register                       |
| segcfg3C                 | Uns32   | Set CFG3.C field of SegCtl1 register                       |
| segcfg4C                 | Uns32   | Set CFG4.C field of SegCtl2 register                       |
| segcfg5C                 | Uns32   | Set CFG5.C field of SegCtl2 register                       |
| cdmmSize                 | Uns32   | Override the cdmmsize reset value                          |
| configAR                 | Uns32   | Enables R6 support                                         |
| configBM                 | Uns32   | Override the BM field in Config register (burst mode)      |
| configDSP                | Boolean | Override Config.DSP (data scratchpad RAM present)          |
| configISP                | Boolean | Override Config.ISP (instruction scratchpad RAM            |
|                          |         | present)                                                   |
| configK0                 | Uns32   | Override power on value of Config.K0 (set Kseg0 cacheabil- |
|                          |         | ity)                                                       |
| configKU                 | Uns32   | Override power on value of Config.KU (set Useg cacheabil-  |
|                          |         | ity)                                                       |
| configK23                | Uns32   | Override power on value of Config.K23 (set Kseg23          |
|                          |         | cacheability)                                              |
| configMDU                | Boolean | Override Config.MDU (iterative multiply/divide unit)       |
| configMM                 | Boolean | Override Config.MM (merging mode for write)                |
| configMT                 | Uns32   | Override Config.MT                                         |
| configSB                 | Boolean | Override Config.SB (simple bus transfers only)             |
| configBCP                | Boolean | Override Config.BCP (Buffer Cache Present)                 |
| MIPS16eASE               | Boolean | Override Config1.CA (enables the MIPS16e ASE)              |
| config1DA                | Uns32   | Override Config1.DA (Deache associativity)                 |
| config1DL                | Uns32   | Override Config1.DL (Deache line size)                     |
| config1DS                | Uns32   | Override Config1.DS (Deache sets per way)                  |
| config1EP                | Boolean | Override Config1.EP (EJTag present)                        |
| config1IA                | Uns32   | Override Config1.IA (Icache associativity)                 |
| config1IL                | Uns32   | Override Config1.IL (Icache line size)                     |
| config1IS                | Uns32   | Override Config1.IS (Icache sets per way)                  |
| config1MMUSizeM1         | Uns32   | Override Config1.MMUSizeM1 (number of MMU entries-         |
|                          |         | 1)                                                         |
| $config1MMUSizeM1\_VPE1$ | Uns32   | Override Config1.MMUSizeM1 for VPE1                        |
| $config1MMUSizeM1\_VPE2$ | Uns32   | Override Config1.MMUSizeM1 for VPE2                        |
| $config1MMUSizeM1\_VPE3$ | Uns32   | Override Config1.MMUSizeM1 for VPE3                        |
| config1WR                | Boolean | Override Config1.WR (watchpoint registers present)         |
| config1PC                | Boolean | Override Config1.PC (Performance Counters present)         |
| config1C2                | Boolean | Override Config1.C2 (Coprocessor 2 present)                |
| config2SU                | Uns32   | Override the SU field in Config2 register                  |
| config2SS                | Uns32   | Override the SS field in Config2 register                  |
| config2SL                | Uns32   | Override the SL field in Config2 register                  |
| config2SA                | Uns32   | Override the SA field in Config2 register                  |
| config3BI                | Boolean | Override Config3.BI                                        |
| config3BP                | Boolean | Override Config3.BP                                        |
| config3CDMM              | Boolean | Override Config3.CDMM                                      |
| config3CTXTC             | Boolean | Override Config3.CTXTC                                     |
| config3DSPP              | Boolean | Override Config3.DSPP                                      |
| config3DSP2P             | Boolean | Override Config3.DSP2P                                     |
| config3IPLW              | Uns32   | Override Config3.IPLW                                      |
| config3ISA               | Uns32   | Override Config3.ISA                                       |
| config3ISAOnExc          | Boolean | Override Config3.ISAOnExc                                  |
| config3ITL               | Boolean | Override Config3.ITL                                       |
| config3LPA               | Boolean | Override Config3.LPA                                       |
| config3MCU               | Boolean | Override Config3.MCU                                       |
| config3MMAR              | Uns32   | Override Config3.MMAR                                      |
| config3RXI               | Boolean | Override Config3.RXI                                       |
| config3SC                | Boolean | Override Config3.RAI Override Config3.SC                   |
| comigose                 | Doolean | Override Comigo.5C                                         |

| config3ULRI        | Boolean | Override Config3.ULRI                                                                  |
|--------------------|---------|----------------------------------------------------------------------------------------|
| config3VZ          | Boolean | Override Config3.VZ                                                                    |
| config3MSAP        | Boolean | Override Config3.WSAP                                                                  |
| config3CMGCR       | Boolean | Override Conngs.MSAP  Override the CMGCR field in Config3 register                     |
| config3SP          | Boolean | Override the CMGCR held in Config3 register  Override the SP field in Config3 register |
|                    |         | Override the SP field in Config3 register  Override the TL field in Config3 register   |
| config3TL          | Uns32   |                                                                                        |
| config3PW          | Boolean | Override the PW field in Config3 register                                              |
| config4AE          | Boolean | Override Config4.AE                                                                    |
| config4IE          | Uns32   | Override Config4.IE                                                                    |
| config4MMUConfig   | Uns32   | Override Config4.MMUConfig field (interpretation depends on MMUExtDef value)           |
| C AMMILE AD C      | 11 20   | 1 - /                                                                                  |
| config4MMUExtDef   | Uns32   | Override Config4.MMUExtDef                                                             |
| config4VTLBSizeExt | Uns32   | Override Config4.VTLBSizeExt                                                           |
| config4KScrExist   | Uns32   | Override Config4.KScrExist                                                             |
| config5EVA         | Boolean | Override Config5.EVA                                                                   |
| config5LLB         | Boolean | Override Config5.LLB (LLAddr supports LLbit)                                           |
| config5MRP         | Boolean | Override Config5.MRP (MaaR Present)                                                    |
| config5NFExists    | Boolean | Override Config5.NFExists                                                              |
| mips32Macro        | Boolean | Enables the MIPS32 SAVE and RESTORE macro instruc-                                     |
| 0.5164.5           |         | tions. Ignored if Config5.CA2 is not set)                                              |
| config5MSAEn       | Boolean | Override Config5.MSAEn                                                                 |
| config5MVH         | Boolean | Override Config5.MVH (enable MTHC0 and MFHC0 in-                                       |
|                    |         | structions)                                                                            |
| config5DEC         | Boolean | Override Config5.DEC (to test Dual Endian Capability)                                  |
| config5GI          | Uns32   | Override Config5.GI (enable GINV)                                                      |
| config5CRCP        | Boolean | Override Config5.CRCP (CRCP Present)                                                   |
| config5VP          | Boolean | Override Config5.VP                                                                    |
| config6FTLBEn      | Boolean | Override power on value of Config6.FTLBEn                                              |
| config7AR          | Boolean | Override Config7.AR (Alias removed Data cache)                                         |
| config7DCIDX_MODE  | Uns32   | Override Config7.DCIDX_MODE                                                            |
| config7HCI         | Boolean | Override Config7.HCI (Hardware Cache Initialization)                                   |
| config7IAR         | Boolean | Override Config7.IAR (Alias removed Instruction cache)                                 |
| config7WII         | Boolean | Override Config7.WII (wait IE/IXMT ignore)                                             |
| config7ES          | Uns32   | Override the ES field in Config7 register (Externalize sync)                           |
| config7WR          | Boolean | Override Config7[31] bit (Alternative implementation of                                |
|                    |         | Watch registers)                                                                       |
| config7FPR         | Boolean | Override Config7.FPR (one-half FPU clock ratio)                                        |
| config7USP         | Uns32   | Override Config7.USP (USPRAM enable)                                                   |
| config7BTLM        | Boolean | Override Config7.BTLM bit                                                              |
| config7BusSlp      | Boolean | Override Config7.BusSlp bit                                                            |
| config7IVAD        | Boolean | Override Config7.IVAD bit                                                              |
| config7RPS         | Boolean | Override Config7.RPS bit                                                               |
| statusFR           | Boolean | Override power on value in Status.FR (Floating point reg-                              |
|                    |         | ister mode)                                                                            |
| fcsrABS2008        | Boolean | Override FCSR.ABS2008 (ABS/NEG compliant with                                          |
|                    |         | IEEE 754-2008)                                                                         |
| fcsrNAN2008        | Boolean | Override FCSR.NAN2008 (QNaN/SNaN encodings match                                       |
|                    |         | IEEE 754-2008 recommendation)                                                          |
| numMaarRegs        | Uns32   | Override number of MAAR registers (must be even)                                       |
| srsconf0SRS1       | Uns32   | Override the SRS1 field in SRSConf0 register                                           |
| srsconf0SRS2       | Uns32   | Override the SRS2 field in SRSConf0 register                                           |
| srsconf0SRS3       | Uns32   | Override the SRS3 field in SRSConf0 register                                           |
| wiredLimit         | Uns32   | Override Limit field of the Wired register                                             |
| wiredLimitBits     | Uns32   | Override width of Limit field of the Wired register                                    |
| wiredWiredBits     | Uns32   | Override width of Wired field of the Wired register                                    |
| cdmmBaseCI         | Boolean | Override CDMMBase.CI                                                                   |

| parityEnable                     | Uns32       | Specify error detection support: 0 - none; 1 - parity; 2 - ECC                                                                 |
|----------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| useMpTb                          | Boolean     | Override Use of multi-processor test bench                                                                                     |
| ExceptionBase                    | Uns32       | Specify the BEV Exception Base address. (use GCR_Cx_RESET_BASE on CMP processors)                                              |
| UseExceptionBase                 | Boolean     | Set to one to use ExceptionBase[29:12] as the corresponding BEV address bits                                                   |
| first BEVException Base Mask Bit | Uns32       | Specify LSB position of GCR_Cx_RESET_EXT_BASE.BEVExceptionBaseMask field. Only used when SegCtl present                        |
| EVAReset                         | Boolean     | Set to one to reset into non-legacy address map and BEV location. Only used when non-CMP and SegCtl present                    |
| ExceptionBaseMask                | Uns32       | Specify the ExceptionBaseMask value used for bits [27:firstBEVExceptionBaseMaskBit]. Only used when non-CMP and SegCtl present |
| ExceptionBasePA                  | Uns32       | Bits [35:29] of the physical address for the BEV overlays. Only used when non-CMP and SegCtl present                           |
| l1BufferCache                    | Boolean     | L1 Buffer Cache                                                                                                                |
| EIC_OPTION                       | Uns32       | Override the external interrupt controller EIC_OPTION                                                                          |
| ICU_NUMINTERRUPTS                | Uns32       | ICU system only: override GIC_SH_CONFIG.NUMINTERRUPTS                                                                          |
| icuBaseAddress                   | Uns32       | ICU system only: Override icuBaseAddress. This should be configured to enable ICU.                                             |
| icuPolarity                      | Uns32       | ICU system only: Override icuPolarity                                                                                          |
| icuTrigger                       | Uns32       | ICU system only: Override icuTrigger                                                                                           |
| icuDual                          | Uns32       | ICU system only: Override icuDual                                                                                              |
| hasImpl17                        | Boolean     | Enable read/write of Impl17 bit in Status register                                                                             |
| hasImpl16                        | Boolean     | Enable read/write of Impl16 bit in Status register                                                                             |
| ISPRAM_SIZE                      | Uns32       | Encoded size of the ISPRAM region (log2( <ispram bytes="" in="" size="">) - 11)</ispram>                                       |
| ISPRAM_BASE                      | Uns64       | Starting physical address of the ISPRAM region                                                                                 |
| ISPRAM_ENABLE                    | Boolean     | Set the enable bit of the ISPRAM region's tag (used to enable the ISPRAM region prior to reset)                                |
| ISPRAM_FILE                      | String      | Load a MIPS hex file into the ISPRAM region prior to reset                                                                     |
| DSPRAM_SIZE                      | Uns32       | Encoded size of the DSPRAM region (log2( <dspram bytes="" in="" size="">) - 11)</dspram>                                       |
| DSPRAM_BASE                      | Uns64       | Starting physical address of the DSPRAM region                                                                                 |
| DSPRAM_ENABLE                    | Boolean     | Set the enable bit of the DSPRAM region's tag (used to enable the DSPRAM region prior to reset)                                |
| DSPRAM_PRESENT                   | Boolean     | DSPRAM is present with SAAR                                                                                                    |
| USPRAM_SIZE                      | Uns32       | Encoded size of the USPRAM region (log2( <uspram bytes="" in="" size="">) - 11)</uspram>                                       |
| USPRAM_BASE                      | Uns64       | Starting physical address of the USPRAM region                                                                                 |
| USPRAM_ENABLE                    | Boolean     | Set the enable bit of the USPRAM region's tag (used to enable the USPRAM region prior to reset)                                |
| USPRAM_FILE                      | String      | Load a MIPS hex file into the USPRAM region prior to reset                                                                     |
| misaligned Data Exception        | Enumeration | Select misaligned data access exception signaling: never, checkCCA or always (never, checkCCA or always)                       |
| ${\bf commitTlbwErr}$            | Boolean     | Commit TLBWI/TLBRI on ECC; in MIPS_DV_MODE only                                                                                |

Table 8.1: Parameters that can be set in: CPU

## 8.1 Parameter values

These are the current parameter values.

| Name                     | Value   |
|--------------------------|---------|
| (Others)                 |         |
| variant                  | M6250   |
| endian                   | none    |
| cacheenable              | default |
| cachedebug               | 0       |
| cacheextbiuinfo          | 0x0     |
| mipsHexFile              |         |
| IMPERAS_MIPS_AVP_OPCODES | F       |
| cacheIndexBypassTLB      | F       |
| MIPS_TRACE               | F       |
| gprNames                 | F       |
| supervisorMode           | F       |
| busErrors                | Т       |
| fixedMMU                 | F       |
| fixedDbgRegSize          | F       |
| removeDSP                | F       |
| removeCMP                | F       |
| removeFP                 | F       |
| removeFTLB               | F       |
| isISA                    | F       |
| hiddenTLBentries         | F       |
| perfCounters             | 0       |
| MTFPU                    | 0       |
| supportDenormals         | F       |
| VPE0MaxTC                | 0       |
| VPE1MaxTC                | 0       |
| mpuRegions               | 0       |
| mpuType                  | 0       |
| mpuEnable                | F       |
| mpuSegment0              | 0       |
| mpuSegment1              | 0       |
| mpuSegment2              | 0       |
| mpuSegment3              | 0       |
| mpuSegment4              | 0       |
| mpuSegment5              | 0       |
| mpuSegment6              | 0       |
| mpuSegment7              | 0       |
| mpuSegment8              | 0       |
| mpuSegment9              | 0       |
| mpuSegment10             | 0       |
| mpuSegment11             | 0       |
| mpuSegment12             | 0       |

| mpuSegment13         | 0    |
|----------------------|------|
| mpuSegment14         | 0    |
| mpuSegment15         | 0    |
| mvpconf0vpe          | 0    |
| tcDisable            | 0    |
| vpeDisable           | 0    |
| mvpconf0tc           | 0    |
| mvpconf0pcp          | F    |
| mvpconf0tcp          | F    |
| mvpconf1c1f          | F    |
| mvpcontrolPolicyMode | F    |
| hasFDC               | 0    |
| licenseWarningDays   | 15   |
| MIPS_UHI             | F    |
| mipsUhiArgs          | 1    |
| mipsUhiJail          |      |
| MIPS_DV_MODE         | F    |
| MIPS_MAGIC_OPCODES   | F    |
| enableTrickbox       | F    |
| fpuexcdisable        | F    |
| TRU_PRESENT          | F    |
| ucLLwordsLocked      | 0    |
| FUSA                 | F    |
| CPC_FAULT_SUPPORTED  | 0    |
| CPC_FAULT_ENABLE     | 0    |
| cop2Bits             | 32   |
| cop2FileName         |      |
| udiConfig            | 0    |
| udiFileName          |      |
| vectoredinterrupt    | F    |
| externalinterrupt    | F    |
| rootFixedMMU         | F    |
| rootMMUSizeM1        | 0    |
| srsctlHSS            | 0    |
| firPS                | 0    |
| firHas2008           | 0    |
| usePreciseFpu        | 0    |
| simulateLite         | NONE |
| pridCompanyOptions   | 0    |
| pridRevision         | 0    |
| globalClusterNum     | 0    |
| intctlIPTI           | 0    |
| intctlIPFDC          | 0    |
| intctlIPPCI          | 0    |
| numWatch             | 0    |
|                      |      |

| xconfigSpecified | F |
|------------------|---|
| segcfg0PA        | 0 |
| segcfg1PA        | 0 |
| segcfg2PA        | 0 |
| segcfg3PA        | 0 |
| segcfg4PA        | 0 |
| segcfg5PA        | 0 |
| segcfg0AM        | 0 |
| segcfg1AM        | 0 |
| segcfg2AM        | 0 |
| segcfg3AM        | 0 |
| segcfg4AM        | 0 |
| segcfg5AM        | 0 |
| segcfg0EU        | 0 |
| segcfg1EU        | 0 |
| segcfg2EU        | 0 |
| segcfg3EU        | 0 |
| segcfg4EU        | 0 |
| segcfg5EU        | 0 |
| segcfg0C         | 0 |
| segcfg1C         | 0 |
| segcfg2C         | 0 |
| segcfg3C         | 0 |
| segcfg4C         | 0 |
| segcfg5C         | 0 |
| cdmmSize         | 0 |
| configAR         | 0 |
| configBM         | 0 |
| configDSP        | F |
| configISP        | F |
| configK0         | 0 |
| configKU         | 0 |
| configK23        | 0 |
| configMDU        | F |
| configMM         | F |
| configMT         | 0 |
| configSB         | F |
| configBCP        | F |
| MIPS16eASE       | F |
| config1DA        | 0 |
| config1DL        | 0 |
| config1DS        | 0 |
| config1EP        | F |
| config1IA        | 0 |
| config1IL        | 0 |

| config1IS             | 0 |
|-----------------------|---|
| config1MMUSizeM1      | 0 |
| config1MMUSizeM1_VPE1 | 0 |
| config1MMUSizeM1_VPE2 | 0 |
| config1MMUSizeM1_VPE3 | 0 |
| config1WR             | F |
| config1PC             | F |
|                       | F |
| config1C2             |   |
| config2SU             | 0 |
| config2SS             | 0 |
| config2SL             | 0 |
| config2SA             | 0 |
| config3BI             | F |
| config3BP             | F |
| config3CDMM           | F |
| config3CTXTC          | F |
| config3DSPP           | F |
| config3DSP2P          | F |
| config3IPLW           | 0 |
| config3ISA            | 0 |
| config3ISAOnExc       | F |
| config3ITL            | F |
| config3LPA            | F |
| config3MCU            | F |
| config3MMAR           | 0 |
| config3RXI            | F |
| config3SC             | F |
| config3ULRI           | F |
| config3VZ             | F |
| config3MSAP           | F |
| config3CMGCR          | F |
| config3SP             | F |
| config3TL             | 0 |
| config3PW             | F |
| config4AE             | F |
| config4IE             | 0 |
| config4MMUConfig      | 0 |
| config4MMUExtDef      | 0 |
| config4VTLBSizeExt    | 0 |
| config4KScrExist      | 0 |
| config5EVA            | F |
| config5LLB            | F |
| config5MRP            | F |
| config5NFExists       | F |
| mips32Macro           | F |
|                       |   |

| config5MSAEn                 | F  |
|------------------------------|----|
| config5MVH                   | F  |
| config5DEC                   | F  |
| config5GI                    | 0  |
| config5CRCP                  | F  |
| config5VP                    | F  |
| config6FTLBEn                | F  |
| config7AR                    | F  |
| config7DCIDX_MODE            | 0  |
| config7HCI                   | F  |
| config7IAR                   | F  |
|                              |    |
| config7WII                   | F  |
| config7ES                    | 0  |
| config7WR                    | F  |
| config7FPR                   | F  |
| config7USP                   | 0  |
| config7BTLM                  | F  |
| config7BusSlp                | F  |
| config7IVAD                  | F  |
| config7RPS                   | F  |
| statusFR                     | F  |
| fcsrABS2008                  | F  |
| fcsrNAN2008                  | F  |
| numMaarRegs                  | 6  |
| srsconf0SRS1                 | 0  |
| srsconf0SRS2                 | 0  |
| srsconf0SRS3                 | 0  |
| wiredLimit                   | 0  |
| wiredLimitBits               | 0  |
| wiredWiredBits               | 0  |
| cdmmBaseCI                   | F  |
| parityEnable                 | 1  |
| useMpTb                      | Т  |
| ExceptionBase                | 0  |
| UseExceptionBase             | F  |
| firstBEVExceptionBaseMaskBit | 20 |
| EVAReset                     | F  |
| ExceptionBaseMask            | 0  |
| ExceptionBasePA              | 0  |
| l1BufferCache                | F  |
| EIC_OPTION                   | 2  |
| ICU_NUMINTERRUPTS            | 0  |
| icuBaseAddress               | 0  |
| icuPolarity                  | 0  |
| icuTrigger                   | 0  |
| Icu 111ggei                  | U  |

| icuDual                   | 0     |
|---------------------------|-------|
| hasImpl17                 | F     |
| hasImpl16                 | F     |
| ISPRAM_SIZE               | 0     |
| ISPRAM_BASE               | 0     |
| ISPRAM_ENABLE             | F     |
| ISPRAM_FILE               |       |
| DSPRAM_SIZE               | 0     |
| DSPRAM_BASE               | 0     |
| DSPRAM_ENABLE             | F     |
| DSPRAM_PRESENT            | F     |
| USPRAM_SIZE               | 0     |
| USPRAM_BASE               | 0     |
| USPRAM_ENABLE             | F     |
| USPRAM_FILE               |       |
| misaligned Data Exception | never |
| commitTlbwErr             | F     |

Table 8.2: Parameter values

# **Execution Modes**

| Mode       | Code |
|------------|------|
| KERNEL     | 0    |
| DEBUG      | 1    |
| SUPERVISOR | 2    |
| USER       | 3    |

Table 9.1: Modes implemented in: CPU

# Exceptions

| Exception | Code |
|-----------|------|
| Int       | 0    |
| Mod       | 1    |
| TLBL      | 2    |
| TLBS      | 3    |
| AdEL      | 4    |
| AdES      | 5    |
| IBE       | 6    |
| DBE       | 7    |
| Sys       | 8    |
| Вр        | 9    |
| RI        | 10   |
| CpU       | 11   |
| Ov        | 12   |
| Tr        | 13   |
| FPE       | 15   |
| Impl1     | 16   |
| Impl2     | 17   |
| C2E       | 18   |
| TLBRI     | 19   |
| TLBXI     | 20   |
| MDMX      | 22   |
| WATCH     | 23   |
| MCheck    | 24   |
| Thread    | 25   |
| DSPDis    | 26   |
| GE        | 27   |
| Prot      | 29   |
| CacheErr  | 30   |

Table 10.1: Exceptions implemented in: CPU

## Hierarchy of the model

A CPU core may be configured to instance many processors of a Symmetrical Multi Processor (SMP). A CPU core may also have sub elements within a processor, for example hardware threading blocks.

OVP processor models can be written to include SMP blocks and to have many levels of hierarchy. Some OVP CPU models may have a fixed hierarchy, and some may be configured by settings in a configuration register. Please see the register definitions of this model.

This model documentation shows the settings and hierarchy of the default settings for this model variant.

### 11.1 Level 1: CPU

This level in the model hierarchy has 16 commands. This level in the model hierarchy has 6 register groups:

| Group name          | Registers |
|---------------------|-----------|
| Core                | 65        |
| DSP                 | 9         |
| Shadow              | 128       |
| COP0                | 62        |
| SPRAM               | 15        |
| Integration_support | 1         |

Table 11.1: Register groups

This level in the model hierarchy has no children.

## **Model Commands**

A Processor model can implement one or more **Model Commands** available to be invoked from the simulator command line, from the OP API or from the Imperas Multiprocessor Debugger.

### 12.1 Level 1: CPU

### 12.1.1 isync

specify instruction address range for synchronous execution

| Argument   | Type  | Description                                  |
|------------|-------|----------------------------------------------|
| -addresshi | Uns64 | end address of synchronous execution range   |
| -addresslo | Uns64 | start address of synchronous execution range |

Table 12.1: isync command arguments

### 12.1.2 itrace

enable or disable instruction tracing

| Argument          | Type    | Description                                   |
|-------------------|---------|-----------------------------------------------|
| -after            | Uns64   | apply after this many instructions            |
| -enable           | Boolean | enable instruction tracing                    |
| -instructioncount | Boolean | include the instruction number in each trace  |
| -memory           | String  | show memory accesses by this instruction. Ar- |
|                   |         | gument can be any combination of X (execute), |
|                   |         | L (load or store access) and S (system)       |
| -off              | Boolean | disable instruction tracing                   |
| -on               | Boolean | enable instruction tracing                    |
| -processorname    | Boolean | Include processor name in all trace lines     |
| -registerchange   | Boolean | show registers changed by this instruction    |
| -registers        | Boolean | show registers after each trace               |

Table 12.2: itrace command arguments

### 12.1.3 mipsCOP0

query a COP0 register value using <register><select>

| Argument  | Type  | Description                        |
|-----------|-------|------------------------------------|
| -register | Uns32 | specify the COP0 register resource |
| -select   | Uns32 | specify the COP0 register select   |

Table 12.3: mipsCOP0 command arguments

### 12.1.4 mipsCacheDisable

### 12.1.4.1 Argument description

Disables tag or full cache model

### 12.1.5 mipsCacheEnable

enable tag or full cache model

| Argument | Type    | Description                      |
|----------|---------|----------------------------------|
| -debug   | Int32   | set cache model debug flags      |
| -full    | Boolean | enable full cache model          |
| -tag     | Boolean | enable cache tag line only model |

Table 12.4: mipsCacheEnable command arguments

### 12.1.6 mipsCacheRatio

Report current hit ratio for selected cache

| Argument | Type    | Description                 |
|----------|---------|-----------------------------|
| -dcache  | Boolean | report hit ratio for dcache |
| -icache  | Boolean | report hit ratio for icache |

Table 12.5: mipsCacheRatio command arguments

### 12.1.7 mipsCacheReport

#### 12.1.7.1 Argument description

Report current cache statistics

#### 12.1.8 mipsCacheReset

#### 12.1.8.1 Argument description

reset the cache model

### 12.1.9 mipsCacheTrace

Control the tracing of cache accesses

| Argument    | Type    | Description                |
|-------------|---------|----------------------------|
| -noartifact | Boolean |                            |
| -nocached   | Boolean |                            |
| -nodcache   | Boolean |                            |
| -noicache   | Boolean |                            |
| -notrue     | Boolean |                            |
| -nouncached | Boolean |                            |
| -off        | Boolean | turn off the cache tracing |
| -on         | Boolean | turn on the cache tracing  |

Table 12.6: mipsCacheTrace command arguments

### 12.1.10 mipsDebugFlags

Set the mips model debug value

| Argument | Type  | Description                    |
|----------|-------|--------------------------------|
| -value   | Uns32 | specify mips model debug flags |

Table 12.7: mipsDebugFlags command arguments

### 12.1.11 mipsReadRegister

Read processor register using <resource><offset>

| Argument  | Type  | Description           |
|-----------|-------|-----------------------|
| -offset   | Uns32 | the register offset   |
| -resource | Uns32 | the register resource |

Table 12.8: mipsReadRegister command arguments

### 12.1.12 mipsReadTLBEntry

read a TLB entry specified by the index

| Argument | Type  | Description          |
|----------|-------|----------------------|
| -index   | Uns64 | select the TLB entry |

Table 12.9: mipsReadTLBEntry command arguments

### 12.1.13 mipsTLBDump

#### 12.1.13.1 Argument description

Dumps the current contents of the TLB

### 12.1.14 mipsTLBGetPhys

Reports the entry(s) in the TLB that match the given virtual address and ASID

| Argument | Type  | Description     |
|----------|-------|-----------------|
| -asid    | Uns64 | ASID            |
| -va      | Uns64 | virtual address |

Table 12.10: mipsTLBGetPhys command arguments

### 12.1.15 mipsWriteRegister

Write processor register using <resource><offset><value>

| Argument  | Type  | Description                    |
|-----------|-------|--------------------------------|
| -offset   | Uns32 | the register offset            |
| -resource | Uns32 | the register resource          |
| -value    | Uns64 | the value to write to register |

Table 12.11: mipsWriteRegister command arguments

### 12.1.16 mipsWriteTLBEntry

Writes values to a TLB entry using the index, lo0, lo1, hi0 and mask fields

| Argument | Type  | Description                 |
|----------|-------|-----------------------------|
| -hi0     | Uns64 | the TLB entry high address  |
| -index   | Uns64 | the TLB entry index         |
| -lo0     | Uns64 | the TLB entry low address 0 |
| -lo1     | Uns64 | the TLB entry low address 1 |
| -mask    | Uns64 | the TLB entry mask          |

Table 12.12: mipsWriteTLBEntry command arguments

# Registers

## 13.1 Level 1: CPU

### 13.1.1 Core

Registers at level:1, type:CPU group:Core

| Name             | Bits | Initial-Hex | RW | Description     |
|------------------|------|-------------|----|-----------------|
| zero             | 32   | 0           | r- | constant zero   |
| at               | 32   | 0           | rw |                 |
| v0               | 32   | 0           | rw |                 |
| v1               | 32   | 0           | rw |                 |
| a0               | 32   | 0           | rw |                 |
| a1               | 32   | 0           | rw |                 |
| a2               | 32   | 0           | rw |                 |
| a3               | 32   | 0           | rw |                 |
| t0               | 32   | 0           | rw |                 |
| t1               | 32   | 0           | rw |                 |
| t2               | 32   | 0           | rw |                 |
| t3               | 32   | 0           | rw |                 |
| t4               | 32   | 0           | rw |                 |
| t5               | 32   | 0           | rw |                 |
| t6               | 32   | 0           | rw |                 |
| t7               | 32   | 0           | rw |                 |
| s0               | 32   | 0           | rw |                 |
| s1               | 32   | 0           | rw |                 |
| s2               | 32   | 0           | rw |                 |
| s3               | 32   | 0           | rw |                 |
| s4               | 32   | 0           | rw |                 |
| s5               | 32   | 0           | rw |                 |
| s6               | 32   | 0           | rw |                 |
| s7               | 32   | 0           | rw |                 |
| t8               | 32   | 0           | rw |                 |
| t9               | 32   | 0           | rw |                 |
| k0               | 32   | 0           | rw |                 |
| k1               | 32   | 0           | rw |                 |
| gp               | 32   | 0           | rw |                 |
| $^{\mathrm{sp}}$ | 32   | 0           | rw | stack pointer   |
| s8               | 32   | 0           | rw | frame pointer   |
| ra               | 32   | 0           | rw |                 |
| pc               | 32   | bfc00000    | rw | program counter |
| r0               | 32   | 0           | r- | constant zero   |

| r1  | 32 | 0 | rw |               |
|-----|----|---|----|---------------|
| r2  | 32 | 0 | rw |               |
| r3  | 32 | 0 | rw |               |
| r4  | 32 | 0 | rw |               |
| r5  | 32 | 0 | rw |               |
| r6  | 32 | 0 | rw |               |
| r7  | 32 | 0 | rw |               |
| r8  | 32 | 0 | rw |               |
| r9  | 32 | 0 | rw |               |
| r10 | 32 | 0 | rw |               |
| r11 | 32 | 0 | rw |               |
| r12 | 32 | 0 | rw |               |
| r13 | 32 | 0 | rw |               |
| r14 | 32 | 0 | rw |               |
| r15 | 32 | 0 | rw |               |
| r16 | 32 | 0 | rw |               |
| r17 | 32 | 0 | rw |               |
| r18 | 32 | 0 | rw |               |
| r19 | 32 | 0 | rw |               |
| r20 | 32 | 0 | rw |               |
| r21 | 32 | 0 | rw |               |
| r22 | 32 | 0 | rw |               |
| r23 | 32 | 0 | rw |               |
| r24 | 32 | 0 | rw |               |
| r25 | 32 | 0 | rw |               |
| r26 | 32 | 0 | rw |               |
| r27 | 32 | 0 | rw |               |
| r28 | 32 | 0 | rw |               |
| r29 | 32 | 0 | rw | stack pointer |
| r30 | 32 | 0 | rw | frame pointer |
| r31 | 32 | 0 | rw |               |

Table 13.1: Registers at level 1, type:CPU group:Core

### 13.1.2 DSP

Registers at level:1, type:CPU group:DSP

| Name   | Bits | Initial-Hex | RW | Description |
|--------|------|-------------|----|-------------|
| lo     | 32   | 0           | rw |             |
| hi     | 32   | 0           | rw |             |
| lo1    | 32   | 0           | rw |             |
| hi1    | 32   | 0           | rw |             |
| lo2    | 32   | 0           | rw |             |
| hi2    | 32   | 0           | rw |             |
| lo3    | 32   | 0           | rw |             |
| hi3    | 32   | 0           | rw |             |
| dspctl | 32   | 0           | rw | DSP control |

Table 13.2: Registers at level 1, type:CPU group:DSP

### 13.1.3 Shadow

Registers at level:1, type:CPU group:Shadow

| Name                   | Bits | Initial-Hex | RW | Description   |
|------------------------|------|-------------|----|---------------|
| zero[0]                | 32   | 0           | r- | constant zero |
| at[0]                  | 32   | 0           | rw | CONDUMIT ZCIU |
| v0[0]                  | 32   | 0           | rw |               |
| v1[0]                  | 32   | 0           |    |               |
| a0[0]                  | 32   | 0           | rw |               |
|                        | 32   | 0           | rw |               |
| a1[0]                  |      |             | rw |               |
| a2[0]                  | 32   | 0           | rw |               |
| a3[0]                  | 32   | 0           | rw |               |
| t0[0]                  | 32   | 0           | rw |               |
| t1[0]                  | 32   | 0           | rw |               |
| t2[0]                  | 32   | 0           | rw |               |
| t3[0]                  | 32   | 0           | rw |               |
| t4[0]                  | 32   | 0           | rw |               |
| t5[0]                  | 32   | 0           | rw |               |
| t6[0]                  | 32   | 0           | rw |               |
| t7[0]                  | 32   | 0           | rw |               |
| s0[0]                  | 32   | 0           | rw |               |
| s1[0]                  | 32   | 0           | rw |               |
| s2[0]                  | 32   | 0           | rw |               |
| s3[0]                  | 32   | 0           | rw |               |
| s4[0]                  | 32   | 0           | rw |               |
| s5[0]                  | 32   | 0           | rw |               |
| s6[0]                  | 32   | 0           | rw |               |
| s7[0]                  | 32   | 0           | rw |               |
| t8[0]                  | 32   | 0           | rw |               |
| t9[0]                  | 32   | 0           | rw |               |
| k0[0]                  | 32   | 0           | rw |               |
| k1[0]                  | 32   | 0           | rw |               |
| gp[0]                  | 32   | 0           | rw |               |
| $\operatorname{sp}[0]$ | 32   | 0           | rw | stack pointer |
| s8[0]                  | 32   | 0           | rw | frame pointer |
| ra[0]                  | 32   | 0           | rw |               |
| zero[1]                | 32   | 0           | r- | constant zero |
| at[1]                  | 32   | 0           | rw |               |
| v0[1]                  | 32   | 0           | rw |               |
| v1[1]                  | 32   | 0           | rw |               |
| a0[1]                  | 32   | 0           | rw |               |
| a1[1]                  | 32   | 0           | rw |               |
| a2[1]                  | 32   | 0           | rw |               |
| a3[1]                  | 32   | 0           | rw |               |
| t0[1]                  | 32   | 0           | rw |               |
| t1[1]                  | 32   | 0           | rw |               |
| t2[1]                  | 32   | 0           | rw |               |
| t3[1]                  | 32   | 0           | rw |               |
| t4[1]                  | 32   | 0           | rw |               |
| t5[1]                  | 32   | 0           | rw |               |
| t6[1]                  | 32   | 0           | rw |               |
| t7[1]                  | 32   | 0           | rw |               |
| s0[1]                  | 32   | 0           | rw |               |
| s1[1]                  | 32   | 0           | rw |               |
| s1[1]<br>s2[1]         | 32   | 0           | rw |               |
| s2[1]<br>s3[1]         | 32   | 0           |    |               |
| s4[1]                  | 32   | 0           | rw |               |
| s4[1]<br>s5[1]         | 32   | 0           | rw |               |
|                        | 32   | 0           | rw |               |
| s6[1]                  | ე/   | U           | rw |               |

| s7[1]                  | 32 | 0 | rw |                   |
|------------------------|----|---|----|-------------------|
| t8[1]                  | 32 | 0 | rw |                   |
| t9[1]                  | 32 | 0 | rw |                   |
| k0[1]                  | 32 | 0 | rw |                   |
| k1[1]                  | 32 | 0 | rw |                   |
| gp[1]                  | 32 | 0 | rw |                   |
| $\operatorname{sp}[1]$ | 32 | 0 | rw | stack pointer     |
| s8[1]                  | 32 | 0 | rw | frame pointer     |
| ra[1]                  | 32 | 0 | rw |                   |
| r0[0]                  | 32 | 0 | r- | constant zero     |
| r1[0]                  | 32 | 0 | rw | COLIDERIN 2010    |
| r2[0]                  | 32 | 0 | rw |                   |
| r3[0]                  | 32 | 0 |    |                   |
| r4[0]                  | 32 | 0 | rw |                   |
|                        |    |   | rw |                   |
| r5[0]                  | 32 | 0 | rw |                   |
| r6[0]                  | 32 | 0 | rw |                   |
| r7[0]                  | 32 | 0 | rw |                   |
| r8[0]                  | 32 | 0 | rw |                   |
| r9[0]                  | 32 | 0 | rw |                   |
| r10[0]                 | 32 | 0 | rw |                   |
| r11[0]                 | 32 | 0 | rw |                   |
| r12[0]                 | 32 | 0 | rw |                   |
| r13[0]                 | 32 | 0 | rw |                   |
| r14[0]                 | 32 | 0 | rw |                   |
| r15[0]                 | 32 | 0 | rw |                   |
| r16[0]                 | 32 | 0 | rw |                   |
| r17[0]                 | 32 | 0 | rw |                   |
| r18[0]                 | 32 | 0 | rw |                   |
| r19[0]                 | 32 | 0 | rw |                   |
| r20[0]                 | 32 | 0 | rw |                   |
| r21[0]                 | 32 | 0 | rw |                   |
| r22[0]                 | 32 | 0 | rw |                   |
| r23[0]                 | 32 | 0 | rw |                   |
| r24[0]                 | 32 | 0 | rw |                   |
| r25[0]                 | 32 | 0 | rw |                   |
| r26[0]                 | 32 | 0 | rw |                   |
| r27[0]                 | 32 | 0 | rw |                   |
| r28[0]                 | 32 | 0 | rw |                   |
| r29[0]                 | 32 | 0 | rw | stack pointer     |
| r30[0]                 | 32 | 0 | rw | frame pointer     |
| r31[0]                 | 32 | 0 | rw | numo pomior       |
| r0[1]                  | 32 | 0 | r- | constant zero     |
| r1[1]                  | 32 | 0 |    | COLIDUCATIV ZCI O |
| r2[1]                  | 32 | 0 | rw |                   |
| r2[1]<br>r3[1]         | 32 | 0 | rw |                   |
|                        | 32 |   | rw |                   |
| r4[1]                  |    | 0 | rw |                   |
| r5[1]                  | 32 | 0 | rw |                   |
| r6[1]                  | 32 | 0 | rw |                   |
| r7[1]                  | 32 | 0 | rw |                   |
| r8[1]                  | 32 | 0 | rw |                   |
| r9[1]                  | 32 | 0 | rw |                   |
| r10[1]                 | 32 | 0 | rw |                   |
| r11[1]                 | 32 | 0 | rw |                   |
| r12[1]                 | 32 | 0 | rw |                   |
| r13[1]                 | 32 | 0 | rw |                   |
| r14[1]                 | 32 | 0 | rw |                   |
|                        |    |   |    |                   |

| r15[1] | 32 | 0 | rw |               |
|--------|----|---|----|---------------|
| r16[1] | 32 | 0 | rw |               |
| r17[1] | 32 | 0 | rw |               |
| r18[1] | 32 | 0 | rw |               |
| r19[1] | 32 | 0 | rw |               |
| r20[1] | 32 | 0 | rw |               |
| r21[1] | 32 | 0 | rw |               |
| r22[1] | 32 | 0 | rw |               |
| r23[1] | 32 | 0 | rw |               |
| r24[1] | 32 | 0 | rw |               |
| r25[1] | 32 | 0 | rw |               |
| r26[1] | 32 | 0 | rw |               |
| r27[1] | 32 | 0 | rw |               |
| r28[1] | 32 | 0 | rw |               |
| r29[1] | 32 | 0 | rw | stack pointer |
| r30[1] | 32 | 0 | rw | frame pointer |
| r31[1] | 32 | 0 | rw |               |

Table 13.3: Registers at level 1, type:CPU group:Shadow

### 13.1.4 COP0

Registers at level:1, type:CPU group:COP0

| Name      | Bits | Initial-Hex | RW | Description                 |
|-----------|------|-------------|----|-----------------------------|
| sr        | 32   | 400004      | rw | CP0 register 12/0 (status)  |
| bad       | 32   | 0           | rw | CP0 register 8/0 (badvaddr) |
| cause     | 32   | 0           | rw | CP0 register 13/0 (cause)   |
| index     | 32   | 0           | rw | CP0 register 0/0            |
| entrylo0  | 32   | 0           | rw | CP0 register 2/0            |
| entrylo1  | 32   | 0           | rw | CP0 register 3/0            |
| context   | 32   | 0           | rw | CP0 register 4/0            |
| userlocal | 32   | 0           | rw | CP0 register 4/2            |
| pagemask  | 32   | 0           | rw | CP0 register 5/0            |
| pagegrain | 32   | c8000000    | rw | CP0 register 5/1            |
| wired     | 32   | 0           | rw | CP0 register 6/0            |
| hwrena    | 32   | 0           | rw | CP0 register 7/0            |
| badvaddr  | 32   | 0           | rw | CP0 register 8/0            |
| badinstr  | 32   | 0           | rw | CP0 register 8/1            |
| badinstrp | 32   | 0           | rw | CP0 register 8/2            |
| count     | 32   | 0           | rw | CP0 register 9/0            |
| entryhi   | 32   | 0           | rw | CP0 register 10/0           |
| compare   | 32   | 0           | rw | CP0 register 11/0           |
| status    | 32   | 400004      | rw | CP0 register 12/0           |
| intctl    | 32   | e0030000    | rw | CP0 register 12/1           |
| srsctl    | 32   | 4000000     | rw | CP0 register 12/2           |
| srsmap    | 32   | 0           | rw | CP0 register 12/3           |
| viewipl   | 32   | 0           | rw | CP0 register 12/4           |
| srsmap2   | 32   | 0           | rw | CP0 register 12/5           |
| viewripl  | 32   | 0           | rw | CP0 register 13/4           |
| nestedexc | 32   | 0           | rw | CP0 register 13/5           |
| epc       | 32   | 0           | rw | CP0 register 14/0           |
| nestedepc | 32   | 0           | rw | CP0 register 14/2           |
| prid      | 32   | 1ab20       | rw | CP0 register 15/0           |
| ebase     | 32   | 80000000    | rw | CP0 register 15/1           |
| cdmmbase  | 32   | 0           | rw | CP0 register 15/2           |

|           |    | 0.0000   |    | CVD               |
|-----------|----|----------|----|-------------------|
| config    | 32 | 81a08882 | rw | CP0 register 16/0 |
| config1   | 32 | bea95482 | rw | CP0 register 16/1 |
| config2   | 32 | 80000000 | rw | CP0 register 16/2 |
| config3   | 32 | 8c2abc28 | rw | CP0 register 16/3 |
| config4   | 32 | c0fc0000 | rw | CP0 register 16/4 |
| config5   | 32 | 2011     | rw | CP0 register 16/5 |
| config7   | 32 | 80000000 | rw | CP0 register 16/7 |
| lladdr    | 32 | 0        | rw | CP0 register 17/0 |
| debug     | 32 | 2028000  | rw | CP0 register 23/0 |
| depc      | 32 | 0        | rw | CP0 register 24/0 |
| errctl    | 32 | 0        | rw | CP0 register 26/0 |
| itaglo    | 32 | 0        | rw | CP0 register 28/0 |
| idatalo   | 32 | 0        | rw | CP0 register 28/1 |
| dtaglo    | 32 | 0        | rw | CP0 register 28/2 |
| ddatalo   | 32 | 0        | rw | CP0 register 28/3 |
| l23taglo  | 32 | 0        | rw | CP0 register 28/4 |
| l23datalo | 32 | 0        | rw | CP0 register 28/5 |
| itaghi    | 32 | 0        | rw | CP0 register 29/0 |
| idatahi   | 32 | 0        | rw | CP0 register 29/1 |
| dtaghi    | 32 | 0        | rw | CP0 register 29/2 |
| ddatahi   | 32 | 0        | rw | CP0 register 29/3 |
| l23taghi  | 32 | 0        | rw | CP0 register 29/4 |
| l23datahi | 32 | 0        | rw | CP0 register 29/5 |
| errorepc  | 32 | 0        | rw | CP0 register 30/0 |
| desave    | 32 | 0        | rw | CP0 register 31/0 |
| kscratch1 | 32 | 0        | rw | CP0 register 31/2 |
| kscratch2 | 32 | 0        | rw | CP0 register 31/3 |
| kscratch3 | 32 | 0        | rw | CP0 register 31/4 |
| kscratch4 | 32 | 0        | rw | CP0 register 31/5 |
| kscratch5 | 32 | 0        | rw | CP0 register 31/6 |
| kscratch6 | 32 | 0        | rw | CP0 register 31/7 |

Table 13.4: Registers at level 1, type:CPU group:COP0

### 13.1.5 SPRAM

Registers at level:1, type:CPU group:SPRAM

| Name          | Bits | Initial-Hex | RW | Description |
|---------------|------|-------------|----|-------------|
| ISPRAM_INDEX  | 8    | 0           | rw |             |
| ISPRAM_ENABLE | 8    | 0           | rw |             |
| ISPRAM_SIZE   | 8    | 0           | rw |             |
| ISPRAM_BASE   | 64   | 0           | rw |             |
| ISPRAM_OFFSET | 32   | 0           | rw |             |
| ISPRAM_FILE   | 64   | -           | -w |             |
| ISPRAM_READ   | 32   | -           | -w |             |
| ISPRAM_WRITE  | 32   | -           | -w |             |
| DSPRAM_INDEX  | 8    | 0           | rw |             |
| DSPRAM_ENABLE | 8    | 0           | rw |             |
| DSPRAM_SIZE   | 8    | 0           | rw |             |
| DSPRAM_BASE   | 64   | 0           | rw |             |
| DSPRAM_OFFSET | 32   | 0           | rw |             |
| DSPRAM_READ   | 32   | -           | -w |             |
| DSPRAM_WRITE  | 32   | -           | -w |             |

Table 13.5: Registers at level 1, type:CPU group:SPRAM

### 13.1.6 Integration\_support

Registers at level:1, type:CPU group:Integration\_support

| Name | Bits | Initial-Hex | RW | Description                           |
|------|------|-------------|----|---------------------------------------|
| stop | 32   | 0           | rw | write with non-zero to stop processor |

Table 13.6: Registers at level 1, type:CPU group:Integration\_support