# AMD Processor Recognition **Application Note** Publication # 20734 Rev: W-1 Issue Date: November 2002 #### © 2000-2002 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 Arrow logo, AMD Athlon, AMD Duron, and combinations thereof, and 3DNow! are trademarks, and AMD-K6-III, AMD-K6-2, AMD-K6, Am486, and ${\rm Am5}_{\rm x}$ 86 are registered trademarks of Advanced Micro Devices, Inc. MMX is a trademark of Intel Corporation. Microsoft is a registered trademark of Microsoft Corporation. Other product names used in this publication are for identification purposes only and may be trademarks of their respective companies. ## **Contents** | Introduction | |-----------------------------------------------------------| | CPUID Instruction Overview | | Testing for the CPUID Instruction | | Illegal Instruction Exception Method 3 | | EFLAGS ID-Bit Method | | Using CPUID Functions | | Identifying the Processor Vendor | | Testing For Extended Functions | | Determining the Processor Signature 7 | | Identifying Supported Features | | Determining Instruction Set Support | | CPUID Test | | MMX <sup>TM</sup> Test | | SSE Test | | Extended Functions Test | | 3DNow! <sup>TM</sup> Instruction Test | | Vendor Check | | MMX Extensions Test | | AMD Processor Signature (Extended Function) 13 | | Displaying the Processor Name | | Name String Supports up to 48 Characters14 | | Differentiation of Processors of the Same Model Number 14 | | S3 State Considerations | | Displaying Cache Information | | Determining Power Management Capabilities 17 | | Determining Maximum Physical and Linear Address Size 17 | | Code Samples | | Example CPUID Code | | Example Function Call | Contents | 2 0 0 | on <sup>TM</sup> Processor or AMD Duron <sup>TM</sup> | |-----------------------------------------|-------------------------------------------------------| | K7_CPUID | oroutine | | Appendix A CPUID Instruction Definition | 31 | | CPUID Instruction | 31 | | Standard Functions | 32 | | | dard Function Input Value and ng32 | | · · | nature and Standard Feature | | Extended Functions | 37 | | | rgest Extended Function Input | | | ID Processor Signature and | | | 00_0003h, and 8000_0004h—<br>43 | | | TLB/Cache Information for aron Processors 43 | | | Cache Information for AMD-K5 ors | | <del>-</del> | TLB/L2 Cache Information for aron Processors | | | Cache Information for the | | Associativity Field Definit | tions | | | dvanced Power Management49 | | | hysical Address and Linear | *iv* Contents | Appendix B | Register Values Returned by the AMD Family Processors | 51 | |------------|-------------------------------------------------------------------------------------|----| | | AMD Athlon Processor and AMD Duron Processor Values | 52 | | | AMD-K6 <sup>®</sup> Processor Values | 60 | | | Am486 <sup>®</sup> , Am5 <sub>x</sub> 86 <sup>®</sup> , and AMD-K5 Processor Values | 62 | Contents 20734W-1 – November 2002 *vi* Contents ## **List of Figures** | Figure 1. | Contents of EAX Register Returned by Function 1 | . 8 | |-----------|-------------------------------------------------|-----| | Figure 2. | Contents of EAX Register Returned by Extended | | | | Function 8000_0001h | 13 | List of Figures vii 20734W-1 – November 2002 viii List of Figures ## **List of Tables** | Table 1. | Summary of CPUID Functions in AMD Processors 5 | |-----------|------------------------------------------------------------------------------------------------------------------| | Table 2. | Summary of CPUID Functions in AMD Athlon <sup>TM</sup> and AMD Duron <sup>TM</sup> Processors | | Table 3. | Summary of Processor Signatures for AMD Processors 9 | | Table 4. | Summary of Standard and Extended Feature Bits 10 | | Table 5. | Processor Name Strings for AMD Athlon and AMD Duron Family of Processors Through Model 4 14 | | Table 6. | Recommended Name String by Platform Segment for AMD Athlon and AMD Duron Family of Processors Models 6 and Above | | Table 7. | Model Number Mappings for AMD Athlon Family of Processors | | Table 8. | Standard Feature Flag Descriptions for AMD-K6 <sup>®</sup> -2 and AMD-K6 <sup>®</sup> -III Processors | | Table 9. | Standard Feature Flag Descriptions for AMD Athlon Processors | | Table 10. | Standard Feature Flag Descriptions for AMD Duron Processors | | Table 11. | Extended Feature Flag Descriptions for AMD-K6-2 and AMD-K6-III Processors | | Table 12. | Extended Feature Flag Descriptions for AMD Athlon Processors | | Table 13. | Extended Feature Flag Descriptions for AMD Duron Processors | | Table 14. | EAX Format Returned by Function 8000_0005h 44 | | Table 15. | EBX Format Returned by Function 8000_0005h 44 | | Table 16. | ECX Format Returned by Function 8000_0005h 44 | | Table 17. | EDX Format Returned by Function 8000_0005h 44 | | Table 18. | EBX Format Returned by Function 8000_0005h 45 | | Table 19. | ECX Format Returned by Function 8000_0005h 45 | | Table 20. | EDX Format Returned by Function 8000_0005h 45 | List of Tables ix | Table 21. | EAX Format Returned by Function 8000_0006h 46 | |-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | Table 22. | EBX Format Returned by Function 8000_0006h 46 | | Table 23. | ECX Format Returned by Function 8000_0006h 47 | | Table 24. | ECX Format Returned by Function 8000_0006h for the AMD-K6®-III Processor | | Table 25. | Associativity Values For L2 Caches and TLBs 48 | | Table 26. | Values Returned by AMD Athlon <sup>TM</sup> and AMD Duron <sup>TM</sup> Processors Models 6, 7, and 8 | | Table 27. | Values Returned by Mobile AMD Athlon <sup>TM</sup> Processors<br>Models 6, 7, and 8, and Mobile AMD Duron <sup>TM</sup><br>Processors Models 3, 6, and 7 | | Table 28. | Values Returned by AMD Athlon <sup>TM</sup> Processors Models 1, 2, and 4, and AMD Duron <sup>TM</sup> Processors Model 3 58 | | Table 29. | Values Returned by AMD-K6® Processors 60 | | Table 30. | Values Returned by Am486 <sup>®</sup> , Am5 <sub>x</sub> 86 <sup>®</sup> , and | | | AMD-K5 Processors | x List of Tables ## **Revision History** | Date | Rev | Description | | | | | |---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | November 2002 | W-1 | Revised Table 12 in Appendix A | | | | | | November 2002 | W | Revised Table 7: Added additional model numbers — 2600+, a 2700+, and a 2800+ | | | | | | August 2002 | ٧ | Added 2400+ and 2600+ models to table 4. | | | | | | August 2002 | U | Added AMD Athlon™ processor model 8 information to the following: Table 2, "Summary of CPUID Functions in AMD Athlon™ and AMD Duron™ Processors" Table 3, "Summary of Processor Signatures for AMD Processors," on page 9 Table 6, "Recommended Name String by Platform Segment for AMD Athlon™ and AMD Duron™ Family of Processors Models 6 and Above," on page 15 Table 7, "Model Number Mappings for AMD Athlon™ Family of Processors," on page 16 Table 9, "Standard Feature Flag Descriptions for the AMD Athlon™ Processors" Table 12, "Extended Feature Flag Descriptions for AMD Athlon™ Processors" Table 26, "Values Returned By the AMD Athlon™ and AMD Duron™ Processors models 6 and 7, and 8" | | | | | Revision History xi | Date | Rev | Description | | | | | |--------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | January 2002 | T | Added the following: "Name String Supports up to 48 Characters" on page 14 "Differentiation of Processors of the Same Model Number" on page 14 "S3 State Considerations" on page 14 "Recommended Name String" on page 14 Table 5, "Processor Name Strings for AMD Athlon™ and AMD Duron™ Family of Processors Through Model 4," on page 14 Revised the following: Table 2, "Summary of CPUID Functions in AMD Athlon™ and AMD Duron™ Processors," on page 6 "Testing For Extended Functions" on page 7 Table 3, "Summary of Processor Signatures for AMD Processors," on page 8 Table 4, "Summary of Standard and Extended Feature Bits," on page 10 Table 6, "Recommended Name String by Platform Segment for AMD Athlon™ and AMD Duron™ Family of Processors Models 6 and Above," on page 16 Table 7, "Model Number Mappings for AMD Athlon™ Family of Processors," on page 35 Table 10, "Standard Feature Flag Descriptions for the AMD Duron™ Processors," on page 36 Table 12, "Extended Feature Flag Descriptions for AMD Athlon™ Processors," on page 39 Table 13, "Extended Feature Flag Descriptions for AMD Duron™ Processors," on page 41 Table 26, "Values Returned By the AMD Athlon™ and AMD Duron™ Processors Models 6 and 7," on page 52 Table 27, "Values Returned by the Mobile AMD Athlon™ Processors Models 6, 7, and 8, and | | | | | | July 2001 | S | the Mobile AMD Duron™ Processors Models 3, 6, and 7," on page 55 Added information about the mobile AMD Athlon™ 4 processor, the AMD Athlon™ MP processor, and the mobile AMD Duron™ processors. | | | | | | June 2000 | R | Added information about the AMD Duron <sup>™</sup> processor throughout the document. Revised "CPUID Instruction Overview" on page 3. Added "The AMD Duron <sup>™</sup> Processor" on page 2. Added Table 5, "Processor Name Strings for the AMD Duron <sup>™</sup> Processor," on page 13. | | | | | xii Revision History | Date | Rev | Description | |--------------------------------------------------------------------------------------------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | Added information about the AMD Athlon™ processor Model 4 throughout the document. | | | | Revised "CPUID Instruction Overview" on page 3. | | | | Revised Table 5, "Processor Name String," on page 15. | | | | Added code sample to "Code Samples" on page 17. | | | | Added "Displaying the AMD Athlon™ or AMD Duron™ Processor Name String" on page 25 and "DisplayK7NameString Subroutine" on page 26. | | | | Revised information about bit 15 in Table 4, "Summary of Standard and Extended Feature Bits," on page 11. | | | | Revised name string for AMD Athlon™ processor Model 1 in Table 5, "Processor Name String," on page 15. | | June 2000 | Q | Made Table 6, "Standard Feature Flag Descriptions for the AMD-K6®-2 and AMD-K6-III Processors," on page 32 is specific to these processors. | | | | Added Table 6, "Standard Feature Flag Descriptions for the AMD Athlon™ Processors," on page 31, which is specific to these processors. | | | | Clarified instruction family and generation being derived from function 1 and function 8000_0001 respectively. | | | | Made Table 9, "Extended Feature Flag Descriptions for the AMD-K6®-2 and AMD-K6-III Processors," on page 36 is specific to these processors. | | | | Added Table 8, "Extended Feature Flag Descriptions for the AMD Athlon™ Processors," on page 34, which is specific to these processors. | | | | Revised Table 21, "Values Returned By the AMD Athlon™ Processor," on page 42. | | Dec 1999 | Р | Added the AMD Athlon processor Model 2 information throughout document. Model 1 refers to the AMD Athlon processor manufactured with 0.25-micron process technology and Model 2 refers to the AMD Athlon processor manufactured with 0.18-micron process technology. | | Nov 1999 | 0 | Clarified usage of "Code Samples" on page 17. | | 1000 1999 | | Added "Example Function Call" on page 25. | | August 1999 | N | Merged standard and extended feature bits into one table. See Table 4, "Summary of Standard and Extended Feature Bits," on page 11. | | | | Revised Table 21, "Values Returned By the AMD Athlon™ Processor," on page 42. | | | | 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 4. | | | 101 | Revised "Determining Instruction Set Support" on page 13. | | | | Revised Tables 12 through 22 to cross-reference new section—"Associativity Field Definitions" on page 45. | | May 1999 L In Table 11 on page 18, changed function 8000_0001h EDX entries for Models 6 and 7 0080_01BFh to 0080_05BFh. | | | Revision History xiii | Date | Rev | Description | | | | |------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | May 1999 | L | Added note about the name string for the AMD-K6-2 processor to Table 11 on page 18. | | | | | | | Added L2 cache information to Table 1 on page 4. | | | | | | | Added Function 8000_0006h to "Displaying Cache Information" on page 10. | | | | | Feb 1999 | K | Added Function 8000_0006h — L2 Cache Information and Table 10, "ECX Format Returned by Function 8000_0006h," on page 17. | | | | | | | Added AMD-K6-III processor Model 9 values and three notes to Table 11 on page 18. | | | | | | | 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® Processors," on page 18, changed function 8000_0001h, EDX value for the AMD-K6 processor Model 7 and deleted note 2. | | | | | May 1998 | | Revised "Functions 8000_0002h, 8000_0003h, and 8000_0004h — Processor Name String" on page 16. | | | | | IVIAY 1998 | 1 | Added return values for AMD-K6 processor Model 9 to Table 10 on page 18. Divided Appendix B table into two separate tables. | | | | | Jan 1998 | Н | Added revised bit 31 description and alternate test for AMD-K6-2 to "Identifying Supported Features" on page 6. | | | | | | | 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. | | | | | | | Added AMD-K6®-2 processor return values to Table 12 on page 21. | | | | | Sept 1997 | F | Moved SYSCALL/SYSRET instruction feature bit (in extended feature function 8000_0001h) from bit 10 to bit 11. See Table 6 on page 15 and Table 12 on page 21. | | | | | Sept 1997 | F | Added bit 31 to the extended feature function 8000_0001h for a new feature. See Table 4 on page 8 and Table 6 on page 15. | | | | | Sept 1997 | F | Added support for AMD-K6® processor Models 7, 8, and 9 to Table 1 on page 4 and Table 2 on page 5. | | | | | Sept 1997 | F | Added return values for AMD-K6 processor Model 7 to Table 12 on page 21. | | | | **xiv** Revision History # 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 on how to use the CPUID instruction to identify AMD processors and their features. After detecting the processor and its capabilities, software can be 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> instruction, SSE, or MMX<sup>TM</sup> instruction support on the processor. (The combined support of 3DNow! instruction extensions SSE is and 3DNow! Professional technology.) 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. Introduction 1 #### **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," contains a detailed description of the CPUID instruction. ## **Testing for the CPUID Instruction** 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: - Execute the CPUID instruction and check whether an illegal instruction exception occurs. If an exception occurs, the processor does not have CPUID support. - Check if the ID bit (bit 21) of the EFLAGS register is writable. If the bit is writable (that is, it can be modified), the CPUID instruction is supported. The Operating System (OS) environment determines which approach is more appropriate. These methods are described in the following sections. ## **Illegal Instruction Exception Method** This method requires a way for a user program to detect and handle illegal instruction exceptions. Where such capabilities are present, this method represents a reliable way of detecting support for the CPUID instruction. The CPUID sample code starting on page 18 uses this method. #### **EFLAGS ID-Bit Method** This method retrieves the contents of EFLAGS using the PUSHFD instruction, toggles the ID bit, and uses the POPFD instruction to write the modified value of the ID bit into the EFLAGS register. It then retrieves the contents of EFLAGS using a second PUSHFD instruction and checks whether the value of the ID bit differs from the original value. If the value has changed, the CPUID instruction is available for identifying the processor and its features. The following code sample demonstrates the way a program uses the PUSHFD and POPFD instructions to test the ID bit. ``` ; Save EFLAGS to stack pushfd gog eax : Store EFLAGS in EAX ; Save in EBX for testing later ebx, eax mov eax, 00200000h ; Switch bit 21 xor push eax : Copy changed value to stack popfd : Save changed EAX to EFLAGS pushfd ; Push EFLAGS to top of stack : Store EFLAGS in EAX рор eax ; See if bit 21 has changed cmp eax, ebx jΖ NO CPUID ; If no change, no CPUID ``` A potential problem with this method 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 preceding 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 the software 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 the AMD family of processors, different members can execute a different number of functions. Table 1 on page 5 and Table 2 on page 6 summarize the CPUID functions currently implemented on AMD processors. **Table 1. Summary of CPUID Functions in AMD Processors** | Standard<br>Function | Extended<br>Function | Description | AMD-K5<br>Processor<br>(Model 0),<br>Am486 <sup>®</sup> DX4<br>and Am5 <sub>x</sub> 86 <sup>®</sup><br>Processors | AMD-K5<br>Processor<br>(Models 1,<br>2, and 3) | AMD-K6 <sup>®</sup> Processor (Models 6, 7) AMD-K6-2 Processor (Model 8) | AMD-K6-III<br>Processor<br>(Model 9) | |----------------------|----------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------------------------------------|--------------------------------------| | 0 | - | Vendor String and Largest<br>Standard Function Value | Х | Х | Х | Х | | 1 | _ | Processor Signature and<br>Standard Feature Bits | Х | Х | Х | Х | | _ | 8000_0000h | Largest Extended<br>Function Value | _ | Х | Х | Х | | _ | 8000_0001h | Extended Processor<br>Signature and Extended<br>Feature Bits | _ | Х | X | Х | | _ | 8000_0002h | Processor Name | _ | Х | Х | Х | | _ | 8000_0003h | Processor Name | _ | Х | Х | Х | | _ | 8000_0004h | Processor Name | _ | Х | Х | Х | | _ | 8000_0005h | L1 TLB*/Cache<br>Information | _ | Х | Х | Х | | _ | 8000_0006h | L2 TLB/Cache<br>Information | - | _ | _ | Х | | _ | 8000_0007h | Advanced Power<br>Management Feature<br>Flags | _ | - | _ | - | | - Notes: | 8000_0008h | Physical Address and<br>Linear Address Size | _ | - | - | - | #### Notes: Future versions of these processors may implement additional functions. Appendix A, "CPUID Instruction Definition," contains detailed descriptions of the functions. Using CPUID Functions 5 <sup>\*</sup> TLB = Translation Lookaside Buffer. Table 2. Summary of CPUID Functions in AMD Athlon™ and AMD Duron™ Processors | Standard<br>Function | Extended<br>Function | Description | AMD Athlon™<br>Processor<br>Models 1, 2,<br>and 4 | AMD Duron™<br>Processor<br>Model 3 | AMD Athlon<br>and<br>AMD Duron<br>Processors<br>Model 6 <sup>2</sup> | AMD Duron<br>Processors<br>Model 7 <sup>3</sup> | AMD Athlon<br>Processors<br>Model 8 <sup>4</sup> | |----------------------|----------------------|--------------------------------------------------------------|---------------------------------------------------|------------------------------------|----------------------------------------------------------------------|-------------------------------------------------|--------------------------------------------------| | 0 | _ | Vendor String and<br>Largest Standard<br>Function Value | Х | Х | Х | Х | Х | | 1 | _ | Processor Signature<br>and Standard Feature<br>Bits | Х | Х | Х | Х | Х | | _ | 8000_0000h | Largest Extended<br>Function Value | Х | Х | Х | Х | Х | | _ | 8000_0001h | Extended Processor<br>Signature and<br>Extended Feature Bits | Х | Х | Х | Х | Х | | _ | 8000_0002h | Processor Name | X | X | X | X | Х | | _ | 8000_0003h | Processor Name | Х | Х | Х | Х | Х | | _ | 8000_0004h | Processor Name | Х | X | Х | Х | Х | | _ | 8000_0005h | L1 TLB <sup>1</sup> /Cache<br>Information | Х | Х | Х | Х | Х | | _ | 8000_0006h | L2 TLB/Cache<br>Information | Х | Х | Х | Х | Х | | - | 8000_0007h | Advanced Power<br>Management Feature<br>Flags | _ | - | Х | Х | Х | | - Notes | 8000_0008h | Physical Address and<br>Linear Address Size | - | _ | X | X | Х | #### Notes: Future versions of these processors may implement additional functions. Appendix A, "CPUID Instruction Definition," contains detailed descriptions of the functions. - 1. TLB = Translation Lookaside Buffer. - 2. The AMD Athlon™ processor model 6 includes the AMD Athlon MP processor, the AMD Athlon XP processor, and the mobile AMD Athlon 4 processor. The AMD Duron™ processor model 6 includes the AMD Duron processor and the mobile AMD Duron processor. - 3. The AMD Duron processor model 7 includes both the AMD Duron processor and the mobile AMD Duron processor. - 4. The AMD Athlon processor model 8 includes the AMD Athlon MP processor, the AMD Athlon XP processor, and the mobile AMD Athlon XP processor. ## **Identifying the Processor Vendor** Software must execute the standard function EAX=0. The CPUID instruction returns a 12-character string that identifies the vendor of the processor. 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 vendor of the processor, 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 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. ## **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<sup>TM</sup> processor models and the AMD Duron<sup>TM</sup> processor belong to instruction family 6. Figure 1 shows the contents of the EAX register obtained by function 1. Table 3 on page 9 summarizes the specific processor signature values returned for AMD processors. Figure 1. Contents of EAX Register Returned by Function 1 **Table 3. Summary of Processor Signatures for AMD Processors** | Processor | Instruction<br>Family [11:8] | Model<br>[7:4] | Stepping ID <sup>2</sup> [3:0] | |--------------------------------------------------------------------|------------------------------|-------------------|--------------------------------| | Am486 <sup>®</sup> and Am5 <sub>x</sub> 86 <sup>®</sup> Processors | 0100b (4h) | yyyy <sup>1</sup> | xxxx | | AMD-K5 Model 0 | 0101b (5h) | 0000b (0h) | XXXX | | AMD-K5 Model 1 | 0101b (5h) | 0001b (1h) | XXXX | | AMD-K5 Model 2 | 0101b (5h) | 0010b (2h) | XXXX | | AMD-K5 Model 3 | 0101b (5h) | 0011b (3h) | XXXX | | AMD-K6 <sup>®</sup> Model 6 | 0101b (5h) | 0110b (6h) | XXXX | | AMD-K6 Model 7 | 0101b (5h) | 0111b (7h) | XXXX | | AMD-K6 <sup>®</sup> -2 Model 8 | 0101b (5h) | 1000b (8h) | XXXX | | AMD-K6 <sup>®</sup> -III Model 9 | 0101b (5h) | 1001b (9h) | xxxx | | AMD Athlon™ Model 1 | 0110b (6h) | 0001b (1h) | XXXX | | AMD Athlon Model 2 | 0110b (6h) | 0010b (2h) | XXXX | | AMD Duron™ Model 3 | 0110b (6h) | 0011b (3h) | xxxxb | | AMD Athlon Model 4 | 0110b (6h) | 0100b (4h) | xxxxb | | AMD Athlon MP Model 6 | 0110b (6h) | 0110b (6h) | xxxxb | | AMD Athlon XP Model 6 | 0110b (6h) | 0110b (6h) | xxxxb | | Mobile AMD Athlon 4 Model 6 | 0110b (6h) | 0110b (6h) | xxxxb | | AMD Duron Model 6 | 0110b (6h) | 0110b (6h) | xxxxb | | Mobile AMD Duron Model 6 | 0110b (6h) | 0110b (6h) | xxxxb | | AMD Duron Model 7 | 0110b (6h) | 0111b (7h) | xxxxb | | Mobile AMD Duron Model 7 | 0110b (6h) | 0111b (7h) | xxxxb | | AMD Athlon XP Model 8 | 0110b (6h) | 1000b (8h) | xxxxb | | AMD Athlon MP Model 8 | 0110b (6h) | 1000b (8h) | xxxxb | | Mobile AMD Athlon XP Model 8 | 0110b (6h) | 1000b (8h) | xxxxb | #### Notes: <sup>1.</sup> Contact your AMD representative for model identifier information. <sup>2.</sup> Stepping ID may change. Consult the appropriate processor Revision Guide, or contact your AMD representative for the latest stepping information. AMD Athlon™ processors of the same model numbers share the same Revision Guide. AMD Duron™ processors of the same model number share the same Revision Guide. ## **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 4 summarizes the standard and extended feature bits. **Table 4. 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) | Four-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, 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 | | 11 | SYSENTER/SYSEXIT Instructions | The SYSENTER and SYSEXIT instructions are supported. | 1 | 0 | | '' | SYSCALL and SYSRET Instructions | The SYSCALL and SYSRET instructions and 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 and FCMOV, are supported. The FCOMI instruction is also supported. | 1 | 1 | | 16 | PAT (Page Attribute Table) | The Page attribute tables are supported. | 1 | 1 | | Note: | I. | 1 | | ı | - 1. Appendix A, "CPUID Instruction Definition," contains details on bit locations and values. - 2. Bit definitions are as follows: 0 = No Support, 1 = Support. | Bit <sup>1</sup> | Feature | Description | Standard <sup>2</sup> | Extended <sup>2</sup> | |------------------|------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------|-----------------------| | 17 | PSE-36 (Page Size Extension) | Page size extensions for 36-bit addresses are supported using a 4-byte directory entry. | 1 | 1 | | 19 | Multiprocessing Capable | Processor capable of operating in multiprocessing configuration. | 0 | 1 | | 22 | AMD Multimedia Instruction<br>Extensions | AMD additions to the original MMX <sup>™</sup> instruction set are supported. | 0 | 1 | | 23 | MMX Instructions | The MMX instruction set is supported. | 1 | 1 | | 24 | FXSAVE/FXRSTOR Instructions | Fast floating-point save and restore is supported. | 1 | 1 | | 25 | Streaming SIMD Extensions (SSE) | Streaming SIMD instruction set extensions are supported. | 1 | 0 | | 30 | 3DNow!™ Instruction Extensions | Extensions to the 3DNow! instructions set are supported. | 0 | 1 | | 31 | 3DNow! Instructions | 3DNow! instructions are supported. | 0 | 1 | **Table 4. Summary of Standard and Extended Feature Bits (continued)** #### Note: - 1. Appendix A, "CPUID Instruction Definition," contains details on bit locations and values. - 2. Bit definitions are as follows: 0 = No Support, 1 = 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," and Appendix B, "Register Values Returned by the AMD Family Processors," 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. To simplify the detection of the new instructions supported in different models of AMD Athlon and AMD Duron family of processors, including the original 3DNow! and MMX instructions, Enhanced 3DNow!, and 3DNow! Professional (combining 3DNow! and SSE support), use the following algorithm. #### **CPUID Test** 1. Establish that the processor has support for CPUID. See "Testing for the CPUID Instruction" on page 3. #### Standard Function Test - 2. Execute CPUID function 0, which returns the processor vendor string and the highest standard function supported. 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™** Test 4. 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. #### **SSE Test** 5. If bit 25 of the standard feature flags is set to "1" on an AMD Athlon or AMD Duron model 6 or greater, SSE instructions are supported. Optionally, if bit 25 of the standard feature flags is set on any previous AMD processor, it 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 is not usable due to a lack of OS support for the additional architected registers. ## **Extended Functions Test** - 6. Execute CPUID extended function 8000\_0000h. This function returns the highest extended function supported in 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!™ Instruction Test 8. If bit 31 of the extended feature flags is set to "1", the 3DNow! instructions are supported. #### **Vendor Check** 9. If the previously saved vendor string (see step 2) contains "AuthenticAMD", continue on to the next step. **3DNow!™ Extensions Test** 10. If bit 30 of the extended feature flags is set to "1", the 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 shows the contents returned in the EAX register. 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. See "Displaying the AMD Athlon™ Processor or AMD Duron™ Processor Name String" on page 26 for an example of how to properly obtain and display the processor name string. #### **Name String Supports** up to 48 Characters Note that the processor name string supports up to 48 characters. For example, the name string "AMD Athlon(tm)" uses 14 characters. Future name strings may be longer, so BIOS vendors should take this into consideration when displaying the name string on boot-up or in a system configuration screen. #### **Differentiation of Processors of the Same Model Number** AMD Athlon and AMD Duron processors model 6 must have the name string programmed properly according to the values in Table 6 on page 15 depending on the processor's L2 cache size. If the L2 cache size value reported by extended function 8000\_0006h ECX bits[31:16] is 256 or greater, then the processor is an AMD Athlon family processor. If the L2 cache size reported is less than 256, then the processor is an AMD Duron family processor. #### S3 State **Considerations** Before entering the S3—Suspend to RAM (STR)—state, the BIOS must save off the processor name string MSRs. Upon exiting the S3 state, the BIOS must then reload the processor name string back into the appropriate MSRs. #### **Recommended Name String** Table 5 summarizes the recommended name strings for AMD Athlon and AMD Duron processors through model 4. Table 5. Processor Name Strings for AMD Athlon™ and AMD Duron™ Family of Processors **Through Model 4** | Processor | ASCII Name String | |--------------------------|-----------------------------------| | AMD Athlon™ Model 1 | AMD-K7(tm) processor | | AMD Athlon Model 2 | AMD Athlon(tm) processor | | AMD Duron™ Model 3 | AMD Duron(tm) <sup>1</sup> | | Mobile AMD Duron Model 3 | mobile AMD Duron(tm) <sup>1</sup> | | AMD Athlon Model 4 | AMD Athlon(tm) <sup>1</sup> | | Notes: | <u> </u> | This name string must be programmed into the processor by the BIOS. See the document, Displaying and Programming the Processor Name String BIOS Application Note, order# 90056. Table 6. Recommended Name String by Platform Segment for AMD Athlon™ and AMD Duron™ Family of Processors Models 6 and Above | Processor | CPUID | MP Capable (bit 19<br>of Extended<br>Feature Flags) | Platform Segment | Recommended Name String <sup>1</sup> | |---------------------|------------------|-----------------------------------------------------|------------------|-----------------------------------------------| | AMD Athlon™ Model 6 | 660 or 661 | Reserved | Multiprocessing | AMD Athlon(tm) MP | | AMD Athlon Model 6 | 660 or 661 | Reserved | Desktop | AMD Athlon(tm) | | AMD Athlon Model | 660 or 661 | Reserved | Mobile | mobile AMD Athlon(tm) 4 | | AMD Athlon Model 6 | 662 | 0 | Multiprocessing | AMD Athlon(tm) XP [xxxxx] <sup>2</sup> | | AMD Athlon Model 6 | 662 | 1 | Multiprocessing | AMD Athlon(tm) MP [xxxxx] <sup>2</sup> | | AMD Athlon Model 6 | 662 | N/A | Desktop | AMD Athlon(tm) XP [xxxxx] <sup>2</sup> | | AMD Athlon Model 6 | 662 | N/A | Mobile | mobile AMD Athlon(tm) 4 | | AMD Duron™ Model 6 | N/A <sup>3</sup> | N/A | Desktop | AMD Duron(tm) | | AMD Duron Model 6 | N/A <sup>3</sup> | N/A | Mobile | mobile AMD Duron(tm) | | AMD Duron Model 7 | N/A <sup>3</sup> | Reserved | Desktop | AMD Duron(tm) | | AMD Duron Model 7 | N/A <sup>3</sup> | Reserved | Mobile | mobile AMD Duron(tm) | | AMD Athlon Model 8 | N/A <sup>3</sup> | 0 | Multiprocessing | AMD Athlon(tm) XP [xxxxx] <sup>2</sup> | | AMD Athlon Model 8 | N/A <sup>3</sup> | 1 | Multiprocessing | AMD Athlon(tm) MP [xxxxx] <sup>2</sup> | | AMD Athlon Model 8 | N/A <sup>3</sup> | 0 | Desktop | AMD Athlon(tm) XP [xxxxx] <sup>2</sup> | | AMD Athlon Model 8 | N/A <sup>3</sup> | 1 | Desktop | AMD Athlon(tm) MP [xxxxx] <sup>2</sup> | | AMD Athlon Model 8 | N/A <sup>3</sup> | N/A | Mobile | mobile AMD Athlon(tm) XP [xxxxx] <sup>2</sup> | #### Notes: - 1. This name string <u>must</u> be programmed into the processor by the BIOS. See the document, Displaying and Programming the Processor Name String BIOS Application Note, order# 90056. - 2. See Table 7 on page 16 for proper model number to insert into name string. - 3. Recommended name strings for the AMD Duron™ processors models 6 and 7 and the AMD Athlon™ processor Model 8 do not vary by CPUID stepping value. | Frequency <sup>1</sup> (MHz) | Model Number | |------------------------------|--------------| | 1300 | 1500+ | | 1333 | 1500+ | | 1400 | 1600+ | | 1467 | 1700+ | | 1500 | 1800+ | | 1533 | 1800+ | | 1600 | 1900+ | | 1666 | 2000+ | | 1733 | 2100+ | | 1800 | 2200+ | | 2000 | 2400+ | | 2083 | 2600+ | | 2133 | 2600+ | | 2167 | 2700+ | | 2250 <sup>2</sup> | 2800+ | | Notes: | | **Table 7. Model Number Mappings for AMD Athlon™ Family of Processors** - It is recommended that the BIOS display the processor name string, including the model number, whenever displaying processor information during a bootup. If the processor frequency is displayed, then the processor name string, including the model number, must also be displayed. Motherboards will not pass AMD validation or be posted on the AMD recommended motherboard Web site, if during a bootup the processor frequency is displayed by the BIOS without also displaying the name string and model number for the AMD Athlon™ processors model 6 and higher having frequencies with corresponding model numbers. - 2. At any frequency above 2250 MHz, the model number should be omitted from the name string. #### **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 processors, the AMD Duron processors, and on the AMD-K6-III processor model 9. Some diagnostic software displays information about the system and the processor 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, "CPUID Instruction Definition." Software can simply display these values, eliminating the need for large pieces of code to test the memory structures. #### **Determining Power Management Capabilities** AMD Athlon family of processors model 6 or greater and AMD Duron family of processors model 7 support the detection of power management features through the use of function 8000\_0007h. These features include an on-chip thermal diode, Voltage ID transitioning, and Frequency ID transitioning. Desktop varieties of model 6 and model 7 processors will have support only for the thermal diode. Mobile varieties of model 6 and model 7 processors support the thermal diode, Voltage ID (VID) transitioning, and Frequency ID (FID) transitioning. ## **Determining Maximum Physical and Linear Address Size** AMD Athlon family of processors model 6 or greater and AMD Duron family processors model 7 support function 8000\_0008h, which provides the maximum physical and maximum linear address size supported by the processor. ## **Code Samples** Developers who want to create their own processor-features detection code should follow the sample code described in "Example CPUID Code." A more elaborate function call, which detects the full range of CPUID information, is provided as sample code in "Example Function Call" on page 26. #### **Example CPUID Code** Developers who want to create their own processor detection program should follow the algorithm in the "cpuid\_ex" program. The code sample is available from AMD's website at the following URL: http://www.amd.com/products/cpg/bin/cpuid\_ex.zip The source code is included, along with an executable that is compiled with Microsoft<sup>®</sup> Visual Studio C/C++ Versions 5 and 6. This example provides a simple algorithm for the developer to follow and can be accommodated by many different processors. The source code, cpuid\_ex.c, follows the recommendations described in this document. To display a list of supported features for the processor, run the program by typing cpuid\_ex ## For convenience, the example CPUID code is displayed as follows: ``` /* The following code follows the guidelines described in this document, It is meant to serve as only an example, as there are other ways to accomplish processor detection. */ #include <stdio.h> #include <excpt.h> /* Symbolic constants for feature flags in CPUID standard feature flags */ #define CPUID STD FPU 0x0000001 #define CPUID STD VME 0x0000002 #define CPUID STD DEBUGEXT 0x0000004 #define CPUID STD 4MPAGE 0x00000008 #define CPUID STD TSC 0x0000010 #define CPUID STD MSR 0x00000020 #define CPUID STD PAE 0x00000040 #define CPUID_STD_MCHKXCP 0x00000080 #define CPUID STD CMPXCHG8B 0x0000100 #define CPUID STD APIC 0 \times 00000200 #define CPUID STD SYSENTER 0x00000800 #define CPUID_STD_MTRR 0x00001000 #define CPUID STD GPE 0x00002000 #define CPUID STD MCHKARCH 0x00004000 #define CPUID_STD_CMOV 0x00008000 #define CPUID STD PAT 0x00010000 #define CPUID STD PSE36 0x00020000 #define CPUID_STD_MMX 0x00800000 #define CPUID_STD_FXSAVE 0x01000000 #define CPUID STD SSE 0x02000000 /* Symbolic constants for feature flags in CPUID extended feature flags */ #define CPUID_EXT_3DNOW 0x80000000 #define CPUID_EXT_AMD_3DNOWEXT 0x40000000 #define CPUID_EXT_AMD_MMXEXT 0x00400000 /* Symbolic constants for application specific feature flags */ #define FEATURE_CPUID 0x0000001 #define FEATURE STD FEATURES 0x0000002 #define FEATURE EXT FEATURES 0x00000004 #define FEATURE TSC 0x00000010 #define FEATURE_MMX 0x00000020 #define FEATURE_CMOV 0x00000040 #define FEATURE 3DNOW 0x0000080 #define FEATURE_3DNOWEXT 0x00000100 ``` \*/ - 1. Processor capabilities should be directly derived from CPUID feature bits wherever possible, instead of being derived from vendor strings and processor signatures. However, some features are not indicated by CPUID feature flags (whether basic or extended) and do require looking at vendor strings and processor signatures. Applications may also choose to implement pseudo capabilities, for example indicating performance levels. - 2. The basic feature flags returned by CPUID function #1 are compatible across all x86 processor vendors with very few exceptions and therefore common feature checks for things like MMX or TSC support do not require a vendor check before evaluating the basic feature flag information. If unsure about a particular feature, review the processor vendor's literature - 3. 3DNow! technology is an open standard. Therefore 3DNow! instruction capabilities are indicated by bit 31 in the extended feature flags regardless of processor vendor. - 4. Applications should always treat the floating-point part of SSE and the MMX part of SSE as separate capabilities because SSE FP requires OS support that might not be available, while SSE MMX works with all operating systems. ``` try { __asm xor eax, eax __asm xor ebx, ebx __asm xor ecx. ecx edx. edx __asm xor __asm cpuid __except (EXCEPTION_EXECUTE_HANDLER) { return (0): result |= FEATURE CPUID; asm { ;; Step 2: Check if CPUID supports function 1 (signature/std features) eax. eax ; CPUID function #0 xor ; largest std func/vendor string cpuid dword ptr [vendor], ebx mov : save dword ptr [vendor+4], edx vendor mov mov dword ptr [vendor+8], ecx string ; largest standard function==0? test eax, eax ; yes, no standard features func $no_standard_features jΖ [result], FEATURE STD FEATURES; does have standard features or ;; Step 3: Get standard feature flags and signature mov eax. 1 : CPUID function #1 cpuid ; get signature/std feature flgs mov [signature], eax ; save processor signature ;; Step 4: Extract desired features from standard feature flags ;; Check for time stamp counter support ; bit 4 indicates TSC support ecx, CPUID STD TSC mov ; supports TSC ? CPUID STD TSC:0 and ecx, edx ; supports TSC ? CY : NC neg есх ; supports TSC ? Oxffffffff:0 sbb ecx, ecx ecx, FEATURE TSC ; supports TSC ? FEATURE TSC:0 and or [result], ecx ; merge into feature flags ``` ``` ;; Check for MMX support ecx, CPUID_STD_MMX ; bit 23 indicates MMX support mov and ecx, edx ; supports MMX ? CPUID_STD_MMX:0 ; supports MMX ? CY : NC neg есх ; supports MMX ? Oxffffffff:0 sbb ecx. ecx ; supports MMX ? FEATURE_MMX:0 ecx, FEATURE_MMX and or [result], ecx ; merge into feature flags ;; Check for CMOV support mov ecx, CPUID_STD_CMOV ; bit 15 indicates CMOV support ; supports CMOV?CPUID STD CMOV:0 ecx, edx and ; supports CMOV ? CY : NC neg есх sbb ecx, ecx ; supports CMOV ? Oxffffffff:0 ecx, FEATURE CMOV ; supports CMOV ? FEATURE CMOV:0 and [result], ecx ; merge into feature flags ٥r ;; Check support for P6-style MTRRs ecx, CPUID STD MTRR ; bit 12 indicates MTRR support mov ecx. edx ; supports MTRR?CPUID STD MTRR:0 and ; supports MTRR ? CY : NC neg есх ; supports MTRR ? Oxffffffff:0 sbb ecx, ecx ecx, FEATURE P6 MTRR ; supports MTRR ? FEATURE MTRR:0 and [result], ecx ; merge into feature flags or ;; Check for initial SSE support. There can still be partial SSE ;; support. Step 9 will check for partial support. ; bit 25 indicates SSE support ecx, CPUID STD SSE mov ecx, edx ; supports SSE ? CPUID STD SSE:0 and ; supports SSE ? CY : NC neg есх ; supports SSE ? Oxffffffff:0 sbb ecx, ecx and ecx, (FEATURE MMXEXT+FEATURE SSEFP); supports SSE? ; FEATURE MMXEXT+FEATURE SSEFP:0 [result], ecx ; merge into feature flags οr ;; Step 5: Check for CPUID extended functions eax, 0x80000000 ; extended function 0x80000000 mov ; largest extended function cpuid eax. 0x80000000 : no function > 0x80000000? cmp ; yes, no extended feature flags jbe $no extended features [result], FEATURE_EXT_FEATURES; does have ext. feature flags or ;; Step 6: Get extended feature flags ``` ``` mov eax, 0x8000001 : CPUID ext. function 0x80000001 : EDX = extended feature flags cpuid ;; Step 7: Extract vendor independent features from extended flags :: Check for 3DNow! instruction support (vendor independent) mo v ecx. CPUID EXT 3DNOW ; bit 31 indicates 3DNow! support : supports 3DNow! ?CPUID EXT 3DNOW:0 and ecx, edx neg есх ; supports 3DNow! ? CY : NC ; supports 3DNow! ? Oxffffffff:0 sbb ecx. ecx ecx, FEATURE 3DNOW ; support 3DNow!?FEATURE 3DNOW:0 and or [result]. ecx ; merge into feature flags ;; Step 8: Determine CPU vendor 1ea esi, vendorAMD ; AMD's vendor string 1ea edi, vendor ; this CPU's vendor string mov ecx, 12 ; strings are 12 characters cld ; compare lowest to highest cmpsb : current vendor string == AMD's ? repe ; no, CPU vendor is not AMD inz $not AMD ;; Step 9: Check AMD specific extended features ecx, CPUID EXT AMD 3DNOWEXT ; bit 30 indicates 3DNow! ext. mov ecx, edx : 3DNow! ext? and ; 3DNow! ext ? CY : NC neg есх sbb ecx. ecx : 3DNow! ext. ? Oxffffffff : 0 ecx, FEATURE_3DNOWEXT ; 3DNow! ext?FEATURE 3DNOWEXT:0 and [result], ecx ; merge into feature flags οr [result], FEATURE MMXEXT ; determined SSE MMX support? test inz $has mmxext ; yes, don't need to check again ;; Check support for AMD's multimedia instruction set additions ecx, CPUID EXT AMD MMXEXT ; bit 22 indicates MMX extension mov and ecx. edx : MMX ext?CPUID EXT AMD MMXEXT:0 ; MMX ext? CY : NC nea есх ecx, ecx ; MMX ext? Oxffffffff : 0 sbb ecx, FEATURE_MMXEXT ; MMX ext ? FEATURE_MMXEXT:0 and [result], ecx or ; merge into feature flags $has mmxext: ``` ``` ;; Step 10: Check AMD-specific features not reported by CPUID :: Check support for AMD-K6 processor-style MTRRs mov eax, [signature]; get processor signature and eax, OxFFF; extract family/model/stepping eax. 0x588 : CPU < AMD-K6-2/CXT ? CY : NC cmp edx, edx; CPU < AMD-K6-2/CXT ? Oxffffffff:0 sbb not edx ; CPU < AMD-K6-2/CXT ? 0:0xffffffff eax, 0x600; CPU < AMD Athlon? CY: NC cmp ecx, ecx; CPU < AMD-K6 ? Oxffffffff:0 sbb and ecx, edx; (CPU \ge AMD - K6 - 2/CXT) \&\& ; (CPU<AMD Athlon) ? Oxffffffff:0 and ecx, FEATURE K6 MTRR; (CPU>=AMD-K6-2/CXT)&& ; (CPU<AMD Athlon) ? FEATURE K6 MTRR:0 [result], ecx ; merge into feature flags or $all done; desired features determined jmp $not AMD: /* Extract features specific to non AMD CPUs */ $no extended features: $no_standard_features: $all done: /* The FP part of SSE introduces a new architectural state and therefore requires support from the operating system. So even if CPUID indicates support for SSE FP, the application might not be able to use it. If CPUID indicates support for SSE FP, check here whether it is also supported by the OS, and turn off the SSE FP feature bit if there is no OS support for SSE FP. Operating systems that do not support SSE FP return an illegal instruction exception if execution of an SSE FP instruction is performed. Here, a sample SSE FP instruction is executed, and is checked for an exception using the (non-standard) __try/__except mechanism of Microsoft Visual C. */ if (result & FEATURE SSEFP) { try { __asm _emit 0x0f __asm _emit 0x56 __asm _emit 0xC0 ;; orps xmm0, xmm0 return (result): ``` ``` _except (EXCEPTION_EXECUTE_HANDLER) { return (result & (~FEATURE_SSEFP)); } else { return (result); /* The sample "application" */ int main (void) unsigned int capabilities = get_feature_flags(); printf ("features = \%08x\n", capabilities); printf ("CPU supports CPUID: capabilities & FEATURE_CPUID ? 'y' : 'n'); printf ("CPU supports CPUID STD: %c\n", capabilities & FEATURE_STD_FEATURES ? 'y' : 'n'); printf ("CPU supports CPUID EXT: %c\n", capabilities & FEATURE_EXT_FEATURES ? 'y' : 'n'); printf ("CPU supports TSC: %c\n", capabilities & FEATURE_TSC ? 'y' : 'n'); %c\n" printf ("CPU supports CMOV: capabilities & FEATURE CMOV ? 'y' : 'n'); printf ("CPU supports MMX: %c\n", capabilities & FEATURE MMX ? 'y' : 'n'); printf ("CPU supports 3DNOW: %c\n", capabilities & FEATURE_3DNOW ? 'y' : 'n'); printf ("CPU supports 3DNOW EXT: %c\n" capabilities & FEATURE 3DNOWEXT ? 'y' : 'n'); printf ("CPU supports AMD-K6-MTRR: %c\n" capabilities & FEATURE_K6_MTRR ? 'y' : 'n'); printf ("CPU supports P6-MTRR: %c\n", capabilities & FEATURE P6 MTRR ? 'y' : 'n'); printf ("CPU supports SSE MMX: %c\n", capabilities & FEATURE_MMXEXT ? 'y' : 'n'); printf ("CPU supports SSE FPU: %c\n", capabilities & FEATURE_SSEFP ? 'y' : 'n'); return (0); ``` ### **Example Function Call** The function call code sample detects the full range of CPUID information and allows the user to query capabilities through a simple function call. The code sample is available from AMD's website at the following URL: http://www.amd.com/products/cpg/bin/getcpu\_caps.zip The zip file contains two files—DETECT.C and ADETECT.H. Follow these steps to use the function call: - 1. Copy DETECT.C and ADETECT.H into your project directory. - 2. Add DETECT.C to your source project. Now the user can make calls to GetCPUCaps() in any module that includes ADETECT.H. Add the function call with the following statement: #include "ADETECT.H" This source code compiles under Microsoft Visual Studio C/C++ Versions 5 and 6. # Displaying the AMD Athlon™ Processor or AMD Duron™ Processor Name String All AMD Athlon and AMD Duron family of processors support CPUID extended functions 8000\_0002h, 8000\_0003h, and 8000\_0004h. These functions 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 look-up table. Instead, software can simply call these three functions to obtain the name string (up to 48 ASCII characters in Little-Endian format) and display it on the screen. The character string is terminated with a 00h (ASCII null character). The following code samples illustrate methods that can be used to display the processor name string as required by the AMD Athlon and AMD Duron processors branding strategy. ### **DisplayK7NameString Subroutine** The name string of the AMD Athlon and AMD Duron family of processors can be displayed by calling the subroutine DisplayK7NameString. The following code sample displays the processor name string. ``` DisplayK7NameString: Returns: cf=0 all 48 possible characters displayed cf=1 end of string reached :----- DisplayK7NameString proc near ; push eax push ebx push ecx push edx K7_CPUID 80000002h call DisplayK7NameSubstring; @f :End of string? K7_CPUID 80000003h call DisplayK7NameSubstring; ;End of string? K7_CPUID 80000004h call DisplayK7NameSubstring; @@: pop pop есх pop ebx pop ret DisplayK7NameString endp ``` #### **K7 CPUID** K7\_CPUID is an AMD macro that generates a CPUID instruction and, optionally, loads the EAX register with the specified function number. ``` K7_CPUID macro cpuidindex IFNB <cpuidindex> mov eax, cpuidindex ENDIF Db OFh, OA2h ;CPUID instruction endm ``` #### Using K7CPUID, the line of code K7\_CPUID 80000002h #### generates the following instructions: ``` mov eax, 80000002h CPUID ``` #### **DisplayK7NameSubstring** The DisplayK7NameSubstring subroutine is called up to three times to display the ASCII characters returned by each CPUID function call. ``` DisplayK7NameSubstring: Returns: cf=0 no errors cf=1 end of string reached DisplayK7NameSubstring proc near; Displays eax, ebx, ecx, edx call DisplayEaxAscii; eax jс @f ;End of string? xchg eax, ebx call DisplayEaxAscii ; ebx @f ;End of string? jс xchg eax, ecx call DisplayEaxAscii ; ecx ;End of string? .i c xchg eax, edx call DisplayEaxAscii ; edx @@: DisplayK7NameSubstring endp ``` #### DisplayEaxAscii The DisplayK7NameSubstring subroutine calls the DisplayEaxAscii subroutine up to four times. DisplayEaxAscii displays the four bytes of the EAX register as ASCII characters starting with the least-significant byte (Little Endian). The subroutine DisplayAlChar used in the example is a generic name for a subroutine that displays the value in the AL register as an ASCII character. This type of subroutine is common to all type of BIOS under a variety of names. ``` ; DisplayEaxAscii: ; Returns: cf=0 no errors cf=1 end of string reached DisplayEaxAscii proc near push eax push cx mov cx, 4 or al, al ;End of string? stc ;(assume end of string) jz @f ;YES--assumed correctly call DisplayAlChar ; NO---display character ror eax, 8 ;next char in al @@: loop @b ;repeat clc @@: ;Restore regs pop СХ pop eax ret DisplayEaxAscii endp ``` 20734W-1 – November 2002 # **Appendix A** # **CPUID Instruction Definition** This appendix contains a detailed description of the CPUID instruction. ### **CPUID Instruction** | Mnemonic | Opcode | Description | |----------------------------------------------------------------------------|-----------------------------------------------|--------------------------------------------| | CPUID Privilege: Registers Affected: Flags Affected: Exceptions Generated: | OF A2h<br>none<br>EAX, EBX, E<br>none<br>none | Identify the processor and its feature set | 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. CPUID Instruction 31 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\_000h through 7FFF\_FFFFh. 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 through 8FFF\_FFFFh. 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\_000h function returns a value of at least 8000\_000h 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: | | EF | <b>3X</b> | | | | EI | X | | | EC | $\mathbf{C}\mathbf{X}$ | | <b>◄</b> Registers | |----|----|-----------|--------------|---|----|----|----|----|----|---------|------------------------|----|---------------------------| | h | t | u | $\mathbf{A}$ | | i | t | n | e | D | ${f M}$ | A | c | <b>◄</b> Alpha Characters | | 68 | 74 | 75 | 41 | 6 | 69 | 74 | 6E | 65 | 44 | 4D | 41 | 63 | <b>◄</b> 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 8 on page 34 contains a list of the currently defined standard feature flags for the AMD-K6 processor models 8 and 9. Table 9 on page 35 contains a list of the currently defined standard feature flags for the AMD Athlon family of processors. Table 10 on page 36 contains a list of the currently defined standard feature flags for the AMD Duron family of processors. (See Table 26 through Table 30 in Appendix B, "Register Values Returned by the AMD Family Processors," 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. For more information, see "CPUID Instruction Overview" on page 2. Table 8. Standard Feature Flag Descriptions for AMD-K6®-2 and AMD-K6®-III Processors | Bit | Feature <sup>1</sup> | AMD-K6 <sup>®</sup> -2<br>Processor<br>(Model 8) | AMD-K6 <sup>®</sup> -III<br>Processor<br>(Model 9) | |--------|--------------------------------------------------------------------------|--------------------------------------------------|----------------------------------------------------| | 0 | Floating-Point Unit | 1 | 1 | | 1 | Virtual Mode Extensions | 1 | 1 | | 2 | Debugging Extensions | 1 | 1 | | 3 | Page Size Extensions (4-Mbyte pages) | 1 | 1 | | 4 | Time Stamp Counter (with RDTSC and CR4 disable bit) | 1 | 1 | | 5 | K86 Family of Processors Model-Specific Registers (with RDMSR and WRMSR) | 1 | 1 | | 6 | PAE (Page Address Extensions) | 0 | 0 | | 7 | Machine Check Exception | 1 | 1 | | 8 | CMPXCHG8B Instruction | 1 | 1 | | 9 | APIC | 0 | 0 | | 10 | Reserved on all AMD-K6® processors | 0 | 0 | | 11 | SYSENTER/SYSEXIT <sup>2</sup> | 0 | 0 | | 12 | Memory Type Range Registers | 0 | 0 | | 13 | Global Paging Extension | 1 <sup>3</sup> | 1 | | 14 | Machine Check Architecture | 0 | 0 | | 15 | Conditional Move Instruction | 0 | 0 | | 16 | PAT (Page Attribute Table) | 0 | 0 | | 17 | PSE-36 (Page Size Extensions) | 0 | 0 | | 18-22 | Reserved on all AMD-K6 processors | 0 | 0 | | 23 | MMX <sup>™</sup> Instructions | 1 | 1 | | 24 | FXSAVE/FXRSTOR | 0 | 0 | | 25-31 | Reserved on all AMD-K6 processors | 0 | 0 | | Notes: | | | 1 | - 1. Bit definitions: 0 = No Support, 1 = Support. - 2. The SYSENTER and SYSEXIT instructions have different implementations than the SYSCALL and SYSRET - See Table 29 on page 60 for more information about Global Paging Extensions in the AMD-K6®-2 processor **Table 9. Standard Feature Flag Descriptions for AMD Athlon™ Processors** | D'1 | _ 1 | AMD Athlon™ Processor | | | | | | | |-------|------------------------------------------------------------------------------------|-----------------------|----------------|----------------|----------------|----------------|--|--| | Bit | Feature <sup>1</sup> | Model 1 | Model 2 | Model 4 | Model 6 | Model 8 | | | | 0 | Floating-Point Unit | 1 | 1 | 1 | 1 | 1 | | | | 1 | Virtual Mode Extensions | 1 | 1 | 1 | 1 | 1 | | | | 2 | Debugging Extensions | 1 | 1 | 1 | 1 | 1 | | | | 3 | Page Size Extensions<br>(4-Mbyte pages) | 1 | 1 | 1 | 1 | 1 | | | | 4 | Time Stamp Counter (with RDTSC and CR4 disable bit) | 1 | 1 | 1 | 1 | 1 | | | | 5 | AMD K86 Family of Processors<br>Model-Specific Registers (with<br>RDMSR and WRMSR) | 1 | 1 | 1 | 1 | 1 | | | | 6 | PAE (Page Address Extensions) | 1 | 1 | 1 | 1 | 1 | | | | 7 | Machine Check Exception | 1 | 1 | 1 | 1 | 1 | | | | 8 | CMPXCHG8B Instruction | 1 | 1 | 1 | 1 | 1 | | | | 9 | APIC | 0 | 1 <sup>2</sup> | 1 <sup>2</sup> | 1 <sup>2</sup> | 1 <sup>2</sup> | | | | 10 | Reserved on all AMD processors | 0 | 0 | 0 | 0 | 0 | | | | 11 | SYSENTER/SYSEXIT <sup>3</sup> | 1 | 1 | 1 | 1 | 1 | | | | 12 | MTRR (Memory Type Range<br>Registers) | 1 | 1 | 1 | 1 | 1 | | | | 13 | Global Paging Extension | 1 | 1 | 1 | 1 | 1 | | | | 14 | Machine Check Architecture | 1 | 1 | 1 | 1 | 1 | | | | 15 | Conditional Move Instruction | 1 | 1 | 1 | 1 | 1 | | | | 16 | PAT (Page Attribute Table) | 1 | 1 | 1 | 1 | 1 | | | | 17 | PSE-36 (Page Size Extensions) | 0 | 1 | 1 | 1 | 1 | | | | 18-22 | Reserved on all AMD processors | 0 | 0 | 0 | 0 | 0 | | | | 23 | MMX™ Instructions | 1 | 1 | 1 | 1 | 1 | | | | 24 | FXSAVE/FXRSTOR | 0 | 1 | 1 | 1 | 1 | | | | 25 | SSE Instructions <sup>4</sup> | 0 | 0 | 0 | 1 | 1 | | | | 26-31 | Reserved on all AMD processors | 0 | 0 | 0 | 0 | 0 | | | - 1. Bit definitions: 0 = No Support, 1 = Support. - 2. The AMD processor contains a local APIC. The BIOS must enable the local APIC in order for bit 9 to return a 1 (supported). - 3. The SYSENTER and SYSEXIT instructions have different implementations than the SYSCALL and SYSRET instructions. - 4. SSE instruction support is only present when the processor is set up to support it by the BIOS. See the AMD Athlon™ and AMD Duron™ Processor BIOS, Software, and Debug Developers Guide, order# 21656. **Table 10. Standard Feature Flag Descriptions for AMD Duron™ Processors** | D'i | | AMD Duron™ Processor | | | | | | |-------|-------------------------------------------------------------------------------------|----------------------|----------------|----------------|--|--|--| | Bit | Feature <sup>1</sup> | Model 3 | Model 6 | Model 7 | | | | | 0 | Floating-Point Unit | 1 | 1 | 1 | | | | | 1 | Virtual Mode Extensions | 1 | 1 | 1 | | | | | 2 | Debugging Extensions | 1 | 1 | 1 | | | | | 3 | Page Size Extensions<br>(4-Mbyte pages) | 1 | 1 | 1 | | | | | 4 | Time Stamp Counter (with RDTSC and CR4 disable bit) | 1 | 1 | 1 | | | | | 5 | AMD K86™ Family of Processors<br>Model-Specific Registers (with<br>RDMSR and WRMSR) | 1 | 1 | 1 | | | | | 6 | PAE (Page Address Extensions) | 1 | 1 | 1 | | | | | 7 | Machine Check Exception | 1 | 1 | 1 | | | | | 8 | CMPXCHG8B Instruction | 1 | 1 | 1 | | | | | 9 | APIC | 1 <sup>2</sup> | 1 <sup>2</sup> | 1 <sup>2</sup> | | | | | 10 | Reserved on all AMD processors | 0 | 0 | 0 | | | | | 11 | SYSENTER/SYSEXIT <sup>3</sup> | 1 | 1 | 1 | | | | | 12 | MTRR (Memory Type Range<br>Registers) | 1 | 1 | 1 | | | | | 13 | Global Paging Extension | 1 | 1 | 1 | | | | | 14 | Machine Check Architecture | 1 | 1 | 1 | | | | | 15 | Conditional Move Instruction | 1 | 1 | 1 | | | | | 16 | PAT (Page Attribute Table) | 1 | 1 | 1 | | | | | 17 | PSE-36 (Page Size Extensions) | 1 | 1 | 1 | | | | | 18-22 | Reserved on all AMD processors | 0 | 0 | 0 | | | | | 23 | MMX™ Instructions | 1 | 1 | 1 | | | | | 24 | FXSAVE/FXRSTOR | 1 | 1 | 1 | | | | | 25 | SSE Instructions <sup>4</sup> | 0 | 1 | 1 | | | | | 26-31 | Reserved on all AMD processors | 0 | 0 | 0 | | | | - 1. Bit definitions: 0 = No Support, 1 = Support. - 2. The AMD processor contains a local APIC. The BIOS must enable the local APIC in order for bit 9 to return a 1 (supported). - The SYSENTER and SYSEXIT instructions have different implementations than the SYSCALL and SYSRET instructions. - 4. SSE instruction support is only present when the processor is set up to support it by the BIOS. See the AMD Athlon™ and AMD Duron™ Processor BIOS, Software, and Debug Developers Guide, order# 21656. ### **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, model, and revision (stepping). (The instruction family can be obtained by using function 1.) The information for function 8000\_0001h is formatted as follows: ■ EAX[3–0] Stepping ID ■ EAX[7–4] Model ■ EAX[11–8] Generation ■ 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 11 on page 38 contains a list of the currently defined feature flags for the AMD-K6 processor models 8 and 9. Table 12 on page 39 contains a list of the currently defined feature flags for the AMD Athlon processors. Table 13 on page 41 contains a list of the currently defined feature flags for the AMD Duron processor. (See Tables 26 through 30 in Appendix B, "Register Values Returned by the AMD Family Processors" on page 51 for all K86 family processor register definitions.) Reserved bits will be used for new features as they are added. Table 11. Extended Feature Flag Descriptions for AMD-K6®-2 and AMD-K6®-III Processors | Bit | Feature <sup>1</sup> | AMD-K6 <sup>®</sup> -2<br>Processor<br>(Model 8) | AMD-K6 <sup>®</sup> -III<br>Processor<br>(Model 9) | |--------|---------------------------------------------------------------------------|--------------------------------------------------|----------------------------------------------------| | 0 | Floating-Point Unit | 1 | 1 | | 1 | Virtual Mode Extensions | 1 | 1 | | 2 | Debugging Extensions | 1 | 1 | | 3 | Page Size Extensions (4-Mbyte Pages) | 1 | 1 | | 4 | Time Stamp Counter (with RDTSC and CR4 disable bit) | 1 | 1 | | 5 | K86 Family of Processors' Model-Specific Registers (with RDMSR and WRMSR) | 1 | 1 | | 6 | PAE (Page Address Extensions) | 0 | 0 | | 7 | Machine Check Exception | 1 | 1 | | 8 | CMPXCHG8B Instruction | 1 | 1 | | 9 | APIC | 0 | 0 | | 10 | Reserved on all AMD-K6® processors | 0 | 0 | | 11 | SYSCALL and SYSRET Instructions <sup>2</sup> | 1 | 1 | | 12 | Memory Type Range Registers | 0 | 0 | | 13 | Global Paging Extension | 1 | 1 | | 14 | Machine Check Architecture | 0 | 0 | | 15 | Conditional Move Instruction | 0 | 0 | | 16 | PAT (Page Attribute Table) | 0 | 0 | | 17 | PSE-36 (Page Size Extensions) | 0 | 0 | | 18-21 | Reserved on all AMD-K6 processors | 0 | 0 | | 22 | AMD MMX™ Instruction Extensions | 0 | 0 | | 23 | MMX Instructions | 1 | 1 | | 24 | FXSAVE/FXRSTOR | 0 | 0 | | 25-29 | Reserved on all AMD-K6 processors | 0 | 0 | | 30 | 3DNow!™ Instruction Extensions | 0 | 0 | | 31 | 3DNow! Instructions | 1 | 1 | | Notes: | | | | #### Notes: - 1. Bit definitions: 0 = No Support, 1 = Support. - The SYSENTER and SYSEXIT instructions have different implementations than the SYSCALL and SYSRET instructions. **Table 12. Extended Feature Flag Descriptions for AMD Athlon™ Processors** | Dia. | _ , 1 | AMD Athlon™ Processor | | | | | | | |-------|------------------------------------------------------------------------------------|-----------------------|----------------|----------------|----------------|----------------|--|--| | Bit | Feature <sup>1</sup> | Model 1 | Model 2 | Model 4 | Model 6 | Model 8 | | | | 0 | Floating-Point Unit | 1 | 1 | 1 | 1 | 1 | | | | 1 | Virtual Mode Extensions | 1 | 1 | 1 | 1 | 1 | | | | 2 | Debugging Extensions | 1 | 1 | 1 | 1 | 1 | | | | 3 | Page Size Extensions (4-Mbyte Pages) | 1 | 1 | 1 | 1 | 1 | | | | 4 | Time Stamp Counter (with RDTSC and CR4 disable bit) | 1 | 1 | 1 | 1 | 1 | | | | 5 | AMD K86 Family of Processors<br>Model-Specific Registers (with RDMSR<br>and WRMSR) | 1 | 1 | 1 | 1 | 1 | | | | 6 | PAE (Page Address Extensions) | 1 | 1 | 1 | 1 | 1 | | | | 7 | Machine Check Exception | 1 | 1 | 1 | 1 | 1 | | | | 8 | CMPXCHG8B Instruction | 1 | 1 | 1 | 1 | 1 | | | | 9 | APIC | 0 | 1 <sup>2</sup> | 1 <sup>2</sup> | 1 <sup>2</sup> | 1 <sup>2</sup> | | | | 10 | Reserved on all AMD processors | 0 | 0 | 0 | 0 | 0 | | | | 11 | SYSCALL and SYSRET Instructions <sup>3</sup> | 1 | 1 | 1 | 1 | 1 | | | | 12 | MTRR (Memory Type Range Registers) | 1 | 1 | 1 | 1 | 1 | | | | 13 | Global Paging Extension | 1 | 1 | 1 | 1 | 1 | | | | 14 | Machine Check Architecture | 1 | 1 | 1 | 1 | 1 | | | | 15 | Conditional Move Instruction | 1 | 1 | 1 | 1 | 1 | | | | 16 | PAT (Page Attribute Table) | 1 | 1 | 1 | 1 | 1 | | | | 17 | PSE-36 (Page Size Extensions) | 0 | 1 | 1 | 1 | 1 | | | | 18 | Reserved on all AMD processors | 0 | 0 | 0 | 0 | 0 | | | | 19 | Multiprocessing Capable | 0 | 0 | 0 | 1 <sup>4</sup> | 1 <sup>5</sup> | | | | 20-21 | Reserved on all AMD processors | 0 | 0 | 0 | 0 | 0 | | | | 22 | AMD MMX™ Instruction Extensions | 1 | 1 | 1 | 1 | 1 | | | - 1. Bit definitions: 0 = No Support, 1 = Support. - 2. The AMD processor contains a local APIC. The BIOS must enable the local APIC in order for bit 9 to return a 1 (supported). - 3. The implementation of the SYSCALL and SYSRET instructions is the same on the AMD Athlon™ processors, the AMD Duron™ processors, as well as on the AMD-K6<sup>®</sup> processors models 8 and 9. The SYSENTER and SYSEXIT instructions have different implementations than the SYSCALL and SYSRET instructions. - 4. This value is a "1" on AMD Athlon™ MP model 6 processors with a CPUID value of 662 or greater. Although the value is a "0" for all AMD Athlon MP processors model 6 with a CPUID value of 660 or 661, these processors are also multiprocessing capable. AMD reserves the right to report a "0" or a "1" for all other model 6 processors which are not tested, supported, or intended by AMD to be used for operation in multiprocessing platforms. See the AMD Athlon Processor Model 6 Revision Guide, order# 24332, for the processor revision information corresponding to these model 6 CPUID values. - 5. This value is a "1" for AMD Athlon MP Model 8 processors and is a "0" for all other AMD Athlon Model 8 processors, including the AMD Athlon XP processor and mobile AMD Athlon XP processor. Table 12. Extended Feature Flag Descriptions for AMD Athlon™ Processors (continued) | D:4 | _ 1 | AMD Athlon™ Processor | | | | | | | |-------|--------------------------------|-----------------------|---------|---------|---------|---------|--|--| | Bit | Feature <sup>1</sup> | Model 1 | Model 2 | Model 4 | Model 6 | Model 8 | | | | 23 | MMX Instructions | 1 | 1 | 1 | 1 | 1 | | | | 24 | FXSAVE/FXRSTOR Instructions | 0 | 1 | 1 | 1 | 1 | | | | 25-29 | Reserved on all AMD processors | 0 | 0 | 0 | 0 | 0 | | | | 30 | 3DNow!™ Instruction Extensions | 1 | 1 | 1 | 1 | 1 | | | | 31 | 3DNow! Instructions | 1 | 1 | 1 | 1 | 1 | | | - 1. Bit definitions: 0 = No Support, 1 = Support. - 2. The AMD processor contains a local APIC. The BIOS must enable the local APIC in order for bit 9 to return a 1 (supported). - 3. The implementation of the SYSCALL and SYSRET instructions is the same on the AMD Athlon™ processors, the AMD Duron™ processors, as well as on the AMD-K6<sup>®</sup> processors models 8 and 9. The SYSENTER and SYSEXIT instructions have different implementations than the SYSCALL and SYSRET instructions. - 4. This value is a "1" on AMD Athlon™ MP model 6 processors with a CPUID value of 662 or greater. Although the value is a "0" for all AMD Athlon MP processors model 6 with a CPUID value of 660 or 661, these processors are also multiprocessing capable. AMD reserves the right to report a "0" or a "1" for all other model 6 processors which are not tested, supported, or intended by AMD to be used for operation in multiprocessing platforms. See the AMD Athlon Processor Model 6 Revision Guide, order# 24332, for the processor revision information corresponding to these model 6 CPUID values. - 5. This value is a "1" for AMD Athlon MP Model 8 processors and is a "0" for all other AMD Athlon Model 8 processors, including the AMD Athlon XP processor and mobile AMD Athlon XP processor. Table 13. Extended Feature Flag Descriptions for AMD Duron™ Processors | D.14 | _ 1 | АМІ | AMD Duron™ Processor | | | | |-------|------------------------------------------------------------------------------------|----------------|----------------------|----------------|--|--| | Bit | Feature <sup>1</sup> | Model 3 | Model 6 | Model 7 | | | | 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 | AMD K86 Family of Processors<br>Model-Specific Registers (with RDMSR<br>and WRMSR) | 1 | 1 | 1 | | | | 6 | PAE (Page Address Extensions) | 1 | 1 | 1 | | | | 7 | Machine Check Exception | 1 | 1 | 1 | | | | 8 | CMPXCHG8B Instruction | 1 | 1 | 1 | | | | 9 | APIC | 1 <sup>2</sup> | 1 <sup>2</sup> | 1 <sup>2</sup> | | | | 10 | Reserved on all AMD processors | 0 | 0 | 0 | | | | 11 | SYSCALL and SYSRET Instructions <sup>3</sup> | 1 | 1 | 1 | | | | 12 | MTRR (Memory Type Range Registers) | 1 | 1 | 1 | | | | 13 | Global Paging Extension | 1 | 1 | 1 | | | | 14 | Machine Check Architecture | 1 | 1 | 1 | | | | 15 | Conditional Move Instruction | 1 | 1 | 1 | | | | 16 | PAT (Page Attribute Table) | 1 | 1 | 1 | | | | 17 | PSE-36 (Page Size Extensions) | 1 | 1 | 1 | | | | 18 | Reserved on all AMD processors | 0 | 0 | 0 | | | | 19 | Multiprocessing Capable | 0 | 04 | 04 | | | | 20-21 | Reserved on all AMD processors | 0 | 0 | 0 | | | | 22 | AMD MMX™ Instruction Extensions | 1 | 1 | 1 | | | | 23 | MMX Instructions | 1 | 1 | 1 | | | - 1. Bit definitions: 0 = No Support, 1 = Support. - 2. The AMD processor contains a local APIC. The BIOS must enable the local APIC in order for bit 9 to return a 1 (supported). - 3. The implementation of the SYSCALL and SYSRET instructions is the same on the AMD Athlon™ processors and the AMD Duron™ processors, as well as on the AMD-K6® processors models 8 and 9. The SYSENTER and SYSEXIT instructions have different implementations than the SYSCALL and SYSRET instructions. - 4. AMD reserves the right to report a "0" or a "1" for all AMD Duron model 6 and model 7 processors which are not tested, supported, or intended by AMD to be used for operation in multiprocessing platforms. Table 13. Extended Feature Flag Descriptions for AMD Duron™ Processors (continued) | Di4 | 1 | AMD Duron™ Processor | | | | | |-------|--------------------------------|----------------------|---------|---------|--|--| | Bit | Feature <sup>1</sup> | Model 3 | Model 6 | Model 7 | | | | 24 | FXSAVE/FXRSTOR Instructions | 1 | 1 | 1 | | | | 25-29 | Reserved on all AMD processors | 0 | 0 | 0 | | | | 30 | 3DNow!™ Instruction Extensions | 1 | 1 | 1 | | | | 31 | 3DNow! Instructions | 1 | 1 | 1 | | | - 1. Bit definitions: 0 = No Support, 1 = Support. - 2. The AMD processor contains a local APIC. The BIOS must enable the local APIC in order for bit 9 to return a 1 (supported). - 3. The implementation of the SYSCALL and SYSRET instructions is the same on the AMD Athlon™ processors and the AMD Duron™ processors, as well as on the AMD-K6® processors models 8 and 9. The SYSENTER and SYSEXIT instructions have different implementations than the SYSCALL and SYSRET instructions. - 4. AMD reserves the right to report a "0" or a "1" for all AMD Duron model 6 and model 7 processors which are not tested, supported, or intended by AMD to be used for operation in multiprocessing platforms. # 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 AMD Athlon™ and AMD Duron™ Processors *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 14, 15, 16, and 17 on page 44 provide the format for the information returned by the 8000\_0005h function for the AMD Athlon and the AMD Duron processors. Table 14 describes the format of the information for the L1 2-Mbyte/4-Mbyte large page TLBs. Table 14. EAX Format Returned by Function 8000\_0005h | | Two-Mbyte/4-Mbyte Pages | | | | | | | | |-----|----------------------------|------------------------|----------------------------|------------------------|--|--|--|--| | | Data | TLB | Instruct | ion 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 | | | | | #### Notes: - 1. See "Associativity for L1 Caches and L1 TLBs" on page 48 for more information. - 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. #### Table 15. EBX Format Returned by Function 8000\_0005h | | Four-Kbyte Pages | | | | | | | | |-------|------------------|------------|----------------|-----------|--|--|--|--| | | Data | TLB | Instruct | ion TLB | | | | | | | Associativity* | # Entries | Associativity* | # Entries | | | | | | EBX | Bits 31-24 | Bits 23-16 | Bits 15-8 | Bits 7–0 | | | | | | Noto: | | | <u> </u> | | | | | | #### Table 16. ECX Format Returned by Function 8000 0005h | | L1 Data Cache | | | | | |-------|------------------------------------------------------|------------|-----------|----------|--| | | Size (Kbytes) Associativity* Lines per Tag Line Size | | | | | | ECX | Bits 31-24 | Bits 23-16 | Bits 15-8 | Bits 7–0 | | | Note: | | | | | | #### Table 17. EDX Format Returned by Function 8000\_0005h | | L1 Instruction Cache | | | | | | |-------|-------------------------------------------------------------|------------|-----------|----------|--|--| | | Size (Kbytes) Associativity* Lines per Tag Line Size (by | | | | | | | EDX | Bits 31-24 | Bits 23-16 | Bits 15-8 | Bits 7–0 | | | | Notos | | | | | | | See "Associativity for L1 Caches and L1 TLBs" on page 48 for more information. See "Associativity for L1 Caches and L1 TLBs" on page 48 for more information. See "Associativity for L1 Caches and L1 TLBs" on page 48 for more information. ### Function 8000 0005h-L1 Cache Information for AMD-K5 and All AMD-K6® Processors 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 18, 19, and 20 provide the format for the information returned by the 8000 0005h function for the AMD-K5 and all AMD-K6<sup>®</sup> processors. Table 18. EBX Format Returned by Function 8000 0005h | | Data TLB | | Instruction TLB | | |-------|--------------------------|--|-----------------|-----------| | | Associativity* # Entries | | Associativity* | # Entries | | EBX | Bits 31–24 Bits 23–16 | | Bits 15-8 | Bits 7–0 | | Note: | | | • | | #### **Table 19. ECX Format Returned by Function 8000 0005h** | | L1 Data Cache | | | | | | | | |-----------------|--------------------------------|--------------------------------------------------------------|-----------|----------|--|--|--|--| | | Size (Kbytes) | Size (Kbytes) Associativity* Lines per Tag Line Size (bytes) | | | | | | | | ECX | Bits 31-24 | Bits 23-16 | Bits 15-8 | Bits 7–0 | | | | | | Note: | | | | | | | | | | * See "Associat | tivity for L1 Caches and L1 TL | Bs" on page 48 for more info | ormation. | | | | | | #### Table 20. EDX Format Returned by Function 8000 0005h | | L1 Instruction Cache | | | | | |-------|--------------------------------------------------------|------------|-----------|----------|--| | | Size (Kbytes) Associativity* Lines per Tag Line Size ( | | | | | | EDX | Bits 31-24 | Bits 23-16 | Bits 15-8 | Bits 7–0 | | | Note: | | | • | | | See "Associativity for L1 Caches and L1 TLBs" on page 48 for more information. See "Associativity for L1 Caches and L1 TLBs" on page 48 for more information. # Function 8000\_0006h−L2 TLB/L2 Cache Information for AMD Athlon™ and AMD Duron™ Processors **Note:** The L2 cache for the AMD Athlon processor model 1 and model 2 must be configured prior to invoking this function. *Input:* EAX = 8000 0006h *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 21, 22, and 23 provide the format for the information returned by the 8000\_0006h function on AMD Athlon and AMD Duron processors. Table 21. EAX Format Returned by Function 8000 0006h | | Two-Mbyte/4-Mbyte Pages | | | | | |-----|--------------------------------------------------------|------------|----------------------------|-----------------------|--| | | L2 Data TLB <sup>2</sup> L2 Instruction or Unified TLB | | | uction 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 48 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. #### Table 22. EBX Format Returned by Function 8000\_0006h | | Four-Kbyte Pages | | | | | | | |-----|--------------------------------------------------------|--------------------------------------------|----------------------------|-----------|--|--|--| | | L2 Data TLB <sup>2</sup> L2 Instruction or Unified TLB | | | | | | | | | Associativity <sup>1</sup> # Entries | | Associativity <sup>1</sup> | # Entries | | | | | EBX | Bits 31-28 | Bits 31–28 Bits 27–16 Bits 15–12 Bits 11–0 | | | | | | #### Notes: - 1. See "Associativity for L2 Caches and L2 TLBs" on page 48 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. Table 23. ECX Format Returned by Function 8000\_0006h | | L2 Cache | | | | |-------|---------------|-------------------|-----------|----------| | | Size (Kbytes) | Line Size (bytes) | | | | ECX | Bits 31-16 | Bits 15-12 | Bits 11-8 | Bits 7-0 | | Note: | | | | | <sup>\*</sup> See "Associativity for L2 Caches and L2 TLBs" on page 48 for more information. # Function 8000\_0006h—L2 Cache Information for the AMD-K6 $^{\rm @}\text{-}\mathrm{III}$ Processor *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 24 provides the format for the information returned by the 8000\_0006h function. Table 24. ECX Format Returned by Function 8000\_0006h for the AMD-K6®-III Processor | | L2 Cache | | | | | | |-------|-----------------------------------------------------------------|--|--|--|--|--| | | Size (Kbytes) Associativity* Lines per Tag Line Size (bytes) | | | | | | | ECX | Bits 31–16 Bits 15–12 Bits 11–8 Bits 7–0 | | | | | | | Noto: | | | | | | | #### Note: <sup>\*</sup> See "Associativity for L2 Caches and L2 TLBs" on page 48 for more information. # **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 eight 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 two-way associativity and a returned value of 04h indicates four-way associativity. #### Associativity for L2 Caches and L2 TLBs The associativity fields for the L2 cache, L2 data TLB, and L2 instruction TLB are four bits wide. Table 25 shows the values returned in these associativity fields. Table 25. Associativity Values For L2 Caches and TLBs | 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 | ### **Function 8000 0007h – Advanced Power Management Feature Flags** *Input:* $EAX = 8000\_0007h$ *Output:* EAX = Reserved EBX = Reserved ECX = Reserved EDX = Advanced Power Management Feature Flags Function 8000\_0007h returns the supported advanced power management features of the processor. - EDX[2] If set, device supports Voltage ID (VID) control. - EDX[1] If set, device supports Frequency ID (FID) control. - EDX[0] If set, device has a temperature sensing diode. For more details, see the *BIOS Requirements for AMD PowerNow!*<sup>TM</sup> *Technology for Mobile*, order# 25264, and the *BIOS Requirements for AMD PowerNow!*<sup>TM</sup> *Technology Low-Power Desktop*, order# 25541. ## Function 8000\_0008h — Physical Address and Linear Address Size *Input:* $EAX = 8000\_0008h$ Output: EAX = Physical Address and Linear Address Size EBX = Reserved ECX = Reserved EDX = Reserved - EAX[15:8] Maximum linear address. - EAX[7:0] Maximum physical address. 20734W-1 – November 2002 # **Appendix B** # **Register Values Returned by the AMD Family Processors** Tables 26–30, on pages 52–62, contain all the values returned for AMD processors by the CPUID instruction. # AMD Athlon™ Processor and AMD Duron™ Processor Values Table 26. Values Returned by AMD Athlon™ and AMD Duron™ Processors Models 6, 7, and 8 | Function<br>Register | | Processor<br>(Model 6) <sup>1</sup> | Processor<br>(Model 7) <sup>1</sup> | Processor<br>(Model 8) <sup>1</sup> | |----------------------|----|-------------------------------------|-------------------------------------|-------------------------------------| | Function: 0 | | (model o) | ( | (initial) | | | | 0000 00016 | 0000 00016 | 0000 00016 | | _ | AX | 0000_0001h | 0000_0001h | 0000_0001h | | _ | ВХ | 6874_7541h | 6874_7541h | 6874_7541h | | | CX | 444D_4163h | 444D_4163h | 444D_4163h | | | DX | 6974_6E65h | 6974_6E65h | 6974_6E65h | | Function: 1 | | | | | | E | AX | 0000_066Xh | 0000_067Xh | 0000_068Xh | | E | ВХ | Reserved | Reserved | Reserved | | E | СХ | Reserved | Reserved | Reserved | | E | DX | 0183_F9FFh <sup>2</sup> | 0183_F9FFh <sup>2</sup> | 0183_F9FFh <sup>2</sup> | | Function: | | | | | | 8000_0000h | | | | | | E | AX | 8000_0008h | 8000_0008h | 8000_0008h | | E | ВХ | Reserved | Reserved | Reserved | | E | CX | Reserved | Reserved | Reserved | | E | DX | Reserved | Reserved | Reserved | | Function: | | | | | | 8000_0001h | | | | | | E | AX | 0000_076Xh | 0000_077Xh | 0000_078Xh | | E | ВХ | Reserved | Reserved | Reserved | | E | СХ | Reserved | Reserved | Reserved | | E | DX | C1C3_F9FFh <sup>3</sup> | C1C3_F9FFh <sup>3</sup> | C1C3_F9FFh <sup>3</sup> | - 1. The returned values for the AMD Athlon™ and AMD Duron™ processors models 6 and 7 are for all non-mobile processors, including the AMD Athlon XP, AMD Athlon MP, AMD Duron processors. - 2. The AMD processors models 6 and 7 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be 0183\_FBFFh. - 3. The AMD processors models 6 and 7 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be C1C3\_FBFFh. This value also varies based on the setting of the MP bit 19. See Table 12 on page 39 and Table 13 on page 41 for details. - 4. The L2 cache size and associativity on AMD processors are product specific. AMD Athlon processor models 6 and greater have an L2 cache size of 256-Kbyte with 16-way set associativity. AMD Duron processor models 6 and greater have an L2 cache size of 64-Kbyte with 16-way set associativity. Table 26. Values Returned by AMD Athlon™ and AMD Duron™ Processors Models 6, 7, and 8 (continued) | Function<br>Register | | Processor | Processor | Processor | |----------------------|--------|------------------------|------------------------|------------------------| | | gister | (Model 6) <sup>1</sup> | (Model 7) <sup>1</sup> | (Model 8) <sup>1</sup> | | Function: | | | | | | 8000_0002h | | | | | | | EAX | 2044 4D41h | 2044 4D41h | 2044 4D41h | | | EBX | 6C68 7441h | 6F72 7544h | 6C68 7441h | | | ECX | 7428 6E6Fh | 6D74 286Eh | 7428 6E6Fh | | | EDX | 5020_296Dh | 7250_2029h | 5020_296Dh | | Function: | | | | | | 8000_0003h | | | | | | | EAX | 6563 6F72h | 7365 636Fh | 6563 6F72h | | | EBX | 726F_7373h | 0072_6F73h | 726F_7373h | | | ECX | 0000_0000h | 0000_0000h | 0000_0000h | | | EDX | 0000_0000h | 0000_0000h | 0000_0000h | | Function: | | | | | | 8000_0004h | | | | | | | EAX | 0000_0000h | 0000 0000h | 0000 0000h | | | EBX | 0000_0000h | 0000_0000h | 0000_0000h | | | ECX | 0000_0000h | 0000_0000h | 0000_0000h | | | EDX | 0000_0000h | 0000_0000h | 0000_0000h | | Function: | | | | | | 8000_0005h | | | | | | | EAX | 0408_FF08h | 0408_FF08h | 0408_FF08h | | | EBX | FF20_FF10h | FF20_FF10h | FF20_FF10h | | | ECX | 4002_0140h | 4002_0140h | 4002_0140h | | | EDX | 4002_0140h | 4002_0140h | 4002_0140h | - 1. The returned values for the AMD Athlon™ and AMD Duron™ processors models 6 and 7 are for all non-mobile processors, including the AMD Athlon XP, AMD Athlon MP, AMD Duron processors. - 2. The AMD processors models 6 and 7 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be 0183\_FBFFh. - 3. The AMD processors models 6 and 7 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be C1C3\_FBFFh. This value also varies based on the setting of the MP bit 19. See Table 12 on page 39 and Table 13 on page 41 for details. - 4. The L2 cache size and associativity on AMD processors are product specific. AMD Athlon processor models 6 and greater have an L2 cache size of 256-Kbyte with 16-way set associativity. AMD Duron processor models 6 and greater have an L2 cache size of 64-Kbyte with 16-way set associativity. Table 26. Values Returned by AMD Athlon™ and AMD Duron™ Processors Models 6, 7, and 8 (continued) | Function R | egister | Processor<br>(Model 6) <sup>1</sup> | Processor<br>(Model 7) <sup>1</sup> | Processor<br>(Model 8) <sup>1</sup> | |-------------------------|--------------------------|-----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------| | Function: | | | | | | 8000_0006l | ı | | | | | | EAX<br>EBX | 0000_0000h<br>4100_4100h<br>**** *140h <sup>4</sup> | 0000_0000h<br>4100_4100h<br>**** *140h <sup>4</sup> | 0000_0000h<br>4100_4100h<br>**** *140h <sup>4</sup> | | | ECX<br>EDX | Reserved | Reserved | Reserved | | Function:<br>8000_0007h | 1 | | | | | | EAX<br>EBX<br>ECX<br>EDX | Reserved<br>Reserved<br>Reserved<br>****_***1h | Reserved<br>Reserved<br>Reserved<br>****_***1h | Reserved<br>Reserved<br>Reserved<br>****_***1h | | Function:<br>8000_0008h | 1 | | | | | | EAX<br>EBX<br>ECX<br>EDX | 0000_2022h<br>Reserved<br>Reserved<br>Reserved | 0000_2022h<br>Reserved<br>Reserved<br>Reserved | 0000_2022h<br>Reserved<br>Reserved<br>Reserved | - 1. The returned values for the AMD Athlon™ and AMD Duron™ processors models 6 and 7 are for all non-mobile processors, including the AMD Athlon XP, AMD Athlon MP, AMD Duron processors. - 2. The AMD processors models 6 and 7 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be 0183\_FBFFh. - 3. The AMD processors models 6 and 7 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be C1C3\_FBFFh. This value also varies based on the setting of the MP bit 19. See Table 12 on page 39 and Table 13 on page 41 for details. - 4. The L2 cache size and associativity on AMD processors are product specific. AMD Athlon processor models 6 and greater have an L2 cache size of 256-Kbyte with 16-way set associativity. AMD Duron processor models 6 and greater have an L2 cache size of 64-Kbyte with 16-way set associativity. Table 27. Values Returned by Mobile AMD Athlon™ Processors Models 6, 7, and 8, and Mobile AMD Duron™ Processors Models 3, 6, and 7 | Function<br>Reg | ister | Mobile AMD Duron™<br>Processor (Model 3) <sup>1</sup> | Mobile Processor<br>(Model 6) <sup>1</sup> | Mobile Processor<br>(Model 7) <sup>1</sup> | Mobile Processor<br>(Model 8) <sup>1</sup> | |-------------------------|-------|-------------------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------| | Function: 0 | | | | | | | | EAX | 0000 0001h | 0000 0001h | 0000 0001h | 0000 0001h | | | EBX | 6874_7541h | 6874_7541h | 6874_7541h | 6874_7541h | | | ECX | 444D_4163h | 444D_4163h | 444D_4163h | 444D_4163h | | | EDX | 6974_6E65h | 6974_6E65h | 6974_6E65h | 6974_6E65h | | Function: 1 | | | | | | | | EAX | 0000_063Xh | 0000_066Xh | 0000_067Xh | 0000_066Xh | | | EBX | Reserved | Reserved | Reserved | Reserved | | | ECX | Reserved | Reserved | Reserved | Reserved | | | EDX | 0183_F9FFh <sup>2</sup> | 0183_F9FFh <sup>2</sup> | 0183_F9FFh <sup>2</sup> | 0183_F9FFh <sup>2</sup> | | Function:<br>8000_0000h | | | | | | | | EAX | 8000 0006h | 8000 0008h | 8000 0008h | 8000_0008h | | | EBX | Reserved | Reserved | Reserved | Reserved | | | ECX | Reserved | Reserved | Reserved | Reserved | | | EDX | Reserved | Reserved | Reserved | Reserved | | Function:<br>8000_0001h | | | | | | | | EAX | 0000 073Xh | 0000_076Xh | 0000 077Xh | 0000_076Xh | | | EBX | Reserved | Reserved | Reserved | Reserved | | | ECX | Reserved _ | Reserved _ | Reserved _ | Reserved | | | EDX | C1C3_F9FFh <sup>3</sup> | C1C3_F9FFh <sup>3</sup> | C1C3_F9FFh <sup>3</sup> | C1C3_F9FFh <sup>3</sup> | | Function: | | | | | | | 8000_0002h | | | | | | | | EAX | 2044_4D41h | 2044_4D41h | 2044_4D41h | 2044 4D41h | | | EBX | 6F72_7544h | 6C68_7441h | 6F72_7544h | 6C68_7441h | | | ECX | 6D74_286Eh | 7428_6E6Fh | 6D74_286Eh | 7428_6E6Fh | | | EDX | 7250_2029h | 5020_296Dh | 7250_2029h | 5020_296Dh | - 1. The returned values for mobile AMD Athlon™ processors models 6, 7, and 8 and AMD Duron™ processors models 3, 6, and 7 are for the mobile AMD Athlon™ 4, mobile AMD Athlon XP, and mobile AMD Duron™ processors. - 2. The AMD processors models 6, 7, and 8 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be 0183\_FBFFh. - 3. The AMD processors models 6, 7, and 8 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be C1C3\_FBFFh. This value also varies based on the setting of the MP bit 19. See Tables 7 and 8 for details. - 4. The L2 cache size and associativity on AMD processors are product specific. AMD Athlon processor models 6 and greater have an L2 cache size of 256-Kbyte with 16-way set associativity. AMD Duron processor models 6 and greater have an L2 cache size of 64-Kbyte with 16-way set associativity. The Mobile AMD Duron processor model 3 has an L2 cache size of 64-Kbyte with 16-way set associativity. Table 27. Values Returned by Mobile AMD Athlon™ Processors Models 6, 7, and 8, and Mobile AMD Duron™ Processors Models 3, 6, and 7 (continued) | Function<br>R | Register | Mobile AMD Duron™<br>Processor (Model 3)¹ | Mobile Processor<br>(Model 6) <sup>1</sup> | Mobile Processor<br>(Model 7) <sup>1</sup> | Mobile Processor<br>(Model 8) <sup>1</sup> | |---------------|----------|-------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------| | Function: | | | | | | | 8000_0003 | h | | | | | | | EAX | 7365_636Fh | 6563_6F72h | 7365_636Fh | 6563_6F72h | | | EBX | 0072 6F73h | 726F 7373h | 0072 6F73h | 726F_7373h | | | ECX | 0000 0000h | 0000 0000h | 0000 0000h | 0000 0000h | | | EDX | 0000_0000h | 0000_0000h | 0000_0000h | 0000_0000h | | Function: | | | | | | | 8000_0004 | h | | | | | | | EAX | 0000_0000h | 0000_0000h | 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_0005 | ih | | | | | | | EAX | 0408_FF08h | 0408_FF08h | 0408_FF08h | 0408_FF08h | | | EBX | FF18_FF10h | FF20_FF10h | FF20_FF10h | FF20_FF10h | | | ECX | 4002_0140h | 4002_0140h | 4002_0140h | 4002_0140h | | | EDX | 4002_0140h | 4002_0140h | 4002_0140h | 4002_0140h | | Function: | | | | | | | 8000_0006 | 5h | | | | | | | EAX | 0000_0000h | 0000_0000h | 0000_0000h | 0000_0000h | | | EBX | 4100_4100h | 4100_4100h | 4100_4100h | 4100_4100h | | | ECX | ****_*140h <sup>4</sup> | ****_*140h <sup>4</sup> | ****_*140h <sup>4</sup> | ****_*140h <sup>4</sup> | | | EDX | Reserved | Reserved | Reserved | Reserved | | Motor | | | | ! | | - 1. The returned values for mobile AMD Athlon™ processors models 6, 7, and 8 and AMD Duron™ processors models 3, 6, and 7 are for the mobile AMD Athlon™ 4, mobile AMD Athlon XP, and mobile AMD Duron™ processors. - 2. The AMD processors models 6, 7, and 8 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be 0183\_FBFFh. - 3. The AMD processors models 6, 7, and 8 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be C1C3 FBFFh. This value also varies based on the setting of the MP bit 19. See Tables 7 and 8 for details. - 4. The L2 cache size and associativity on AMD processors are product specific. AMD Athlon processor models 6 and greater have an L2 cache size of 256-Kbyte with 16-way set associativity. AMD Duron processor models 6 and greater have an L2 cache size of 64-Kbyte with 16-way set associativity. The Mobile AMD Duron processor model 3 has an L2 cache size of 64-Kbyte with 16-way set associativity. Table 27. Values Returned by Mobile AMD Athlon™ Processors Models 6, 7, and 8, and Mobile AMD Duron™ Processors Models 3, 6, and 7 (continued) | Function<br>I | Register | Mobile AMD Duron™<br>Processor (Model 3)¹ | Mobile Processor<br>(Model 6) <sup>1</sup> | Mobile Processor<br>(Model 7) <sup>1</sup> | Mobile Processor<br>(Model 8) <sup>1</sup> | |------------------------|--------------------------|-------------------------------------------|------------------------------------------------|------------------------------------------------|------------------------------------------------| | Function:<br>8000_0007 | 7h | | | | | | | EAX<br>EBX<br>ECX<br>EDX | Not Supported | Reserved<br>Reserved<br>Reserved<br>****_***7h | Reserved<br>Reserved<br>Reserved<br>****_***7h | Reserved<br>Reserved<br>Reserved<br>****_***7h | | Function:<br>8000_0008 | EAX<br>EBX<br>ECX<br>EDX | Not Supported | 0000_2022h<br>Reserved<br>Reserved<br>Reserved | 0000_2022h<br>Reserved<br>Reserved<br>Reserved | 0000_2022h<br>Reserved<br>Reserved<br>Reserved | - 1. The returned values for mobile AMD Athlon™ processors models 6, 7, and 8 and AMD Duron™ processors models 3, 6, and 7 are for the mobile AMD Athlon™ 4, mobile AMD Athlon XP, and mobile AMD Duron™ processors. - 2. The AMD processors models 6, 7, and 8 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be 0183 FBFFh. - 3. The AMD processors models 6, 7, and 8 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be C1C3 FBFFh. This value also varies based on the setting of the MP bit 19. See Tables 7 and 8 for details. - 4. The L2 cache size and associativity on AMD processors are product specific. AMD Athlon processor models 6 and greater have an L2 cache size of 256-Kbyte with 16-way set associativity. AMD Duron processor models 6 and greater have an L2 cache size of 64-Kbyte with 16-way set associativity. The Mobile AMD Duron processor model 3 has an L2 cache size of 64-Kbyte with 16-way set associativity. Table 28. Values Returned by AMD Athlon™ Processors Models 1, 2, and 4, and AMD Duron™ Processors Model 3 | Function<br>Register | AMD Athlon™ Processor<br>(Model 1) | | | AMD Duron™ Processor<br>(Model 3) | |--------------------------|------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------| | Function: 0 | | | | | | EAX<br>EBX | 0000_0001h | | 0000_0001h<br>6874_7541h | 0000_0001h<br>6874 7541h | | ECX | 444D 4163h | 444D 4163h | 444D 4163h | 444D 4163h | | EDX | 6974_6E65h | 6974_6E65h | 6974_6E65h | 6974_6E65h | | Function: 1 | | | | | | EAX<br>EBX<br>ECX<br>EDX | 0000_061Xh<br>Reserved<br>Reserved<br>0081_F9FFh | 0000_062Xh<br>Reserved<br>Reserved<br>0183_F9FFh <sup>1</sup> | 0000_064Xh<br>Reserved<br>Reserved<br>0183_F9FFh <sup>1</sup> | 0000_063Xh<br>Reserved<br>Reserved<br>0183_F9FFh <sup>1</sup> | | Function:<br>8000_0000h | | | | | | EAX<br>EBX<br>ECX<br>EDX | 8000_0006h<br>Reserved<br>Reserved<br>Reserved | 8000_0006h<br>Reserved<br>Reserved<br>Reserved | 8000_0006h<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 | 0000_071Xh<br>Reserved<br>Reserved<br>C0C1_F9FFh | 0000_072Xh<br>Reserved<br>Reserved<br>C1C3_F9FFh <sup>2</sup> | 0000_074Xh<br>Reserved<br>Reserved<br>C1C3_F9FFh <sup>2</sup> | 0000_073Xh<br>Reserved<br>Reserved<br>C1C3_F9FFh <sup>2</sup> | | Function:<br>8000_0002h | | | | | | EAX<br>EBX<br>ECX<br>EDX | 2D44_4D41h<br>7428_374Bh<br>5020_296Dh<br>6563_6F72h | 2044_4D41h<br>6C68_7441h<br>7428_6E6Fh<br>5020_296Dh | 2044_4D41h<br>6C68_7441h<br>7428_6E6Fh<br>5020_296Dh | 2044_4D41h<br>6F72_7544h<br>6D74_286Eh<br>7250_2029h | <sup>1.</sup> The AMD Duron™ processor and AMD Athlon™ processor models 2 and 4 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be 0183\_FBFFh. <sup>2.</sup> The AMD Duron processor and AMD Athlon processor models 2 and 4 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be C1C3\_FBFFh. <sup>3.</sup> The L2 cache size and associativity on AMD processors are product specific. The AMD Athlon processor models 1 and 2 have an L2 cache size of 512-Kbyte with two-way set associativity. The AMD Athlon processor model 4 has an L2 cache size of 256-Kbyte with 16-way set associativity. The AMD Duron processor has an L2 cache size of 64-Kbyte with 16-way set associativity. Table 28. Values Returned by AMD Athlon™ Processors Models 1, 2, and 4, and AMD Duron™ Processors Model 3 (continued) | Function<br>Register | AMD Athlon™ Processor<br>(Model 1) | AMD Athlon Processor<br>(Model 2) | AMD Athlon Processor<br>(Model 4) | AMD Duron™ Processor<br>(Model 3) | |----------------------|------------------------------------|-----------------------------------|-----------------------------------|-----------------------------------| | Function: | | | | | | 8000_0003h | | | | | | EAX | 726F_7373h | 6563_6F72h | 6563_6F72h | 7365_636Fh | | EBX | 0000_0000h | 726F_7373h | 726F_7373h | 0072_6F73h | | ECX | 0000 0000h | 0000 0000h | 0000 0000h | 0000_0000h | | EDX | 0000_0000h | 0000_0000h | 0000_0000h | 0000_0000h | | Function: | | | | | | 8000_0004h | | | | | | EAX | 0000_0000h | 0000_0000h | 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 | 0408_FF08h | 0408_FF08h | 0408_FF08h | 0408_FF08h | | EBX | FF18_FF10h | FF18_FF10h | FF18_FF10h | FF18_FF10h | | ECX | 4002_0140h | 4002_0140h | 4002_0140h | 4002_0140h | | EDX | 4002_0140h | 4002_0140h | 4002_0140h | 4002_0140h | | Function: | | | | | | 8000_0006h | | | | | | EAX | 0000_0000h | 0000_0000h | 0000_0000h | 0000_0000h | | EBX | 4100_4100h | 4100_4100h | 4100_4100h | 4100_4100h | | ECX | ****_*140h <sup>3</sup> | ****_*140h <sup>3</sup> | ****_*140h <sup>3</sup> | ****_*140h <sup>3</sup> | | EDX | Reserved | Reserved | Reserved | Reserved | <sup>1.</sup> The AMD Duron™ processor and AMD Athlon™ processor models 2 and 4 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be 0183\_FBFFh. <sup>2.</sup> The AMD Duron processor and AMD Athlon processor models 2 and 4 contain an APIC, but it is not reflected in this value. If the BIOS enables the APIC, the value would be C1C3\_FBFFh. <sup>3.</sup> The L2 cache size and associativity on AMD processors are product specific. The AMD Athlon processor models 1 and 2 have an L2 cache size of 512-Kbyte with two-way set associativity. The AMD Athlon processor model 4 has an L2 cache size of 256-Kbyte with 16-way set associativity. The AMD Duron processor has an L2 cache size of 64-Kbyte with 16-way set associativity. # **AMD-K6<sup>®</sup> Processor Values** Table 29. Values Returned by AMD-K6® Processors | 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 | 0000_0001h | 0000_0001h | 0000_0001h | 0000_0001h | | | | EBX | 6874_7541h | 6874_7541h | 6874_7541h | 6874_7541h | | | | ECX | 444D_4163h | 444D_4163h | 444D_4163h | 444D_4163h | | | | EDX | 6974_6E65h | 6974_6E65h | 6974_6E65h | 6974_6E65h | | | Function: 1 | | | | | | | | | EAX | 0000_056Xh | 0000_057Xh | 0000_058Xh | 0000_059Xh | | | | EBX | Reserved | Reserved | Reserved | Reserved | | | | ECX | Reserved | Reserved | Reserved | Reserved | | | | EDX | 0080_01BFh | 0080_01BFh | 0080_21BFh <sup>1</sup> | 0080_21BFh | | | Function: | | | | | | | | 8000_0000h | | | | | | | | | EAX | 8000_0005h | 8000_0005h | 8000_0005h | 8000_0006h | | | | EBX | Reserved | Reserved | Reserved | Reserved | | | | ECX | Reserved | Reserved | Reserved | Reserved | | | | EDX | Reserved | Reserved | Reserved | Reserved | | | Function: | | | | | | | | 8000_0001h | | | | | | | | | EAX | 0000_066Xh | 0000_067Xh | 0000_068Xh | 0000_069Xh | | | | EBX | Reserved | Reserved | Reserved | Reserved | | | | ECX | Reserved | Reserved | Reserved | Reserved | | | | EDX | 0080_05BFh | 0080_05BFh | 8080_29BFh <sup>2</sup> | 8080_29BFh | | #### 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. 60 AMD-K6<sup>®</sup> Processor Values Table 29. Values Returned by AMD-K6® Processors (continued) | 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_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 | | Function: | | | | | | | 8000_0006h | | | | | | | | EAX | Undefined | Undefined | Undefined | Reserved | | | EBX | Undefined | Undefined | Undefined | Reserved | | | ECX | Undefined | Undefined | Undefined | 0100_4220h | | | EDX | Undefined | Undefined | Undefined | Reserved | - 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. # $Am486^{\mathbb{R}}$ , $Am5_{x}86^{\mathbb{R}}$ , and AMD-K5 Processor Values Table 30. Values Returned by $\rm Am486^{\it B}$ , $\rm Am5_{\it X}86^{\it B}$ , and $\rm AMD\text{-}K5$ Processors | 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_0001h<br>6874_7541h<br>444D_4163h<br>6974_6E65h | | 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: | | | | | | | 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 | <sup>\*</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. Table 30. Values Returned by Am486<sup>®</sup>, Am5<sub>x</sub>86<sup>®</sup>, and AMD-K5 Processors (continued) | 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:<br>8000_0003h | | | | | | | EAX<br>EBX<br>ECX<br>EDX | 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 | | Function:<br>8000_0004h | | | | | | | EAX<br>EBX<br>ECX<br>EDX | Undefined<br>Undefined<br>Undefined<br>Undefined | Undefined<br>Undefined<br>Undefined<br>Undefined | 0000_0000h<br>0000_0000h<br>0000_0000h<br>0000_0000h | 0000_0000h<br>0000_0000h<br>0000_0000h<br>0000_0000h | 0000_0000h<br>0000_0000h<br>0000_0000h<br>0000_0000h | | Function:<br>8000_0005h | | | | | | | EAX<br>EBX<br>ECX<br>EDX | Undefined<br>Undefined<br>Undefined<br>Undefined | Undefined<br>Undefined<br>Undefined<br>Undefined | Reserved<br>0480_0000h<br>0804_0120h<br>1004_0120h | Reserved<br>0480_0000h<br>0804_0120h<br>1004_0120h | Reserved<br>0480_0000h<br>0804_0120h<br>1004_0120h | <sup>\*</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.