

# AMD Processor Recognition Application Note

Publication # 20734 Rev: N Issue Date: August 1999

#### © 1999 Advanced Micro Devices, Inc. All rights reserved.

The contents of this document are provided in connection with Advanced Micro Devices, Inc. ("AMD") products. AMD makes no representations or warranties with respect to the accuracy or completeness of the contents of this publication and reserves the right to make changes to specifications and product descriptions at any time without notice. No license, whether express, implied, arising by estoppel or otherwise, to any intellectual property rights is granted by this publication. Except as set forth in AMD's Standard Terms and Conditions of Sale, AMD assumes no liability whatsoever, and disclaims any express or implied warranty, relating to its products including, but not limited to, the implied warranty of merchantability, fitness for a particular purpose, or infringement of any intellectual property right.

AMD's products are not designed, intended, authorized or warranted for use as components in systems intended for surgical implant into the body, or in other applications intended to support or sustain life, or in any other application in which the failure of AMD's product could create a situation where personal injury, death, or severe property or environmental damage may occur. AMD reserves the right to discontinue or make changes to its products at any time without notice.

#### Trademarks

AMD, the AMD logo, AMD Athlon, and combinations thereof, 3DNow!, K86, and AMD-K5 are trademarks, and AMD-K6, Am486, and  $Am5_X86$  are registered trademarks of Advanced Micro Devices, Inc.

MMX is a trademark of Intel Corporation.

Other product names used in this publication are for identification purposes only and may be trademarks of their respective companies.

## Contents

|              | Revision History                                                               | ix |
|--------------|--------------------------------------------------------------------------------|----|
| AMD Processo | or Recognition                                                                 | 1  |
|              | Introduction                                                                   | 1  |
|              | CPUID Instruction Overview                                                     | 2  |
|              | Testing for the CPUID Instruction                                              | 3  |
|              | Using CPUID Functions                                                          | 4  |
|              | Identifying the Processor Vendor                                               | 5  |
|              | Testing For Extended Functions                                                 | 6  |
|              | Determining the Processor Signature                                            | 6  |
|              | Identifying Supported Features                                                 | 8  |
|              | Determining Instruction Set SupportAMD Processor Signature (Extended Function) |    |
|              | Displaying the Processor Name                                                  |    |
|              | Displaying Cache Information                                                   | 11 |
|              | Sample Code                                                                    | 12 |
| Appendix A C | CPUID Instruction Definition                                                   | 13 |
|              | CPUID Instruction                                                              | 13 |
|              | Standard Functions                                                             | 14 |
|              | Extended Functions                                                             | 17 |
|              | Associativity Field Definitions                                                | 24 |
| Appendix B R | Register Values Returned by the AMD Family Processors                          | 25 |
|              | AMD Athlon <sup>™</sup> Processor Values                                       | 26 |
|              | AMD-K6 <sup>®</sup> Processor Values                                           | 28 |
|              | Am486 <sup>®</sup> , Am5X86 <sup>®</sup> , and AMD-K5™ Processor Values        | 31 |

## **List of Figures**

| Figure 1. | Contents of EAX Register Returned by Function 1 | 7  |
|-----------|-------------------------------------------------|----|
| Figure 2. | Contents of EAX Register Returned by Extended   |    |
|           | Function 8000_0001h                             | 11 |

## **List of Tables**

| Table 1.  | Summary of CPUID Functions in AMD Processors 5                                           |
|-----------|------------------------------------------------------------------------------------------|
| Table 2.  | Summary of Processor Signatures for AMD                                                  |
|           | Processors                                                                               |
| Table 3.  | Summary of Standard and Extended Feature Bits 8                                          |
| Table 4.  | Standard Feature Flag Descriptions                                                       |
| Table 5.  | Extended Feature Flag Descriptions 18                                                    |
| Table 6.  | EAX Format Returned by Function 8000_0005h for<br>the AMD Athlon <sup>™</sup> Processor  |
| Table 7.  | EBX Format Returned by Function 8000_0005h for<br>the AMD Athlon Processor 20            |
| Table 8.  | ECX Format Returned by Function 8000_0005h for<br>the AMD Athlon Processor 20            |
| Table 9.  | EDX Format Returned by Function 8000_0005h for<br>the AMD Athlon Processor 20            |
| Table 10. | EBX Format Returned by Function 8000_0005h 21                                            |
| Table 11. | ECX Format Returned by Function 8000_0005h 21                                            |
| Table 12. | EDX Format Returned by Function 8000_0005h 21                                            |
| Table 13. | EAX Format Returned by Function 8000_0006h for<br>the AMD Athlon Processor 22            |
| Table 14. | EBX Format Returned by Function 8000_0006h for<br>the AMD Athlon Processor 22            |
| Table 15. | ECX Format Returned by Function 8000_0006h for<br>the AMD Athlon Processor               |
| Table 16. | ECX Format Returned by Function 8000_0006h for<br>the AMD-K6 <sup>®</sup> -III Processor |
|           |                                                                                          |

AMD Processor Recognition

| Table 17. | Associativity Values For L2 Caches and TLBs 24                                 |
|-----------|--------------------------------------------------------------------------------|
| Table 18. | Values Returned By the AMD Athlon Processor 26                                 |
| Table 19. | Values Returned By AMD-K6 Processors                                           |
| Table 20. | Values Returned By Am486 <sup>®</sup> , Am5 <sub>X</sub> 86 <sup>®</sup> , and |
|           | AMD-K5 <sup>TM</sup> Processors 31                                             |

## **Revision History**

| Date        | Rev | Description                                                                                                                                                               |
|-------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Dec 1997    | G   | Changed part names for AMD-K6 processor Models 8 and 9 in Table 2 on page 5.                                                                                              |
| Dec 1997    | G   | Added 3DNow!™ instructions feature (bit 31) to Table 4 on page 8 and Table 6 on page 15.                                                                                  |
| Dec 1997    | G   | Added AMD-K6 <sup>®</sup> -2 processor return values to Table 12 on page 21.                                                                                              |
| Jan 1998    | Н   | Added revised bit 31 description and alternate test for AMD-K6-2 to "Identifying Supported Features" on page 6.                                                           |
| May 1998    | I   | Revised "Functions 8000_0002h, 8000_0003h, and 8000_0004h – Processor Name String" on page 16.                                                                            |
| May 1998    | I   | Added return values for AMD-K6 processor Model 9 to Table 10 on page 18. Divided Appendix B table into two separate tables.                                               |
| Nov 1998    | J   | In "Standard Functions" on page 12, clarified AMD's vendor identification string stored in registers EBX, EDX, and ECX.                                                   |
| Nov 1998    | J   | In Table 11, "Values Returned By AMD-K6 <sup>®</sup> Processors," on page 18, changed function 8000_0001h, EDX value for the AMD-K6 processor Model 7 and deleted note 2. |
| Feb 1999    | K   | Added L2 cache information to Table 1 on page 4.                                                                                                                          |
| Feb 1999    | Κ   | Added Function 8000_0006h to "Displaying Cache Information" on page 10.                                                                                                   |
| Feb 1999    | К   | Added Function 8000_0006h – L2 Cache Information and Table 10, "ECX Format Returned by Function 8000_0006h," on page 17.                                                  |
| Feb 1999    | K   | Added AMD-K6-III processor Model 9 values and three notes to Table 11 on page 18.                                                                                         |
| May 1999    | L   | In Table 11 on page 18, changed function 8000_0001h EDX entries for Models 6 and 7 from 0080_01BFh to 0080_05BFh.                                                         |
| May 1999    | L   | Added note about the name string for the AMD-K6-2 processor to Table 11 on page 18.                                                                                       |
|             |     | Added the AMD Athlon™ processor information throughout document.                                                                                                          |
|             |     | Added url www.amd.com/products/cpg/bin, where codes samples and utilities are available.                                                                                  |
| August 1999 | м   | Revised "Testing for the CPUID Instruction" on page 3.                                                                                                                    |
| August 1999 |     | Revised "Determining Instruction Set Support" on page 9.                                                                                                                  |
|             |     | Revised Tables 6 through 16 to cross-reference new section—"Associativity Field Definitions" on page 24.                                                                  |
| August 1999 | N   | Merged standard and extended feature bits into one table. See Table 3, "Summary of Standard and Extended Feature Bits," on page 8.                                        |
| -           |     | Revised Table 18, "Values Returned By the AMD Athlon™ Processor," on page 26.                                                                                             |

## **Application** Note

## **AMD Processor Recognition**

## Introduction

Due to the increasing number of choices available in the x86 processor marketplace, the need for a simple way for hardware and software to identify the type of processor and its feature set has become critical. The CPUID instruction was added to the x86 instruction set for this purpose. This document contains information about using the CPUID instruction to test for extended features, such as an L2 cache on the AMD-K6<sup>®</sup>-III processor and AMD Athlon<sup>TM</sup> processor.

The CPUID instruction provides complete information about the processor (vendor, type, name, etc.) and its capabilities (features). After detecting the processor and its capabilities, software can be accurately tuned to the system for maximum performance and benefit to users. For example, software can roughly determine the performance level of a particular processor by detecting the type or speed of the processor. If the performance level is high enough, the software can enable additional capabilities or more advanced algorithms. Another example involves testing for the presence of 3DNow!<sup>TM</sup> or MMX<sup>TM</sup> instructions on the processor. If the software finds these features present when it checks the feature bits, it can utilize these more powerful extensions for dramatically better performance on new multimedia software. The current software development kit (SDK) contains code for determining the speed of AMD processors. The SDK is available at the following url:

