









All rights reserved. <sup>©</sup> 2000 RiSE<sup>™</sup> Technology

Devices sold by RiSE<sup>™</sup> Technology are covered by the warranty and patent indemnification provisions appearing in it's Terms of Sale only. RiSE<sup>™</sup> Technology makes no warranty, express or implied or by description regarding information set forth herein or regarding the freedom of the described devices from patent infringement. RiSE<sup>™</sup> Technology Company reserves the right to discontinue production and change specifications and prices at any time and without notice,

RiSE<sup>™</sup> Technology assumes no responsibility for the use of any circuitry other than circuitry embodied in a RiSE<sup>™</sup> Technology product. No other circuits, patents or licensees are implied.

RISE<sup>™</sup> Technology products are not authorized for use as components in life systems or as part of life support devices.

RiSE<sup>™</sup> and RiSE<sup>™</sup> iDragon<sup>™</sup> are trademarks of RiSE<sup>™</sup> Technology Company. All other trademarks are properties of respective owners.

Products, brand and corporate names used in this publication are for identification purposes only and may be trademarks of their respective companies.

This document contains information about a product under development at RiSE<sup>™</sup> Technology Company and is intended to assist in evaluating this product. This is not a released product and specifications are subject to change without notice.





# **Table of Contents**

| INTRODUCTION                                                           | 5  |
|------------------------------------------------------------------------|----|
| CPUID                                                                  | 5  |
| CPU SPEED DETECTION                                                    | 6  |
| CORE SPEED RATING                                                      | 6  |
| VERSION/STEPPING SPECIFIC CONFIGURATION                                | 7  |
| CONTROL REGISTER CR4                                                   | 8  |
| RISE <sup>™</sup> iDragon <sup>™</sup> PROCESSOR RESET AND INIT STATES | 8  |
| SYSTEM MANAGEMENT MODE                                                 | 9  |
| 8.1 SMM STATE-SAVE AREA                                                | 10 |
| 8.2 SMM INITIAL REGISTER VALUES                                        |    |
| 8.4 I/O INSTRUCTION RESTART                                            |    |
| 8.5 AUTO HALT RESTART                                                  | 13 |
| 8.6 BACK-TO-BACK SMI INTERRUPTS WHEN USING I/O INSTRUCTION RESTART     | 13 |
|                                                                        |    |

| CONFIGURATION | CETTINIC   | 1/ |   |
|---------------|------------|----|---|
| CONFIGURATION | 3E 1/1 ING |    | Ł |
|               | ,          |    |   |

 $\bigcirc$ 





# **List of Tables**

| TABLE 1. | CPUID RETURN VALUES WITH EAX == 0                                                               | 5  |
|----------|-------------------------------------------------------------------------------------------------|----|
| TABLE 2. | CPUID EAX RETURN VALUES WITH EAX == 1                                                           | 5  |
| TABLE 3. | CPUID EDX RETURN VALUES WITH EAX == 1                                                           | 6  |
| TABLE 4. | CORE SPEED RATING LOOKUP TABLE*                                                                 | 7  |
| TABLE 5. | RISE <sup>™</sup> <i>iDragon</i> <sup>™</sup> PROCESSOR ARCHITECTURAL STATE AFTER RESET OR INIT | 8  |
| TABLE 6. | SMM STATE-SAVE AREA MAP                                                                         | 10 |
| TABLE 7. |                                                                                                 | 11 |
| TABLE 8. | SMM REVISION IDENTIFIER FIELDS                                                                  | 12 |

 $\mathcal{C}$ 





## Introduction

The RiSE<sup> $^{\text{TM}}$ </sup> *iDragon*<sup> $^{\text{TM}}</sup> processor is a sixth generation processor optimized for low-power, high$  $performance multimedia Windows<sup><math>^{\text{TM}}$ </sup> applications. The innovative RiSE<sup> $^{\text{TM}}$ </sup> *iDragon*<sup> $^{\text{TM}}</sup> processor is the first$  $superscalar, superpipelined, Pentium<sup><math>^{\text{RM}}$ </sup> MMX\* compatible processor featuring 3 integer units, 3-way superscalar MMX technology, and a fully pipelined floating point unit. The innovative circuitry of the RiSE<sup> $^{\text{TM}}$ </sup> *iDragon*<sup> $^{\text{TM}}</sup> processor maximizes processing per clock cycle while requiring minimal power consumption –$ providing an ideal choice for cost–effective, power–efficient PC-embedded consumer informationappliance, thin server and thin client systems.</sup></sup></sup>

This document is intended for BIOS and operating system software developers and contains information required to implement system support for the RiSE<sup>™</sup> *iDragon*<sup>™</sup> processor.

# CPUID

The CPUID instruction should be used to detect the RiSE<sup>™</sup> *iDragon*<sup>™</sup> processor and the model–specific features supported. Unsupported features should not be used by the BIOS, operating system, or by the application software. The RiSE<sup>™</sup> *iDragon*<sup>™</sup> processor returns values for the CPUID instruction are shown in Tables 1 through 3. The Intel P55C processor return values are included in the tables for comparison.

When the BIOS identifies the processor, if the processor is a RiSE<sup>™</sup>

- \* *iDragon*<sup>™</sup> processor, its name appears as "RiSE(tm) mP6 (tm) xxx processor"
- \* *iDragon*<sup>™</sup> II processor, its name appears as "RiSE(tm) *mP6* II(tm) xxx processor"
- Where xxx is the rated performance number (refer to Table 4A or 4 B).

| REGISTER    | RiSE <sup>™</sup> <i>mP6</i> <sup>™</sup> | P55C         |
|-------------|-------------------------------------------|--------------|
| EAX         | 1                                         | 1            |
| EBX:ECX:EDX | RiseRiseRise                              | GenuineIntel |

#### TABLE 1. CPUID RETURN VALUES WITH EAX == 0

| TABLE 2. | <b>CPUID EAX RET</b> | <b>URN VALUES</b> | WITH EAX == 1 |
|----------|----------------------|-------------------|---------------|
|----------|----------------------|-------------------|---------------|

| PROCESSOR                                                  | [13:12]<br>Type ID | [11:8]<br>Family ID | [7:4]<br>Model ID | [3:0]<br>Stepping ID |
|------------------------------------------------------------|--------------------|---------------------|-------------------|----------------------|
| RiSE <sup>™</sup> <i>iDragon</i> <sup>™</sup> (0.25 um)    | 0                  | 5                   | 0                 | Varies               |
| RiSE <sup>™</sup> <i>iDragon</i> <sup>™</sup> (0.18 um)    | 0                  | 5                   | 2                 | Varies               |
| RiSE <sup>™</sup> <i>iDragon</i> <sup>™</sup> II (0.25 um) | 0                  | 5                   | 8                 | Varies               |
| RiSE <sup>™</sup> <i>iDragon</i> <sup>™</sup> II (0.18 um) | 0                  | 5                   | 9                 | Varies               |
| P55C                                                       | 0                  | 5                   | 4                 | Varies               |





#### TABLE 3. CPUID EDX RETURN VALUES WITH EAX == 1