http://www.amd.com/products/cpg/bin

### **CPUID Instruction Overview**

Software operating at any privilege level can execute the CPUID instruction to identify the processor and its feature set. In addition, the CPUID instruction implements multiple functions, each providing different information about the processor, including the vendor, model number, revision (stepping), features, cache organization, and processor name. The multiple-function approach allows the CPUID instruction to return a complete picture about the type of processor and its capabilities—more detailed information than could be returned by a single function. In addition to gathering all the information by calling multiple functions, the CPUID instruction provides the flexibility of making only one call to obtain the specific data requested.

The functions are divided into two types: **standard functions** and **extended functions**. Standard functions provide a simple method for software to access information common to all x86 processors. Extended functions provide information on extensions specific to a vendor's processor (for example, AMD family processors).

The flexibility of the CPUID instruction allows for the addition of new CPUID functions in future generations of processors. Appendix A, "CPUID Instruction Definition" on page 13 contains a detailed description of the CPUID instruction.

## **Testing for the CPUID Instruction**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <ul> <li>Beginning with the Am486<sup>®</sup>DX4 processor, all AMD family processors support the CPUID instruction. To use the CPUID instruction, software must first determine if the processor supports the CPUID instruction. CPUID support is determined in one of the following ways:</li> <li>Execute the CPUID instruction and check whether an</li> </ul> |                                                                                                                                                                                                                                                                                             |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | illegal instruction exception occurs. If an exception occurs the processor does not have CPUID support.                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                             |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <ul> <li>Check if the ID bit (bit 21) of the EFLAGS register is<br/>writable. If the bit is writable (that is, it can be modified)<br/>the CPUID instruction is supported.</li> </ul>                                                                                                                                                                              |                                                                                                                                                                                                                                                                                             |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                    | S) environment determines which<br>ate. These techniques are described                                                                                                                                                                                                                      |  |  |  |
| Illegal Instruction<br>Exception Method                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                             |  |  |  |
| <b>EFLAGS ID-Bit</b><br><b>Method</b> This technique retrieves the contents of EFLAGS of<br>PUSHFD instruction, toggles the ID bit, and uses the<br>instruction to write the modified value of the ID bit<br>EFLAGS register. It then retrieves the contents of<br>using a second PUSHFD instruction and checks who<br>value of the ID bit differs from the original value. If<br>has changed, the CPUID instruction is available for id<br>the processor and its features. The following code<br>demonstrates the way a program uses the PUSHFD an<br>instructions to test the ID bit. |                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                             |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | pushfd<br>pop eax<br>mov ebx, eax<br>xor eax, 00200000h<br>push eax<br>popfd<br>pushfd<br>pop eax<br>cmp eax, ebx<br>jz NO_CPUID                                                                                                                                                                                                                                   | ; Save EFLAGS to stack<br>; Store EFLAGS in EAX<br>; Save in EBX for testing later<br>; Switch bit 21<br>; Copy changed value to stack<br>; Save changed EAX to EFLAGS<br>; Push EFLAGS to top of stack<br>; Store EFLAGS in EAX<br>; See if bit 21 has changed<br>; If no change, no CPUID |  |  |  |

A potential problem with this approach is that an interrupt or a trap (such as a debug trap) can occur between the POPFD and the following PUSHFD, and that the interrupt or trap handler code destroys the value of the ID bit. Where possible, the above code should be preceded by a CLI instruction and followed by an STI instruction, which ensures that no interrupts occur between the POPFD and the PUSHFD. However, traps can still occur, even if the code is preceded by a CLI instruction and followed by an STI instruction.

## **Using CPUID Functions**

When software uses the CPUID instruction to identify a processor, it is important that it uses the instruction appropriately. The instruction has been defined to make it easy to identify the type and features of x86 processors manufactured by many different vendors.

The standard functions (EAX=0 and EAX=1) are the same for all processors. Having standard functions simplifies software's task of testing for and implementing features common to x86 processors. Software can test for these features and, as new x86 processors are released, benefit from these capabilities immediately.

Extended functions are specific to a vendor's processor. These functions provide additional information about AMD processors that software can use to identify enhanced features and functions. To test for extended functions, software checks for a value of at least 8000\_0001h in the EAX register returned by function 8000\_0000h.

Within AMD's family of processors, different members can execute a different number of functions. Table 1 on page 5 summarizes the CPUID functions currently implemented on AMD processors.

| Standard<br>Function | Extended<br>Function | Description                                                  | Am486 <sup>®</sup> DX4<br>and Am5 <sub>X</sub> 86 <sup>®</sup><br>Processors | AMD-K5™<br>Processor<br>(Model 0) | AMD-K5<br>Processor<br>(Model 1,<br>2, and 3) | AMD-K6 <sup>®</sup><br>Processor<br>(Models 6, 7)<br>AMD-K6-2<br>Processor<br>(Model 8) | AMD-K6-III<br>Processor<br>(Model 9) | AMD Athlon™<br>Processor |
|----------------------|----------------------|--------------------------------------------------------------|------------------------------------------------------------------------------|-----------------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------|--------------------------|
| 0                    | _                    | Vendor String and Largest<br>Standard Function Value         | Х                                                                            | Х                                 | Х                                             | Х                                                                                       | Х                                    | Х                        |
| 1                    | _                    | Processor Signature and<br>Standard Feature Bits             | Х                                                                            | Х                                 | Х                                             | Х                                                                                       | Х                                    | Х                        |
| -                    | 8000_0000h           | Largest Extended Function<br>Value                           | -                                                                            | _                                 | Х                                             | Х                                                                                       | Х                                    | Х                        |
| -                    |                      | Extended Processor<br>Signature and Extended<br>Feature Bits | _                                                                            | _                                 | Х                                             | Х                                                                                       | Х                                    | Х                        |
| _                    | 8000_0002h           | Processor Name                                               | -                                                                            | -                                 | Х                                             | Х                                                                                       | Х                                    | Х                        |
| _                    | 8000_0003h           | Processor Name                                               | -                                                                            | —                                 | Х                                             | Х                                                                                       | Х                                    | Х                        |
| _                    | 8000_0004h           | Processor Name                                               | -                                                                            | —                                 | Х                                             | Х                                                                                       | Х                                    | Х                        |
| _                    | 8000_0005h           | L1 TLB <sup>*</sup> /Cache Information                       | -                                                                            | -                                 | Х                                             | Х                                                                                       | Х                                    | Х                        |
|                      | 0000 000ch           | L2 TLB/Cache Information                                     |                                                                              | _                                 | _                                             |                                                                                         | Х                                    | Х                        |

| Table 1. | Summary | y of CPUID | Functions i | n AMD | Processors |
|----------|---------|------------|-------------|-------|------------|
|----------|---------|------------|-------------|-------|------------|

Future versions of these processors may implement additional functions.

Appendix A, "CPUID Instruction Definition" on page 13 contains detailed descriptions of the functions.

\* TLB = translation lookaside buffer.

## **Identifying the Processor Vendor**

Software must execute the standard function EAX=0. The CPUID instruction returns a 12-character string that identifies the processor's vendor. The instruction also returns the largest standard function input value defined for the CPUID instruction on the processor.

For AMD processors, function 0 returns a vendor string of "AuthenticAMD". This string informs the software to follow AMD's definition for subsequent CPUID functions and the registers returned for those functions.

Once the software identifies the processor's vendor, it knows the definition for all the functions supplied by the CPUID instruction. By using these functions, the software obtains the processor information needed to properly tune its functionality to the capabilities of the processor.

## **Testing For Extended Functions**

Software must test for extended functions with function 8000\_0000h. The EAX register returns the largest extended function input value defined for the CPUID instruction on the processor. If this value is at least 8000\_0001h, extended functions are supported.

With one exception, the AMD extended feature flags include all the information provided in the standard feature flags as well as indicators for the additional AMD processor-specific feature enhancements. The duplication of standard feature bits within the extended feature bits can minimize the number of function calls required by software. The exception is bit 11, which indicates that the SYSENTER and SYSEXIT instructions are supported in the standard features and that the SYSCALL and SYSRET instructions are supported in the extended features.

### **Determining the Processor Signature**

Standard function 1 (EAX=1) of the CPUID instruction returns the standard processor signature and feature bits. The standard processor signature is returned in the EAX register and provides information regarding the specific revision (stepping) and model of the processor and the instruction family level supported by the processor. The revision level can be used to determine if the processor supports specific features. However, it is not recommended that the revision level be used in this manner unless this information is not available through the standard or extended feature bits.

All AMD-K6 processor models belong to instruction family 5 (as returned in EAX by function 1). All AMD Athlon processor models belong to instruction family 6 (as returned in EAX by function 1). Figure 1 on page 7 shows the contents of the EAX register obtained by function 1. Table 2 on page 7 summarizes the specific processor signature values returned for AMD processors.



#### Figure 1. Contents of EAX Register Returned by Function 1

| Processor                                                          | Instruction<br>Family | Model                   | Stepping ID <sup>3</sup> |
|--------------------------------------------------------------------|-----------------------|-------------------------|--------------------------|
| Am486 <sup>®</sup> and Am5 <sub>x</sub> 86 <sup>®</sup> Processors | 0100b (4h)            | yyyy <sup>1</sup>       | XXXX                     |
| AMD-K5 <sup>™</sup> Processor (Model 0)                            | 0101b (5h)            | 0000b (0h)              | XXXX                     |
| AMD-K5 Processor (Model 1)                                         | 0101b (5h)            | 0001b (1h)              | XXXX                     |
| AMD-K5 Processor (Model 2)                                         | 0101b (5h)            | 0010b (2h)              | XXXX                     |
| AMD-K5 Processor (Model 3)                                         | 0101b (5h)            | 0011b (3h)              | XXXX                     |
| AMD-K6 <sup>®</sup> Processor (Model 6)                            | 0101b (5h)            | 0110b (6h)              | XXXX                     |
| AMD-K6 Processor (Model 7)                                         | 0101b (5h)            | 0111b (7h)              | XXXX                     |
| AMD-K6-2 Processor (Model 8)                                       | 0101b (5h)            | 1000b (8h)              | XXXX                     |
| AMD-K6-III Processor (Model 9)                                     | 0101b (5h)            | 1001b (9h)              | XXXX                     |
| AMD Athlon™ Processor                                              | 0110b (6h)            | 0001b (1h) <sup>2</sup> | XXXX                     |
| Notes:                                                             | -                     |                         | •                        |

#### Table 2. Summary of Processor Signatures for AMD Processors

1. Contact your AMD representative for Model identifier information.

2. Initially, the AMD Athlon processor has a model of 0001b (1h).

3. Contact your AMD representative for the latest stepping information.

## **Identifying Supported Features**

The feature bits are returned in the EDX register for two CPUID functions—standard function 1 and extended function 8000\_0001h. Each bit corresponds to a specific feature and indicates if that feature is present on the processor. Table 3 summarizes the standard and extended feature bits.

Table 3. Summary of Standard and Extended Feature Bits

| Bit <sup>1</sup> | Feature                                                                          | Description                                                                                                          | Standard <sup>2</sup> | Extended <sup>2</sup> |
|------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|
| 0                | Floating-Point Unit                                                              | A floating-point unit is available.                                                                                  | 1                     | 1                     |
| 1                | Virtual Mode Extensions                                                          | Virtual mode extensions are available.                                                                               | 1                     | 1                     |
| 2                | Debugging Extensions                                                             | I/O breakpoint debug extensions are supported.                                                                       | 1                     | 1                     |
| 3                | PSE (Page Size Extensions)                                                       | 4-Mbyte pages are supported.                                                                                         | 1                     | 1                     |
| 4                | Time Stamp Counter<br>(with RDTSC and CR4 disable bit)                           | A time stamp counter is available in the processor,<br>and the RDTSC instruction is supported.                       | 1                     | 1                     |
| 5                | K86™ Family of Processors'<br>Model-Specific Registers (with<br>RDMSR and WRMSR) | The K86 model-specific registers are available in the processor, and the RDMSR and WRMSR instructions are supported. | 1                     | 1                     |
| 6                | PAE (Page Address Extensions)                                                    | Page address extensions are supported using an 8-byte directory entry.                                               | 1                     | 1                     |
| 7                | MCE (Machine Check Exception)                                                    | The machine check exception is supported.                                                                            | 1                     | 1                     |
| 8                | CMPXCHG8B Instruction                                                            | The CMPXCHG8B instruction is supported.                                                                              | 1                     | 1                     |
| 9                | APIC                                                                             | A local APIC unit is available.                                                                                      | 1                     | 1                     |
|                  | SYSENTER/SYSEXIT Instructions                                                    | The SYSENTER and SYSEXIT instructions are<br>supported.                                                              | 1                     | 0                     |
| 11               | SYSCALL and SYSRET Instructions                                                  | The SYSCALL and SYSRET instructions and<br>associated extensions are supported.                                      | 0                     | 1                     |
| 12               | MTRR (Memory Type Range<br>Registers)                                            | Memory type range registers are available.                                                                           | 1                     | 1                     |
| 13               | Global Paging Extension                                                          | Global paging extensions are available.                                                                              | 1                     | 1                     |
| 14               | MCA (Machine Check Architecture)                                                 | Machine check architecture is supported                                                                              | 1                     | 1                     |
| 15               | Conditional Move Instructions                                                    | The conditional move instructions CMOV, FCMOV, and FCOMI are supported.                                              | 1                     | 1                     |
| 16               | PAT (Page Attribute Table)                                                       | The Page attribute tables are supported.                                                                             | 1                     | 1                     |
| 17               | PSE-36 (Page Size Extension)                                                     | Page size extensions for 36-bit addresses are supported using a 4-byte directory entry.                              | 1                     | 1                     |

2. Bit definitions: 0 = No Support, 1 = Support

| Bit <sup>1</sup> | Feature                                                                           | Description                                                                   | Standard <sup>2</sup> | Extended <sup>2</sup> |
|------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-----------------------|-----------------------|
| 22               | AMD Multimedia Instruction<br>Extensions                                          | AMD additions to the original MMX <sup>™</sup> instruction set are supported. | 0                     | 1                     |
| 23               | MMX <sup>™</sup> Instructions                                                     | The MMX instruction set is supported.                                         | 1                     | 1                     |
| 24               | FXSAVE/FXRSTOR                                                                    | Fast floating-point save and restore is supported.                            | 1                     | 1                     |
| 30               | AMD 3DNow!™ InstructionExtensions to the 3DNow! instruction set are<br>supported. |                                                                               | 0                     | 1                     |
| 31               | 3DNow! Instructions                                                               | 3DNow! instructions are supported.                                            | 0                     | 1                     |
| Note:            | ·                                                                                 |                                                                               |                       |                       |
| 1.               | Appendix A, "CPUID Instruction Definiti                                           | ion" on page 13 contains details on bit locations and values.                 |                       |                       |
| 2.               | Bit definitions: $0 = No$ Support, $1 = Sup$                                      | port                                                                          |                       |                       |

Table 3. Summary of Standard and Extended Feature Bits (continued)

Bit definitions: 0 = No Support,

Before using any of the enhanced features added to the latest generation of processors, software should test each feature bit returned by functions 1 and 8000 0001h to identify the capabilities available on the processor. For example, software must test feature bit 23 to determine if the processor executes the MMX technology instructions. Attempting to execute an unavailable feature can cause errors and exceptions.

Bit 31, as returned by extended function 8000\_0001h, designates the presence of 3DNow! technology. Other processor vendors have adopted this technology, so bit 31 is now considered an open standard. Appendix A, "CPUID Instruction Definition" on page 13 and Appendix B, "Register Values Returned by the AMD Family Processors" on page 25 contain details on bit locations and values.

#### **Determining Instruction Set Support**

It is preferable to use CPUID feature flags as much as possible, rather than deriving capabilities from vendor specifiers combined with CPUID model numbers.

The AMD Athlon processor adds two new sets of powerful extensions to the x86 instruction set-3DNow! extensions and multimedia enhancement extensions. See the AMD Additions to the 3DNow!™ and MMX™ Instruction Sets Manual, order# 22466 for more information about these new 24 instructions.

To simplify the detection of the new instructions and the original 3DNow! and MMX instructions, use the following algorithm. A code sample using the CPUID instruction to identify the processor and its features is available from AMD's AMD Processor Recognition

website at http://www.amd.com/products/cpg/bin. There are other ways to implement detection besides the way shown in the sample.

- **CPUID Test** 1. Establish that the processor has support for CPUID. See "Testing for the CPUID Instruction" on page 3.
- Standard Function2. Execute CPUID function 0, which returns the processor<br/>vendor string and the highest standard function supported.<br/>Save the vendor string for a later comparison. (See step 9.)
  - 3. If step 2 indicates that the highest standard function is at least 1, execute CPUID function 1, which returns the standard feature flags in the EDX register.
- MMX Test4. If bit 23 of the standard feature flags is set to 1, MMX technology is supported. MMX instruction support is the basic minimum processor feature required to support other instruction extensions.
- Optional SSE Test
   5. Optionally, if bit 25 of the standard feature flags is set, the processor has streaming SIMD extensions (SSE) capabilities. Further qualification of SSE is done by checking for OS support. SSE support might be present in the processor, but not usable due to a lack of OS support for the additional architected registers.
- Extended Functions6. Execute CPUID extended function 8000\_0000h. This<br/>function returns the highest extended function supported in<br/>EAX. If EAX=0, there is no support for extended functions.
  - 7. If the highest extended function supported is at least 8000\_0001h, execute CPUID function 8000\_0001h. This function returns the extended feature flags in EDX.
- **3DNow! Test** 8. If bit 31 of the extended feature flags is set to 1, the 3DNow! instructions are supported.
- Vendor Check9. If the previously saved vendor string (see step 2) contains<br/>"AuthenticAMD", continue on to the next step.
- **3DNow! Extensions**10. If bit 30 of the extended feature flags is set to 1, the<br/>additions to the 3DNow! instruction set are supported.
- **MMX Extensions Test** 11. If bit 22 of the extended feature flags is set to 1, the new multimedia enhancement instructions that augment the MMX instruction set are supported.

#### **AMD Processor Signature (Extended Function)**

Extended function 8000\_0001h returns the AMD processor signature. The signature is returned in the EAX register and provides generation, model, and stepping information for AMD processors. Figure 2 on page 11 shows the contents returned in the EAX register.

| 31                              |                    | 12 11 | 87 4 | 43 0 |
|---------------------------------|--------------------|-------|------|------|
|                                 |                    |       |      |      |
| Reserved                        |                    |       |      |      |
| Generation<br>Model<br>Stepping | 11-8<br>7-4<br>3-0 |       |      |      |