| EDX Bits — Meaning                      | RISE <sup>™</sup> mP6 <sup>™</sup> | P55C    | Notes      |
|-----------------------------------------|------------------------------------|---------|------------|
| 0 — Floating Point Unit on Chip (FPU)   | 1                                  | 1       |            |
| 1 — VM86 Extensions (VME)               | 0                                  | 1       |            |
| 2 — Debugging Extensions (DE)           | 0                                  | 1       |            |
| 3 — Page Size Extensions (PSE)          | 0                                  | 0       |            |
| 4 — Time Stamp Counter (TSC)            | 1                                  | 1       |            |
| 5 — Model Specific Registers (MSR)      | 0                                  |         |            |
| 6 — Physical Address Extensions (PAE)   | 0                                  | <` (o > |            |
| 7 — Machine Check Exception (MCE)       | 0                                  | > /t // | $\bigcirc$ |
| 8 — CMPXCHG8B instruction (CX8)         | 0                                  |         | 1          |
| 9 — APIC supported                      | 0                                  | ٢ 1     | 2          |
| 10:11 — RESERVED                        |                                    | -       |            |
| 12 — Memory Type Range Registers (MTRR) | 0                                  | 0       |            |
| 13 — PTE Global Flag (PGE)              | 0                                  | 0       |            |
| 14 — Machine Check Architecture (MCA)   | 0                                  | 0       |            |
| 15 — Conditional Move supported (CMQV)  | 0                                  | 0       |            |
| 16:22 — RESERVED                        | -                                  | -       |            |
| 23 — MMX supported                      | 1                                  | 1       |            |
| 24:31 — RESERVED                        | -                                  | -       |            |

Notes:

- 1. The CMPXCHG8B instruction is supported and always enabled on the RiSE<sup>™</sup>*iDragon*<sup>™</sup> processor; however, as specified in an erratum for early versions of Windows NT\* 4.0, the default CPUID function bit is set to 0.
- 2. Pentium processor multiprocessing capabilities are not supported on the RiSE<sup>™</sup> *iDragon*<sup>™</sup> processor.

# **CPU Speed Detection**

The RiSE<sup> $^{\text{M}}$ </sup> *iDragon*<sup> $^{\text{M}}</sup> processor supports the Time Stamp Counter and the RDTSC instruction. BIOS algorithms may use this facility to measure timed operations for CPU speed detection. During system boot, BIOS detects and displays the speed/ratio for the processor.</sup>$ 

# **CPU Core Speed Rating**

A lookup table that references the processor operating frequency to a Core speed rating number should be incorporated into the speed detection algorithm. Tables 4A and 4B respectively list the current core speed of the RiSE<sup>m</sup> *iDragon*<sup>m</sup> processor and the RiSE<sup>m</sup> *iDragon*<sup>m</sup> Il processor.





|                 | Core Speed | Bus Ratio | Bus Speed |
|-----------------|------------|-----------|-----------|
|                 | 133        | 2:1       | 66        |
|                 | 150        | 2:1       | 75        |
|                 | 166        | 2:1       | 83        |
| <               | 190        | 2:1       | 95        |
| $\sim$          | 200        | 2:1       | 100       |
| $\overline{\ }$ | 238        | 2.5:1     | 95        |
|                 | 250        | 2.5:1     | 100       |
|                 | 285        | 3:1       | 95        |
|                 | 300        | 3:1       | 100       |
| 1               | 333        | 3.5:1     | 95        |
| 1               | 350        | 3.5:1     | 100       |
|                 |            |           |           |

#### TABLE 4A. *iDragon*<sup>™</sup> CORE SPEED RATING LOOKUP TABLE

#### TABLE 4B. *iDragon*<sup>™</sup> I CORE SPEED RATING LOOKUP TABLE

| Bus Speed | Bus Ratio | Core Speed |
|-----------|-----------|------------|
| 66        | 2:1       | 133        |
| 75        | 2:1       | 150        |
| 83        | 2:1       | 166        |
| 95        | 2:1       | 190        |
| 100       | 2:1       | 200        |
| 95        | 2.5:1     | 238        |
| 100       | 2.5:1     | 250        |
| 95        | 3:1       | 285        |
| 100       | 3:1       | 300        |
| 95        | 3.5:1     | 333        |
| 100       | 3.5:1     | 350        |



# **Version / Stepping Specific Configuration**

For the production version of the  $RiSE^{TM}$  *iDragon*<sup>TM</sup> processor, no stepping–specific initialization is required.



to set them.



# **Control Register CR4**

The Pentium<sup>®</sup> processor introduced a new control register (CR4) for controlling many of its new model– specific architectural features. The RiSE<sup>TM</sup> *iDragon*<sup>TM</sup> processor provides a CR4 register compatible with the Pentium processor; however, it does not implement all of the model–specific features that can be controlled through the CR4 register. The CPUID instruction described in Section 0 should be used to determine the features supported by the RiSE<sup>TM</sup> *iDragon*<sup>TM</sup> processor.



Bits VME, PVI, PSE, MCE, PGE and PCE are not supported on the RiSE<sup>™</sup> *iDragon*<sup>™</sup> processor. These six bits return a value of 0 when read and although they cannot be set, no GP exception occurs on attempts

The **DE** bit is reserved on the RiSE<sup>™</sup> *iDragon*<sup>™</sup> processor. The return value when this bit is read and its response to attempts to set it are both undefined; however, no GP exception occurs on attempts to set or clear it.

# RiSE<sup>™</sup>*iDragon*<sup>™</sup> Processor Reset and Init States

The state of each register of the Ri\$E<sup>™</sup> iDragon<sup>™</sup> processor after a RESET or INIT is listed in Table 5.

| TABLE 5.) RISE IDragon PROCESSOR ARCHITECTURAL STATE AFTER RESET OR INIT |                                                                                      |                         |       |  |
|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-------------------------|-------|--|
| REGISTER                                                                 | RESET State                                                                          | INIT State <sup>1</sup> | NOTES |  |
| EFLAGS                                                                   | 0000002H                                                                             |                         | 2     |  |
| EIP                                                                      | 0000FFF0H                                                                            |                         |       |  |
| CS                                                                       | Selector = F000H<br>Base = FFFF0000H<br>Limit = FFFFH<br>AR = Present, R/W, Accessed |                         |       |  |
| SS, DS, ES, FS, GS                                                       | Selector = 0000H<br>Base = 00000000H<br>Limit = FFFFH<br>AR = Present, R/W, Accessed |                         |       |  |
| EAX                                                                      | 0000000H                                                                             |                         | 3     |  |
| EDX                                                                      | 0000050xH                                                                            |                         | 4     |  |
| EBX, ECX, ESI, EDI, EBP, ESP                                             | 0000000H                                                                             |                         |       |  |

# TABLE 5. RISE "Dragon" PROCESSOR ARCHITECTURAL STATE AFTER RESET OR INIT





| REGISTER                | RESET State                                                                | INIT State <sup>1</sup> | NOTES              |
|-------------------------|----------------------------------------------------------------------------|-------------------------|--------------------|
| GDTR, IDTR              | Base = 00000000H<br>Limit = FFFFH<br>AR = Present, R/W                     |                         |                    |
| LDTR, Task Register     | Selector = 0000H<br>Base = 00000000H<br>Limit = FFFFH<br>AR = Present, R/W |                         |                    |
| FPU Stack ST7-ST0       | 00000000000000000000000000000000000000                                     | Unchanged               |                    |
| FPU Control Word        | 0040H                                                                      | Unchanged               |                    |
| FPU Status Word         | 0000H                                                                      | Unchanged               |                    |
| FPU Tag Word            | 5555H                                                                      | Unchanged               | $\bigtriangledown$ |
| FPU Instruction Pointer | 000000000000                                                               | Unchanged               |                    |
| FPU Data Pointer        | 0000000000000                                                              | Unchanged               |                    |
| CR0                     | 60000010H                                                                  |                         | 5                  |
| CR2, CR3, CR4           | 00000000H                                                                  |                         |                    |
| DR7                     | 00000400H                                                                  |                         |                    |
| DR6                     | FFFFOFFOH                                                                  |                         |                    |
| DR0, DR1, DR2, DR3      | 0000000н                                                                   |                         |                    |
| Data and Code Cache     | Invalid                                                                    | Unchanged               |                    |
| TLBs                    | Invalid                                                                    | Invalid                 |                    |
| TSC                     | 0                                                                          | Unchanged               |                    |

#### Notes:

- 1. Unless otherwise specified, the INIT state is the same as the RESET state.
- 2. Software should not depend on the states of the 10 most significant bits of the EFLAGS register following a reset.
- 3. The EAX register contains the results of the Built In Self Test (BIST) when invoked. If EAX = 00000000H then BIST completed successfully. If EAX is non-zero then BIST failed.
- 4. The EDX register contains the RiSE<sup>™</sup>*iDragon*<sup>™</sup> processor identification and revision information.
- 5. The CD and NW flags are unchanged following INIT, bit 4 is set to 1, and all other bits are cleared.

## System Management Mode

The System Management Mode (SMM) of the RiSE<sup>TM</sup> *iDragon*<sup>TM</sup> processor is functionally identical to that of the Pentium<sup>®</sup> processor. SMM handlers should not rely on the availability of any Pentium processor model–specific registers or features that are not supported by the RiSE<sup>TM</sup> *iDragon*<sup>TM</sup> processor. The CPUID instruction should be used to determine the model–specific features available.





#### 8.1 SMM State–Save Area

When the RiSE<sup> $^{\text{M}}$ </sup> *iDragon*<sup> $^{\text{M}}</sup> processor enters SMM, it writes the processor state information into the SMM state–save area of SMRAM. The SMM state–save map area is located in SMRAM between addresses [SMBASE + 8000H + 7FFFH] and [SMBASE + 8000H + 7E00H]. Table 6 lists the information contained within the SMM state–save area. Processor state information not listed in Table 6 is not automatically saved nor restored by the processor. It is the responsibility of the SMM handler to save and restore any additional state information that it alters during execution.</sup>$ 

| OFFSET<br>(Added to SMBASE + 8000H) | REGISTER  | WRITABLE |  |  |
|-------------------------------------|-----------|----------|--|--|
| 7FFCH                               | CR0       | No       |  |  |
| 7FF8H                               | CR3       | No       |  |  |
| 7FF4H                               | EFLAGS    | Yes      |  |  |
| 7FF0H                               | EIP       | Yes      |  |  |
| 7FECH                               | EDI       | Yes      |  |  |
| 7FE8H                               | ESI       | Yes      |  |  |
| 7FE4H                               | EBP       | Yes      |  |  |
| 7FE0H                               | ESR       | Yes      |  |  |
| 7FDCH                               | EBX       | Yes      |  |  |
| 7FD8H                               | EDX       | Yes      |  |  |
| 7FD4H                               | ECX       | Yes      |  |  |
| 7FD0H                               | EAX       | Yes      |  |  |
| 7РССН                               | DR6       | No       |  |  |
| <b>ХЕС8Н</b>                        | DR7       | No       |  |  |
| 7FC4H                               | TR        | No       |  |  |
| 7FC0H                               | LDTR Base | No       |  |  |
| 7FBCH                               | GS        | No       |  |  |
| 7FB8H                               | FS        | No       |  |  |
| 7FB4H                               | DS        | No       |  |  |
| 7FB0H                               | SS        | No       |  |  |
| 7FACH                               | CS        | No       |  |  |
| 7FA8H                               | ES        | No       |  |  |
| 7FA7H – 7F98H                       | RESERVED  | No       |  |  |
| 7F94H                               | IDT Base  | No       |  |  |

#### TABLE 6. SMM STATE-SAVE AREA MAP





| OFFSET<br>(Added to SMBASE + 8000H) | REGISTER                             | WRITABLE |
|-------------------------------------|--------------------------------------|----------|
| 7F92H                               | IDT Limit (Word)                     | No       |
| 7F91H – 7F8CH                       | RESERVED                             | No       |
| 7F88H                               | GDT Base                             | No       |
| 7F86H                               | GDT Limit (Word)                     | No       |
| 7F85H – 7F04H                       | RESERVED                             | No       |
| 7F02H                               | Auto HALT Restart Field (Word)       | Yes      |
| 7F00H                               | I/O Instruction Restart Field (Word) | Yes      |
| 7EFCH                               | SMM Revision Identifier Field        | No       |
| 7EF8H                               | SMBASE Field                         | Yes      |
| 7EF7H – 7EF4H                       | RESERVED                             | No       |
| 7EF0H                               | Restart EIP                          | No       |
| 7EEFH – 7EE8H                       | RESERVED                             | No       |
| 7EE4H                               | CR4                                  | No       |
| 7ЕЕОН                               | CR2                                  | No       |
| 7ED8H                               | TSS Descriptor                       | No       |
| 7ED0H                               | LDT Descriptor                       | No       |
| 7EC8H                               | GS Descriptor                        | No       |
| 7ЕСОН                               | FS Descriptor                        | No       |
| 7EB8H                               | DS Descriptor                        | No       |
| <b>VEBOH</b>                        | SS Descriptor                        | No       |
| 7EA8H                               | CS Descriptor                        | No       |
| 7EA0H                               | ES Descriptor                        | No       |
| 7E9FH – 7E00H                       | RESERVED                             | No       |

#### 8.2 SMM Initial Register Values

The initial state of each processor register upon entry to SMM is listed in Table 7.

#### TABLE 7. REGISTER INITIALIZATION IN SMM

| REGISTER                  | INITIAL CONTENTS | NOTES |
|---------------------------|------------------|-------|
| General-purpose registers | Undefined        |       |
| EFLAGS                    | 0000002H         |       |
| EIP                       | 00008000H        |       |





| REGISTER                     | INITIAL CONTENTS                                   | NOTES            |
|------------------------------|----------------------------------------------------|------------------|
| CS Selector                  | SMM Base shifted right 4 bits (default 3000H)      | 1                |
| CS Base                      | SMM Base (default 00030000H)                       | 1                |
| CS Limit                     | FFFFH (4 GBytes)                                   | 1                |
| DS, ES, FS, GS, SS Selectors | 0000Н                                              | 1                |
| DS, ES, FS, GS, SS Bases     | 00000000Н                                          | 1                |
| DS, ES, FS, GS, SS Limits    | FFFFFH (4 GBytes)                                  | 1                |
| CR0                          | Bits 0, 2, 3 and 31 are cleared; others unmodified |                  |
| DR6                          | Unpredictable                                      | $\left( \right)$ |
| DR7                          | 00000400Н                                          | $\bigvee$        |

Notes:

1. Attr=Preset. R/W. Accessed, G=1, D=0, AVL=0, DPL=0,

#### 8.3 SMM Revision Identifier

The SMM Revision Identifier is used to ascertain the version and extensions of SMM being used and is located at offset 7EFCH in the SMM state—save area. Table 8 shows the SMM Revision Identifier Fields and associated RiSE<sup>™</sup> *iDragon*<sup>™</sup> processor default values. I/O Instruction Restart and SMBase Relocation are always enabled on the RiSE<sup>™</sup> *iDragon*<sup>™</sup> processor.

|          |         | /            |          |       | /       |
|----------|---------|--------------|----------|-------|---------|
| TARIE 8  | SMM REV | <b>NOI2N</b> | IDENT    | IFIFR | FIFI DS |
| TADEE 0. |         |              | ID ÉI VI |       |         |

| BITS 31-18                             | BIT 17              | BIT 16                  | BITS 15-0          |
|----------------------------------------|---------------------|-------------------------|--------------------|
| RESERVED                               | SMM Base Relocation | I/O Instruction Restart | SMM Revision Level |
| $\langle \bigcirc 9 \setminus \rangle$ | 1                   | 1                       | 0002H              |

### 8.4 I/O Instruction Restart

The I/O Instruction Restart Field, located at offset 7F00H in the SMM state–save area, controls an I/O instruction restart. If the I/O Instruction Restart Field contains the value 00FFH during an RSM instruction, then the value restored in the EIP register is the value found in the Restart EIP Field of the SMM state–save area. This restored EIP points to the I/O instruction that received the SMI request, and the processor automatically re-executes the trapped I/O instruction. However, if the I/O Instruction Restart Field contains the value 0000H during an RSM instruction, then the value restored in the EIP register is located in the EIP Field in the SMM state–save area. This information is tabulated below.

| Value of I/O Instruction Field | Origin of Value Stored in EIP Register    |
|--------------------------------|-------------------------------------------|
| 00FFh                          | Restart EIP Field of SMM State-Save Area  |
| 0000H                          | EIP Register Field of SMM State-Save Area |





I/O Instruction Restart is always enabled on the RiSE<sup>m</sup> *iDragon*<sup>m</sup> processor. When the processor enters SMM, a value of 0000H is always written to the I/O Instruction Restart Field. It is the responsibility of the SMM handler to examine the state of the processor and to determine if an I/O instruction restart is required.

#### 8.5 Auto Halt Restart

The Auto Halt Restart Field, located at offset 7F02H in the SMM state–save area, is loaded with a value of 0001H if the processor was in the HALT state when the SMI occurred. If the processor was not in HALT state, a value of 0000H is saved. Upon exit of SMM, the processor examines the Auto Halt Restart Field. If the Auto Halt Restart Field contains a value of 0001H, the Restart EIP is restored to the EIP register and the processor re–executes the HALT instruction upon exit of SMM. However, if the Auto Halt Restart Field contains 0000H, then the value from the EIP field is restored to the EIP register and the processor begins execution at the instruction following the HALT. If the SMM Handler routine clears this flag, the processor begins execution with the instruction following the HALT instruction.

## 8.6 Back-to-Back SMI Interrupts When Using I/O Instruction Restart

To avoid program error, the SMM handler must be able to identify back-to-back SMI interrupts on I/O instructions when I/O Instruction Restarting is being used. Setting the I/O Instruction Restart Field value to 00FFH during the second of the back-to-back executions of the SMM handler causes the EIP value to be set.

Doc#: MKTB16401.00





# Appendix A – Machine–Specific Code for RiSE<sup>™</sup>*iDragon*<sup>™</sup> Configuration Setting

The following code should be included in the system BIOS to properly support feature validation of the production steppings of the  $RiSE^{II}$  *iDragon* processor. Include it in the non–compressed area so that it is available to vendors for easy modification to facilitate validation of different bit settings.

```
* * *
;Routine:
           mP6 Msr Setup Reg
;
;Purpose: For configuration setup of iDragon family
;
           This routine should be used to do configuration setup on iDragon
;Comment:
;
           None
;Inputs:
;
;Outputs:
           None
;****
                                                            * * * * * * * * * * *
Public
        mP6 Msr Setup Reg
mP6_Msr_Setup_Reg Proc Near
     pushad
              eax, 6363452Ah
     mov
              ecx, 3231206Ch
     mov
                   2A32313Ah
     mov
               edx,
     cpuid
              eax, 63634523h
     mov
     mov
              ecx/ 32315F6Ch
              edx, 2333313Ah
     mov
     cpuid
     popad
     ret
```

 $mP6\_\texttt{Msr}\_\texttt{Setup}\_\texttt{Reg} \text{ endp}$