#### Figure 2. Contents of EAX Register Returned by Extended Function 8000\_0001h

#### **Displaying the Processor Name**

Functions 8000\_0002h, 8000\_0003h, and 8000\_0004h return an ASCII string containing the name of the processor. These functions eliminate the need for software to search for the processor name in a lookup table, a process requiring a large block of memory and frequent updates. Instead, software can simply call these three functions to obtain the name string (48 ASCII characters in little endian format) and display it on the screen. Although the name string can be up to 48 characters in length, shorter names have the remaining byte locations filled with the ASCII NULL character (00h). To simplify the display routines and avoid using screen space, software only needs to display characters until a NULL character is detected.

#### **Displaying Cache Information**

Functions 8000\_0005h and 8000\_0006h provide cache information for the processor, although function 8000\_0006h is only supported on the AMD Athlon processor and the AMD-K6-III processor Model 9. Some diagnostic software displays information about the system and the processor's configuration. It is common for this type of software to provide cache size and organization of information. Functions 8000\_0005h and 8000\_0006h provide a simple way for software to obtain information about the on-chip cache and translation lookaside buffer (TLB) structures. The size and organization information is returned in the registers as described in Appendix A on page 13. Software can simply display these values, eliminating the need for large pieces of code to test the memory structures.

## Sample Code

A code sample using the CPUID instruction to identify the processor and its features is available from AMD's website at http://www.amd.com/products/cpg/bin.

# **Appendix A**

## **CPUID Instruction Definition**

This appendix contains a detailed description of the CPUID instruction.

## **CPUID Instruction**

| mnemonic              | opcode      | description                                |
|-----------------------|-------------|--------------------------------------------|
| CPUID                 | 0F A2h      | Identify the processor and its feature set |
| Privilege:            | none        |                                            |
| Registers Affected:   | EAX, EBX, E | ECX, EDX                                   |
| Flags Affected:       | none        |                                            |
| Exceptions Generated: | none        |                                            |

The CPUID instruction is an application-level instruction that software executes to identify the processor and its feature set. This instruction offers multiple functions, each providing a different set of information about the processor. The CPUID instruction can be executed from any privilege level. Software can use the information returned by this instruction to tune its functionality for the specific processor and its features.

Not all processors implement the CPUID instruction. Therefore, software must test to determine if the instruction is present on the processor. If the ID bit (21) in the EFLAGS register is writeable, the CPUID instruction is implemented.

The CPUID instruction supports multiple functions. The information associated with each function is obtained by executing the CPUID instruction with the function number in the EAX register. Functions are divided into two types: standard functions and extended functions. Standard functions are found in the low function space, 0000\_0000h-7FFF\_FFFh. In general, all x86 processors have the same standard function definitions.

Extended functions are defined specifically for processors supplied by the vendor listed in the vendor identification string. Extended functions are found in the high function space, 8000\_0000h-8FFF\_FFFh. Because not all vendors have defined extended functions, software must test for their presence on the processor. AMD processors have extended functions if the 8000\_0000h function returns a value of at least 8000\_0001h in the EAX register.

## **Standard Functions**

#### Function 0 – Largest Standard Function Input Value and Vendor Identification String

- *Input:* EAX = 0
- *Output:* EAX = Largest function input value recognized by the CPUID instruction EBX, EDX, ECX = Vendor identification string

This is a standard function found in all processors implementing the CPUID instruction. It returns two values. The first value is returned in the EAX register and indicates the largest standard function value recognized by the processor. The second value is the vendor identification string. This 12-character ASCII string is returned in the EBX, EDX, and ECX registers in little endian format. AMD processors return a vendor identification string of "AuthenticAMD" as follows:

|    | EI | BX |    |    | EI | DX |    |    | EC           | CX |    | Registers        |
|----|----|----|----|----|----|----|----|----|--------------|----|----|------------------|
| h  | t  | u  | Α  | i  | t  | n  | e  | D  | $\mathbf{M}$ | Α  | с  | Alpha Characters |
| 68 | 74 | 75 | 41 | 69 | 74 | 6E | 65 | 44 | 4D           | 41 | 63 | ASCII Codes      |

Software uses the vendor identification string as follows:

- To identify the processor as an AMD processor
- To apply AMD's definition of the CPUID instruction for all additional function calls

#### Function 1 – Processor Signature and Standard Feature Flags

*Input:* EAX = 1

Output: EAX = Processor Signature EBX = Reserved ECX = Reserved EDX = Standard Feature Flags

Function 1 returns two values—the Processor Signature and the Standard Feature Flags. The processor signature is returned in the EAX register and identifies the specific processor by providing information on its type—instruction family, model, and revision (stepping). The information is formatted as follows:

- EAX[3–0] Stepping ID
- EAX[7–4] Model
- EAX[11–8] Instruction Family
- EAX[31–12] Reserved

The standard feature flags are returned in the EDX register and indicate the presence of specific features. In most cases, a "1" indicates the feature is present, and a "0" indicates the feature is not present. Table 4 on page 16 contains a list of the currently defined standard feature flags for the AMD-K6 processor Models 8 and 9, and the AMD Athlon processor (see tables 18 through 20 in Appendix B, "Register Values Returned by the AMD Family Processors" on page 25 for all K86 family processor register definitions, including the AMD-K6 processor Models 6 and 7). Reserved bits will be used for new features as they are added.

| Table 4. Standard Feature Flag Descripti | ions |
|------------------------------------------|------|
|------------------------------------------|------|

| Bit                                                                                         | Feature <sup>1</sup>                                | AMD-K6 <sup>®</sup> -2<br>Processor<br>(Model 8) | AMD-K6-III<br>Processor<br>(Model 9) | AMD Athlon <sup>**</sup><br>Processor<br>(Model 1) |
|---------------------------------------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------|--------------------------------------|----------------------------------------------------|
| 0                                                                                           | Floating-Point Unit                                 | 1                                                | 1                                    | 1                                                  |
| 1                                                                                           | Virtual Mode Extensions                             | 1                                                | 1                                    | 1                                                  |
| 2                                                                                           | Debugging Extensions                                | 1                                                | 1                                    | 1                                                  |
| 3                                                                                           | Page Size Extensions (4-Mbyte pages)                | 1                                                | 1                                    | 1                                                  |
| 4                                                                                           | Time Stamp Counter (with RDTSC and CR4 disable bit) | 1                                                | 1                                    | 1                                                  |
| 5 K86 <sup>™</sup> Family of Processors' Model-Specific Registers<br>(with RDMSR and WRMSR) |                                                     | 1                                                | 1                                    | 1                                                  |
| 6                                                                                           | PAE (Page Address Extensions)                       | 0                                                | 0                                    | 1                                                  |
| 7                                                                                           | Machine Check Exception                             | 1                                                | 1                                    | 1                                                  |
| 8                                                                                           | CMPXCHG8B Instruction                               | 1                                                | 1                                    | 1                                                  |
| 9                                                                                           | APIC                                                | 0                                                | 0                                    | 0 <sup>2</sup>                                     |
| 10                                                                                          | Reserved on all AMD processors                      | 0                                                | 0                                    | 0                                                  |
| 11                                                                                          | SYSENTER/SYSEXIT                                    | 0                                                | 0                                    | 1                                                  |
| 12                                                                                          | Memory Type Range Registers                         | 0                                                | 0                                    | 1                                                  |
| 13                                                                                          | Global Paging Extension                             | 1 <sup>3</sup>                                   | 1                                    | 1                                                  |
| 14                                                                                          | Machine Check Architecture                          | 0                                                | 0                                    | 1                                                  |
| 15                                                                                          | Conditional Move Instruction                        | 0                                                | 0                                    | 1                                                  |
| 16                                                                                          | PAT (Page Attribute Table)                          | 0                                                | 0                                    | 1                                                  |
| 17                                                                                          | PSE-36 (Page Size Extensions)                       | 0                                                | 0                                    | 0                                                  |
| 18-22                                                                                       | Reserved on all AMD processors                      | 0                                                | 0                                    | 0                                                  |
| 23                                                                                          | MMX <sup>™</sup> Instructions                       | 1                                                | 1                                    | 1                                                  |
| 24                                                                                          | FXSAVE/FXRSTOR                                      | 0                                                | 0                                    | 0                                                  |
| 25-31                                                                                       | Reserved on all AMD processors                      | 0                                                | 0                                    | 0                                                  |

1. Bit definitions: 0 = No Support, 1 = Support.

2. The AMD Athlon processor contains a local APIC. The BIOS must enable the local APIC in order for bit 9 to return a 1 (supported).

3. See Table 19 on page 28 for more information about Global Paging Extensions in the AMD-K6-2 processor Model 8.

## **Extended Functions**

#### Function 8000\_0000h – Largest Extended Function Input Value

*Input:* EAX = 8000\_0000h

```
Output: EAX = Largest function input value recognized by the CPUID instruction
EBX = Reserved
ECX = Reserved
EDX = Reserved
```

Function 8000\_0000h returns a value in the EAX register that indicates the largest extended function value recognized by the processor.

#### Function 8000\_0001h – AMD Processor Signature and Extended Feature Flags

*Input:* EAX = 8000\_0001h

Output: EAX = AMD Processor Signature EBX = Reserved ECX = Reserved EDX = Extended Feature Flags

Function 8000\_0001h returns two values—the AMD Processor Signature and the Extended Feature Flags. The AMD processor signature is returned in the EAX register and identifies the specific processor by providing information regarding its type—generation/family, model, and revision (stepping). The information is formatted as follows:

- EAX[3–0] Stepping ID
- EAX[7–4] Model
- EAX[11–8] Generation/Family
- EAX[31–12] Reserved

The extended feature flags are returned in the EDX register and indicate the presence of specific features found in AMD processors. In most cases, a '1' indicates the feature is present, and a '0' indicates the feature is not present. Table 5 on page 18 contains a list of the currently defined feature flags for the AMD-K6 processor Models 8 and 9, and the AMD Athlon processor (see tables 18 through 20 in Appendix B, "Register Values Returned by the AMD Family Processors" on page 25 for all K86 family processor register definitions). Reserved bits will be used for new features as they are added.

| Bit   | Feature <sup>1</sup>                                                                      | AMD-K6 <sup>®</sup> -2<br>Processor<br>(Model 8) | AMD-K6-III<br>Processor<br>(Model 9) | AMD Athlon™<br>Processor<br>(Model 1) |
|-------|-------------------------------------------------------------------------------------------|--------------------------------------------------|--------------------------------------|---------------------------------------|
| 0     | Floating-Point Unit                                                                       | 1                                                | 1                                    | 1                                     |
| 1     | Virtual Mode Extensions                                                                   | 1                                                | 1                                    | 1                                     |
| 2     | Debugging Extensions                                                                      | 1                                                | 1                                    | 1                                     |
| 3     | Page Size Extensions (4-Mbyte Pages)                                                      | 1                                                | 1                                    | 1                                     |
| 4     | Time Stamp Counter (with RDTSC and CR4 disable bit)                                       | 1                                                | 1                                    | 1                                     |
| 5     | K86 <sup>™</sup> Family of Processors' Model-Specific Registers<br>(with RDMSR and WRMSR) | 1                                                | 1                                    | 1                                     |
| 6     | PAE (Page Address Extensions)                                                             | 0                                                | 0                                    | 1                                     |
| 7     | Machine Check Exception                                                                   | 1                                                | 1                                    | 1                                     |
| 8     | CMPXCHG8B Instruction                                                                     | 1                                                | 1                                    | 1                                     |
| 9     | APIC                                                                                      | 0                                                | 0                                    | 0 <sup>2</sup>                        |
| 10    | Reserved on all AMD processors                                                            | 0                                                | 0                                    | 0                                     |
| 11    | SYSCALL and SYSRET Instructions <sup>3</sup>                                              | 1                                                | 1                                    | 1                                     |
| 12    | Memory Type Range Registers                                                               | 0                                                | 0                                    | 1                                     |
| 13    | Global Paging Extension                                                                   | 1                                                | 1                                    | 1                                     |
| 14    | Machine Check Architecture                                                                | 0                                                | 0                                    | 1                                     |
| 15    | Conditional Move Instruction                                                              | 0                                                | 0                                    | 1                                     |
| 16    | PAT (Page Attribute Table)                                                                | 0                                                | 0                                    | 1                                     |
| 17    | PSE-36 (Page Size Extensions)                                                             | 0                                                | 0                                    | 0                                     |
| 18-21 | Reserved on all AMD processors                                                            | 0                                                | 0                                    | 0                                     |
| 22    | AMD MMX <sup>™</sup> Instruction Extensions                                               | 0                                                | 0                                    | 1                                     |
| 23    | MMX Instructions                                                                          | 1                                                | 1                                    | 1                                     |
| 24    | FXSAVE/FXRSTOR                                                                            | 0                                                | 0                                    | 0                                     |
| 25–29 | Reserved on all AMD processors                                                            | 0                                                | 0                                    | 0                                     |
| 30    | AMD 3DNow! <sup>™</sup> Instruction Extensions                                            | 0                                                | 0                                    | 1                                     |
| 31    | 3DNow! Instructions                                                                       | 1                                                | 1                                    | 1                                     |

#### Table 5. Extended Feature Flag Descriptions

Notes:

1. Bit definitions: 0 = No Support, 1 = Support.

2. The AMD Athlon processor contains a local APIC. The BIOS must enable the local APIC for bit 9 to return a 1 (supported).

3. The implementation of the SYSCALL and SYSRET instructions is the same on the AMD Athlon processor and the AMD-K6 processor Models 8 and 9. The SYSENTER and SYSEXIT instructions are not implemented the same as the SYSCALL and SYSRET instructions.

#### Functions 8000\_0002h, 8000\_0003h, and 8000\_0004h – Processor Name String

*Input:* EAX = 8000\_0002h, 8000\_0003h, or 8000\_0004h

Output: EAX = Processor Name String EBX = Processor Name String ECX = Processor Name String EDX = Processor Name String

Functions 8000\_0002h, 8000\_0003h, and 8000\_0004h each return part of the processor name string in the EAX, EBX, ECX, and EDX registers. These three functions use the four registers to return an ASCII string of up to 48 characters in little endian format. For example, function 8000\_0002h returns the first 16 characters of the processor name. The first character resides in the least significant byte of EAX, and the last character (of this group of 16) resides in the most significant byte of EDX. The NULL character (ASCII 00h) is used to indicate the end of the processor name string. This feature is useful for processor names that require fewer than 48 characters.

#### Function 8000\_0005h – L1 TLB/Cache Information for the AMD Athlon™ Processor

*Input:* EAX = 8000\_0005h

Output: EAX = 2-Mbyte/4-Mbyte Pages and L1 TLB Information EBX = 4-Kbyte Pages and L1 TLB Information ECX = L1 Data Cache Information EDX = L1 Instruction Cache Information

Function 8000\_0005h returns information about the processor L1 TLBs and caches. Tables 6, 7, 8 and 9 provide the format for the information returned by the 8000\_0005h function for AMD Athlon processor.

Table 6 describes the format of the information for the L1 2-Mbyte/4-Mbyte large page TLBs.

| Table 6. | EAX Format Returned by | y Function 8000 | _0005h for the A | MD Athlon <sup>™</sup> Processor |
|----------|------------------------|-----------------|------------------|----------------------------------|
|----------|------------------------|-----------------|------------------|----------------------------------|

|        | 2-Mbyte/4-Mbyte Pages      |                        |                            |                        |  |  |
|--------|----------------------------|------------------------|----------------------------|------------------------|--|--|
|        | Data                       | TLB                    | Instructi                  | on TLB                 |  |  |
|        | Associativity <sup>1</sup> | # Entries <sup>2</sup> | Associativity <sup>1</sup> | # Entries <sup>2</sup> |  |  |
| EAX    | Bits 31–24                 | Bits 23–16             | Bits 15–8                  | Bits 7–0               |  |  |
| lates: |                            |                        | •                          |                        |  |  |

Notes:

1. See "Associativity for L1 Caches and L1 TLBs" on page 24 for more information.

2. The number of entries returned is the number of entries available for 2-Mbyte large pages. Because 4-Mbyte large pages require two 2-Mbyte entries, the number of entries available for 4-Mbyte large pages is one-half the returned value.

Note:

|                                                                                | 4-Kbyte Pages              |            |                            |           |  |  |  |
|--------------------------------------------------------------------------------|----------------------------|------------|----------------------------|-----------|--|--|--|
|                                                                                | Data                       | TLB        | Instruction TLB            |           |  |  |  |
|                                                                                | Associativity <sup>*</sup> | # Entries  | Associativity <sup>*</sup> | # Entries |  |  |  |
| EBX                                                                            | Bits 31–24                 | Bits 23-16 | Bits 15–8                  | Bits 7–0  |  |  |  |
| See "Associativity for L1 Caches and L1 TLBs" on page 24 for more information. |                            |            |                            |           |  |  |  |

#### Table 8. ECX Format Returned by Function 8000\_0005h for the AMD Athlon™ Processor

|                                                                                                    | L1 Data Cache |                            |               |                   |  |  |
|----------------------------------------------------------------------------------------------------|---------------|----------------------------|---------------|-------------------|--|--|
|                                                                                                    | Size (Kbytes) | Associativity <sup>*</sup> | Lines per Tag | Line Size (bytes) |  |  |
| ECX                                                                                                | Bits 31–24    | Bits 23-16                 | Bits 15–8     | Bits 7–0          |  |  |
| Note:       *       See "Associativity for L1 Caches and L1 TLBs" on page 24 for more information. |               |                            |               |                   |  |  |

#### Table 9. EDX Format Returned by Function 8000\_0005h for the AMD Athlon™ Processor

|                                                                                                | L1 Instruction Cache |                            |               |                   |  |  |
|------------------------------------------------------------------------------------------------|----------------------|----------------------------|---------------|-------------------|--|--|
|                                                                                                | Size (Kbytes)        | Associativity <sup>*</sup> | Lines per Tag | Line Size (bytes) |  |  |
| EDX                                                                                            | Bits 31–24           | Bits 23-16                 | Bits 15–8     | Bits 7–0          |  |  |
| Note:     *     See "Associativity for L1 Caches and L1 TLBs" on page 24 for more information. |                      |                            |               |                   |  |  |

#### Function 8000\_0005h – L1 Cache Information for AMD-K5<sup>™</sup> and All AMD-K6<sup>®</sup> Processors

*Note:* See "Function 8000\_0005h — L1 TLB/Cache Information for the AMD Athlon<sup>™</sup> Processor" on page 19 for more information.

*Input:* EAX = 8000\_0005h

Output: EAX = Reserved EBX = TLB Information ECX = L1 Data Cache Information EDX = L1 Instruction Cache Information

Function 8000\_0005h returns information about the processor's on-chip L1 caches and associated TLBs. Tables 10, 11, and 12 provide the format for the information returned by the 8000\_0005h function for the AMD-K5 and all AMD-K6 processors.

#### Table 10. EBX Format Returned by Function 8000\_0005h

|                                                                                                | Data                       | TLB        | Instruct       | ion TLB   |  |  |
|------------------------------------------------------------------------------------------------|----------------------------|------------|----------------|-----------|--|--|
|                                                                                                | Associativity <sup>*</sup> | # Entries  | Associativity* | # Entries |  |  |
| EBX                                                                                            | Bits 31–24                 | Bits 23–16 | Bits 15–8      | Bits 7–0  |  |  |
| Note:     *     See "Associativity for L1 Caches and L1 TLBs" on page 24 for more information. |                            |            |                |           |  |  |

#### Table 11. ECX Format Returned by Function 8000\_0005h

|                         |                                | L1 Data                       | a Cache       |                   |
|-------------------------|--------------------------------|-------------------------------|---------------|-------------------|
|                         | Size (Kbytes)                  | Associativity <sup>*</sup>    | Lines per Tag | Line Size (bytes) |
| ECX                     | Bits 31–24                     | Bits 23-16                    | Bits 15–8     | Bits 7–0          |
| Note:<br>* See "Associa | tivity for L1 Caches and L1 TL | .Bs" on page 24 for more info | ormation.     |                   |

#### Table 12. EDX Format Returned by Function 8000\_0005h

|                         |                                | L1 Instruct                  | tion Cache    |                   |
|-------------------------|--------------------------------|------------------------------|---------------|-------------------|
|                         | Size (Kbytes)                  | Associativity <sup>*</sup>   | Lines per Tag | Line Size (bytes) |
| EDX                     | Bits 31–24                     | Bits 23-16                   | Bits 15–8     | Bits 7–0          |
| Note:<br>* See "Associa | tivity for L1 Caches and L1 TL | Bs" on page 24 for more info | ormation.     |                   |

#### Function 8000\_0006h – L2 TLB/L2 Cache Information for the AMD Athlon™ Processor

This function is available on the AMD-K6-III processor Model 9 (see page 23) and the AMD Athlon processor.

*Note:* The AMD Athlon processor L2 cache must be configured prior to invoking this function.

| Input: | EAX = 8000           | 0006h   |
|--------|----------------------|---------|
| input. | $\Pi_{1112} = 00000$ | _000011 |

*Output:* EAX = 2-Mbyte/4-Mbyte Pages and L2 TLB Information EBX = 4-Kbyte Pages and L2 TLB Information ECX = L2 Unified Cache Information EDX = Reserved

Function 8000\_0006h returns information about the L2 cache and TLB. Tables 13, 14, and 15 provide the format for the information returned by the 8000\_0006h function on the AMD Athlon processor.

|     |                            | 2-Mbyte/4          | -Mbyte Pages               |                   |
|-----|----------------------------|--------------------|----------------------------|-------------------|
|     | L2 Data                    | a TLB <sup>2</sup> | L2 Instruction             | on or Unified TLB |
|     | Associativity <sup>1</sup> | # Entries          | Associativity <sup>1</sup> | # Entries         |
| EAX | Bits 31–28                 | Bits 27-16         | Bits 15-12                 | Bits 11–0         |

Notes:

1. See "Associativity for L2 Caches and L2 TLBs" on page 24 for more information.

2. A unified L2 TLB is indicated by a value of 0000h in the upper 16 bits of the EBX register. Unified TLB information is then referenced in the lower 16 bits of the EBX register.

|                            | 4-Kbyt             | e Pages                    |                       |
|----------------------------|--------------------|----------------------------|-----------------------|
| L2 Dat                     | a TLB <sup>2</sup> | L2 Instr                   | uction or Unified TLB |
| Associativity <sup>1</sup> | # Entries          | Associativity <sup>1</sup> | # Entries             |
| Bits 31–28                 | Bits 27–16         | Bits 15-12                 | Bits 11–0             |

Notes:

EBX

1. See "Associativity for L2 Caches and L2 TLBs" on page 24 for more information.

2. A unified L2 TLB is indicated by a value of 0000h in the upper 16 bits of the EBX register. Unified TLB information is then referenced in the lower 16 bits of the EBX register.

|                         |                                 | L2 C                         | ache          |                   |
|-------------------------|---------------------------------|------------------------------|---------------|-------------------|
|                         | Size (Kbytes)                   | Associativity <sup>*</sup>   | Lines per Tag | Line Size (bytes) |
| ECX                     | Bits 31–16                      | Bits 15-12                   | Bits 11–8     | Bits 7–0          |
| Note:<br>* See "Associo | ntivity for L2 Caches and L2 TL | Bs" on page 24 for more info | ormation.     | •                 |

#### Table 15. ECX Format Returned by Function 8000\_0006h for the AMD Athlon™ Processor

#### Function 8000\_0006h – L2 Cache Information for the AMD-K6<sup>®</sup>-III Processor

This function is available on the AMD-K6-III processor Model 9. See page 22 for information about the AMD Athlon processor.

Note: See "Function  $8000_{0006h} - L2 TLB/L2$  Cache Information for the AMD Athlon<sup>TM</sup> Processor" on page 22 for more information.

*Input:* EAX = 8000\_0006h

Output: EAX = Reserved EBX = Reserved ECX = L2 Unified Cache Information EDX = Reserved

Function 8000\_0006h returns information about the processor's L2 cache. Table 16 provides the format for the information returned by the 8000\_0006h function.

#### Table 16. ECX Format Returned by Function 8000\_0006h for the AMD-K6<sup>®</sup>-III Processor

|                         |                               | L2 (                         | Cache         |                   |
|-------------------------|-------------------------------|------------------------------|---------------|-------------------|
|                         | Size (Kbytes)                 | Associativity <sup>*</sup>   | Lines per Tag | Line Size (bytes) |
| ECX                     | Bits 31–16                    | Bits 15–12                   | Bits 11–8     | Bits 7–0          |
| Note:<br>* See "Associa | tivity for L2 Caches and L2 T | LBs" on page 24 for more inf | ormation.     |                   |

### **Associativity Field Definitions**

This section describes the values returned in the associativity fields.

#### Associativity for L1 Caches and L1 TLBs

The associativity fields for the L1 data cache, L1 instruction cache, L1 data TLB, and L1 instruction TLB are all 8 bits wide. Except for 00h (Reserved) and FFh (Full), the number returned in the associativity field represents the actual number of ways, with a range of 01h through FEh. For example, a returned value of 02h indicates 2-way associativity and a returned value of 04h indicates 4-way associativity.

#### Associativity for L2 Caches and L2 TLBs

The associativity fields for the L2 cache, L2 data TLB, and L2 instruction TLB are 4 bits wide. Table 17 shows the values returned in these associativity fields.

| Bits 15–12 | Associativity |
|------------|---------------|
| 0000b      | L2 off        |
| 0001b      | Direct mapped |
| 0010b      | 2-way         |
| 0011b      | Reserved      |
| 0100b      | 4-way         |
| 0101b      | Reserved      |
| 0110b      | 8-way         |
| 0111b      | Reserved      |
| 1000b      | 16-way        |
| 1001b      | Reserved      |
| 1010b      | Reserved      |
| 1011b      | Reserved      |
| 1100b      | Reserved      |
| 1101b      | Reserved      |
| 1110b      | Reserved      |
| 1111b      | Full          |

Table 17. Associativity Values For L2 Caches and TLBs

# **Appendix B**

# **Register Values Returned by the AMD Family Processors**

Tables 18 through 20 contain all the values returned for AMD processors by the CPUID instruction.

## AMD Athlon<sup>™</sup> Processor Values

| Function<br>Registe | AMD Athlon™<br>Processor<br>(Model 1) |
|---------------------|---------------------------------------|
| Function: 0         |                                       |
| EAX                 | 0000_0001h                            |
| EBX                 |                                       |
| EC                  |                                       |
| ED                  | 6974_6E65h                            |
| Function: 1         |                                       |
| EAX                 |                                       |
| EBX                 | -                                     |
| EC                  |                                       |
| EDX                 | 0081_F9FFh <sup>1</sup>               |
| Function:           |                                       |
| 8000_0000h          |                                       |
| EAX                 |                                       |
| EB                  |                                       |
| EC                  |                                       |
| EDX                 | C Reserved                            |
| Function:           |                                       |
| 8000_0001h          |                                       |
| EAX                 |                                       |
| EB                  | -                                     |
| EC                  | •                                     |
| ED)                 | COC1_F9FFh <sup>2</sup>               |
| Function:           |                                       |
| 8000_0002h          |                                       |
| EAX                 |                                       |
| EB                  |                                       |
| EC                  |                                       |
| ED)                 | 6563_6F72h                            |

#### Table 18. Values Returned By the AMD Athlon™ Processor

Notes:

1. AMD Athlon processors contain APIC, MTRRs, Global Paging Extension, Machine Check Architecture, Conditional Move Instructions, and Page Attribute Table.

2. AMD Athlon processors contain Machine Check Architecture, Conditional Move Instructions, and Page Attribute Table.

3. The L2 cache size and associativity on the AMD Athlon processor are product specific. Valid sizes are 512 Kbytes, 1 Mbytes, 2 Mbytes, 4 Mbytes, or 8 Mbytes. Associativity is two-way for 512-Kbyte, 1-Mbyte, and 2-Mbyte L2 cache sizes and direct mapped for 4-Mbyte, and 8-Mbyte L2 cache sizes.

| Function<br>Register     | AMD Athlon™<br>Processor<br>(Model 1)                           |                                                 |
|--------------------------|-----------------------------------------------------------------|-------------------------------------------------|
| Function:<br>8000_0003h  |                                                                 |                                                 |
| EAX<br>EBX<br>ECX<br>EDX | 726F_7373h<br>0000_0000h<br>0000_0000h<br>0000_0000h            |                                                 |
| Function:<br>8000_0004h  |                                                                 |                                                 |
| EAX<br>EBX<br>ECX<br>EDX | 0000_0000h<br>0000_0000h<br>0000_0000h<br>0000_0000h            |                                                 |
| Function:<br>8000_0005h  |                                                                 | - Reserved for future AMD Athlon processor mode |
| EAX<br>EBX<br>ECX<br>EDX | 0408_FF08h<br>FF18_FF10h<br>4002_0140h<br>4002_0140h            |                                                 |
| Function:<br>8000_0006h  |                                                                 |                                                 |
| EAX<br>EBX<br>ECX<br>EDX | 0000_0000h<br>4100_4100h<br>****_*140h <sup>3</sup><br>Reserved |                                                 |

Table 18. Values Returned By the AMD Athlon™ Processor (continued)

Notes:

1. AMD Athlon processors contain APIC, MTRRs, Global Paging Extension, Machine Check Architecture, Conditional Move Instructions, and Page Attribute Table.

2. AMD Athlon processors contain Machine Check Architecture, Conditional Move Instructions, and Page Attribute Table.

3. The L2 cache size and associativity on the AMD Athlon processor are product specific. Valid sizes are 512 Kbytes, 1 Mbytes, 2 Mbytes, 4 Mbytes, or 8 Mbytes. Associativity is two-way for 512-Kbyte, 1-Mbyte, and 2-Mbyte L2 cache sizes and direct mapped for 4-Mbyte, and 8-Mbyte L2 cache sizes.

AMD Processor Recognition

## AMD-K6<sup>®</sup> Processor Values

| Function<br>Register     | AMD-K6 <sup>®</sup><br>Processor<br>(Model 6) | AMD-K6<br>Processor<br>(Model 7)                 | AMD-K6-2<br>Processor<br>(Model 8)                            | AMD-K6-III<br>Processor<br>(Model 9)             |
|--------------------------|-----------------------------------------------|--------------------------------------------------|---------------------------------------------------------------|--------------------------------------------------|
| Function: 0              |                                               |                                                  |                                                               |                                                  |
| EAX<br>EBX<br>ECX        | 6874_7541h                                    | 0000_0001h<br>6874_7541h<br>444D 4163h           | 0000_0001h<br>6874_7541h<br>444D 4163h                        | 0000_0001h<br>6874_7541h<br>444D 4163h           |
| EDX                      |                                               | 6974_6E65h                                       | 6974_6E65h                                                    | 6974_6E65h                                       |
| Function: 1              |                                               |                                                  |                                                               |                                                  |
| EAX<br>EBX<br>ECX<br>EDX | Reserved<br>Reserved                          | 0000_057Xh<br>Reserved<br>Reserved<br>0080_01BFh | 0000_058Xh<br>Reserved<br>Reserved<br>0080_21BFh <sup>1</sup> | 0000_059Xh<br>Reserved<br>Reserved<br>0080_21BFh |
| Function:<br>8000_0000h  |                                               |                                                  |                                                               |                                                  |
| EAX<br>EBX<br>ECX<br>EDX | Reserved<br>Reserved                          | 8000_0005h<br>Reserved<br>Reserved<br>Reserved   | 8000_0005h<br>Reserved<br>Reserved<br>Reserved                | 8000_0006h<br>Reserved<br>Reserved<br>Reserved   |
| Function:<br>8000_0001h  |                                               |                                                  |                                                               |                                                  |
| EAX<br>EBX<br>ECX<br>EDX | Reserved<br>Reserved                          | 0000_067Xh<br>Reserved<br>Reserved<br>0080 05BFh | 0000_068Xh<br>Reserved<br>Reserved<br>8080_29BFh <sup>2</sup> | 0000_069Xh<br>Reserved<br>Reserved<br>8080 29BFh |

#### Table 19. Values Returned By AMD-K6<sup>®</sup> Processors

Notes:

1. AMD-K6-2 processor Model 8/[F:8], EDX = 0080\_21BFh – Global Paging Extension supported. AMD-K6-2 processor Model 8/[7:0], EDX = 0080\_01BFh.

2. AMD-K6-2 processor Model 8/[F:8], EDX = 8080\_29BFh – Global Paging Extension supported. AMD-K6-2 processor Model 8/[7:0], EDX = 8080\_09BFh.

*3.* Extended functions 8000\_0002h, 8000\_0003h, and 8000\_0004h each return part of the processor name string. Some AMD-K6-2 processors may have the following name string: function 8000\_0002h, ECX = 322D\_296Dh and EDX = 6F72\_5020h, and function 8000\_0003h, EAX = 7373\_6563h and EBX = 0000\_726Fh.

4. Extended functions 8000\_0002h, 8000\_0003h, and 8000\_0004h each return part of the processor name string. Some AMD-K6-III processors may have the following name string: function 8000\_0002h, ECX = 492D\_296Dh and EDX = 5020\_4949h, and function 8000\_0003h, EAX = 6563\_6F72h and EBX = 726F\_7373h.

| Function<br>Re | gister | AMD-K6 <sup>®</sup><br>Processor<br>(Model 6) | AMD-K6<br>Processor<br>(Model 7) | AMD-K6-2<br>Processor<br>(Model 8) | AMD-K6-III<br>Processor<br>(Model 9) |
|----------------|--------|-----------------------------------------------|----------------------------------|------------------------------------|--------------------------------------|
| Function:      |        |                                               |                                  |                                    |                                      |
| 8000_0002h     |        |                                               |                                  |                                    |                                      |
|                | EAX    | 2D44 4D41h                                    | 2D44 4D41h                       | 2D44_4D41h                         | 2D44_4D41h                           |
|                | EBX    | 6D74 364Bh                                    | 6D74 364Bh                       | 7428_364Bh                         | 7428_364Bh                           |
|                | ECX    | 202F_7720h                                    | 202F_7720h                       | 3320_296Dh <sup>3</sup>            | 3320_296Dh <sup>4</sup>              |
|                | EDX    | 746C_756Dh                                    | 746C_756Dh                       | 7270_2044h <sup>3</sup>            | 5020_2B44h <sup>4</sup>              |
| Function:      |        |                                               |                                  |                                    |                                      |
| 8000_0003h     |        |                                               |                                  |                                    |                                      |
|                | EAX    | 6465 6D69h                                    | 6465_6D69h                       | 7365_636Fh <sup>3</sup>            | 6563_6F72h <sup>4</sup>              |
|                | EBX    | 6520_6169h                                    | 6520_6169h                       | 0072 6F73h <sup>3</sup>            | 726F 7373h <sup>4</sup>              |
|                | ECX    | 6E65_7478h                                    | 6E65_7478h                       | 0000 0000h                         | 0000 0000h                           |
|                | EDX    | 6E6F_6973h                                    | 6E6F_6973h                       | 0000_0000h                         | 0000_0000h                           |
| Function:      |        |                                               |                                  |                                    |                                      |
| 8000_0004h     |        |                                               |                                  |                                    |                                      |
|                | EAX    | 0000 0073h                                    | 0000 0073h                       | 0000 0000h                         | 0000_0000h                           |
|                | EBX    | 0000 0000h                                    | 0000 0000h                       | 0000 0000h                         | 0000 0000h                           |
|                | ECX    | 0000_0000h                                    | 0000_0000h                       | 0000_0000h                         | 0000_0000h                           |
|                | EDX    | 0000_0000h                                    | 0000_0000h                       | 0000_0000h                         | 0000_0000h                           |
| Function:      |        |                                               |                                  |                                    |                                      |
| 8000_0005h     |        |                                               |                                  |                                    |                                      |
|                | EAX    | Reserved                                      | Reserved                         | Reserved                           | Reserved                             |
|                | EBX    | 0280_0140h                                    | 0280_0140h                       | 0280_0140h                         | 0280_0140h                           |
|                | ECX    | 2002_0220h                                    | 2002_0220h                       | 2002_0220h                         | 2002_0220h                           |
|                | EDX    | 2002_0220h                                    | 2002_0220h                       | 2002_0220h                         | 2002_0220h                           |

|  | Table 19. | Values Returned B | y AMD-K6 <sup>®</sup> | Processors | (continued) |
|--|-----------|-------------------|-----------------------|------------|-------------|
|--|-----------|-------------------|-----------------------|------------|-------------|

Notes:

AMD-K6-2 processor Model 8/[F:8], EDX = 0080\_21BFh – Global Paging Extension supported. 1. AMD-K6-2 processor Model 8/[7:0], EDX = 0080\_01BFh.

2. AMD-K6-2 processor Model 8/[F:8], EDX = 8080\_29BFh – Global Paging Extension supported. AMD-K6-2 processor Model 8/[7:0], EDX = 8080\_09BFh.

3. Extended functions 8000\_0002h, 8000\_0003h, and 8000\_0004h each return part of the processor name string. Some AMD-K6-2 processors may have the following name string: function  $8000_{002h}$ , ECX =  $322D_{296Dh}$  and EDX =  $6F72_{5020h}$ , and function 8000\_0003h, EAX = 7373\_6563h and EBX = 0000\_726Fh.

4. Extended functions 8000\_0002h, 8000\_0003h, and 8000\_0004h each return part of the processor name string. Some AMD-K6-III processors may have the following name string: function 8000\_0002h, ECX = 492D\_296Dh and EDX = 5020\_4949h, and function '8000 0003h, ÉAX = 6563 6F72h and EBX = 726F 7373h.

| Function<br>Register | AMD-K6 <sup>®</sup><br>Processor<br>(Model 6) | AMD-K6<br>Processor<br>(Model 7) | AMD-K6-2<br>Processor<br>(Model 8) | AMD-K6-III<br>Processor<br>(Model 9) |
|----------------------|-----------------------------------------------|----------------------------------|------------------------------------|--------------------------------------|
| Function:            |                                               |                                  |                                    |                                      |
| 8000_0006h           |                                               |                                  |                                    |                                      |
| EAX                  | Undefined                                     | Undefined                        | Undefined                          | Reserved                             |
| EBX                  | Undefined                                     | Undefined                        | Undefined                          | Reserved                             |
| ECX                  | Undefined                                     | Undefined                        | Undefined                          | 0100_4220h                           |
| EDX                  | Undefined                                     | Undefined                        | Undefined                          | Reserved                             |

#### Table 19. Values Returned By AMD-K6<sup>®</sup> Processors (continued)

AMD-K6-2 processor Model 8/[7:0], EDX = 0080\_01BFh.

2. AMD-K6-2 processor Model 8/[F:8], EDX = 8080\_29BFh – Global Paging Extension supported. AMD-K6-2 processor Model 8/[7:0], EDX = 8080\_09BFh.

3. Extended functions 8000\_0002h, 8000\_0003h, and 8000\_0004h each return part of the processor name string. Some AMD-K6-2 processors may have the following name string: function 8000\_0002h, ECX = 322D\_296Dh and EDX = 6F72\_5020h, and function 8000\_0003h, EAX = 7373\_6563h and EBX = 0000\_726Fh.

4. Extended functions 8000\_0002h, 8000\_0003h, and 8000\_0004h each return part of the processor name string. Some AMD-K6-III processors may have the following name string: function 8000\_0002h, ECX = 492D\_296Dh and EDX = 5020\_4949h, and function 8000 0003h, EAX = 6563 6F72h and EBX = 726F 7373h.

## Am486<sup>®</sup>, Am5<sub>X</sub>86<sup>®</sup>, and AMD-K5<sup>m</sup> Processor Values

|                                   |                                                                          |                                                      | , allu ANID-KS                                       | 1100055015                                           |                                                          |
|-----------------------------------|--------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------|
| Function<br>Register              | Am486 <sup>®</sup> and<br>Am5 <sub>X</sub> 86 <sup>®</sup><br>Processors | AMD-K5™<br>Processor<br>(Model 0)                    | AMD-K5<br>Processor<br>(Model 1)                     | AMD-K5<br>Processor<br>(Model 2)                     | AMD-K5<br>Processor<br>(Model 3)                         |
| Function: 0                       |                                                                          |                                                      |                                                      |                                                      |                                                          |
| EAX<br>EBX<br>ECX<br>EDX          | 0000_0001h<br>6874_7541h<br>444D_4163h<br>6974_6E65h                     | 0000_0001h<br>6874_7541h<br>444D_4163h<br>6974_6E65h | 0000_0001h<br>6874_7541h<br>444D_4163h<br>6974_6E65h | 0000_0001h<br>6874_7541h<br>444D_4163h<br>6974_6E65h | 0000_0001 h<br>6874_7541 h<br>444D_4163 h<br>6974_6E65 h |
| Function: 1                       |                                                                          |                                                      |                                                      |                                                      |                                                          |
| EAX<br>EBX<br>ECX<br>EDX          | 0000_04XXh<br>Reserved<br>Reserved<br>0000_0001h                         | 0000_050Xh<br>Reserved<br>Reserved<br>0000_03BFh*    | 0000_051Xh<br>Reserved<br>Reserved<br>0000_21BFh     | 0000_052Xh<br>Reserved<br>Reserved<br>0000_21BFh     | 0000_053Xh<br>Reserved<br>Reserved<br>0000_21BFh         |
| Function:<br>8000_0000h           |                                                                          |                                                      |                                                      |                                                      |                                                          |
| EAX<br>EBX<br>ECX<br>EDX          | 0000_0000h<br>Undefined<br>Undefined<br>Undefined                        | 0000_0000h<br>Undefined<br>Undefined<br>Undefined    | 8000_0005h<br>Reserved<br>Reserved<br>Reserved       | 8000_0005h<br>Reserved<br>Reserved<br>Reserved       | 8000_0005h<br>Reserved<br>Reserved<br>Reserved           |
| Function:<br>8000_0001h           |                                                                          |                                                      |                                                      |                                                      |                                                          |
| EAX<br>EBX<br>ECX<br>EDX          | Undefined<br>Undefined<br>Undefined<br>Undefined                         | Undefined<br>Undefined<br>Undefined<br>Undefined     | 0000_051Xh<br>Reserved<br>Reserved<br>0000_21BFh     | 0000_052Xh<br>Reserved<br>Reserved<br>0000_21BFh     | 0000_053Xh<br>Reserved<br>Reserved<br>0000_21BFh         |
| Function:<br>8000_0002h           |                                                                          |                                                      |                                                      |                                                      |                                                          |
| EAX<br>EBX<br>ECX<br>EDX          | Undefined<br>Undefined<br>Undefined<br>Undefined                         | Undefined<br>Undefined<br>Undefined<br>Undefined     | 2D44_4D41h<br>7428_354Bh<br>5020_296Dh<br>6563_6F72h | 2D44_4D41h<br>7428_354Bh<br>5020_296Dh<br>6563_6F72h | 2D44_4D41h<br>7428_354Bh<br>5020_296Dh<br>6563_6F72h     |
| Function:<br>8000_0003h           |                                                                          |                                                      |                                                      |                                                      |                                                          |
| EAX<br>EBX<br>ECX<br>EDX<br>Note: | Undefined<br>Undefined<br>Undefined<br>Undefined                         | Undefined<br>Undefined<br>Undefined<br>Undefined     | 726F_7373h<br>0000_0000h<br>0000_0000h<br>0000_0000h | 726F_7373h<br>0000_0000h<br>0000_0000h<br>0000_0000h | 726F_7373h<br>0000_0000h<br>0000_0000h<br>0000_0000h     |

#### Table 20. Values Returned By Am486<sup>®</sup>, Am5<sub>x</sub>86<sup>®</sup>, and AMD-K5<sup>™</sup> Processors

Note:

\* The AMD-K5 processor Model 0 reserves bit 13 and implements feature bit 9 to indicate support for Global Paging Extensions instead of support for APIC.

| Function<br>Register | Am486 <sup>®</sup> and<br>Am5 <sub>X</sub> 86 <sup>®</sup><br>Processors | AMD-K5™<br>Processor<br>(Model 0) | AMD-K5<br>Processor<br>(Model 1) | AMD-K5<br>Processor<br>(Model 2) | AMD-K5<br>Processor<br>(Model 3) |
|----------------------|--------------------------------------------------------------------------|-----------------------------------|----------------------------------|----------------------------------|----------------------------------|
| Function:            |                                                                          |                                   |                                  |                                  |                                  |
| 8000_0004h           |                                                                          |                                   |                                  |                                  |                                  |
| EAX                  | Undefined                                                                | Undefined                         | 0000_0000h                       | 0000_0000h                       | 0000_0000h                       |
| EBX                  | Undefined                                                                | Undefined                         | 0000_0000h                       | 0000_0000h                       | 0000_0000h                       |
| ECX                  | Undefined                                                                | Undefined                         | 0000_0000h                       | 0000_0000h                       | 0000_0000h                       |
| EDX                  | Undefined                                                                | Undefined                         | 0000_0000h                       | 0000_0000h                       | 0000_0000h                       |
| Function:            |                                                                          |                                   |                                  |                                  |                                  |
| 8000_0005h           |                                                                          |                                   |                                  |                                  |                                  |
| EAX                  | Undefined                                                                | Undefined                         | Reserved                         | Reserved                         | Reserved                         |
| EBX                  | Undefined                                                                | Undefined                         | 0480_0000h                       | 0480_0000h                       | 0480_0000h                       |
| ECX                  | Undefined                                                                | Undefined                         | 0804_0120h                       | 0804_0120h                       | 0804_0120h                       |
| EDX                  | Undefined                                                                | Undefined                         | 1004_0120h                       | 1004_0120h                       | 1004_0120h                       |

#### Table 20. Values Returned By Am486<sup>®</sup>, Am5<sub>X</sub>86<sup>®</sup>, and AMD-K5<sup>™</sup> Processors (continued)

<sup>4</sup> The AMD-K5 processor Model 0 reserves bit 13 and implements feature bit 9 to indicate support for Global Paging Extensions instead of support for APIC.