# **BIOS** and Kernel **Developer's Guide** (BKDG) For AMD Family 10h **Processors**

# © 2005–2007 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, 3DNow!, and combinations thereof are trademarks of Advanced Micro Devices, Inc.

MMX is a trademark of Intel Corporation.

Microsoft is a registered trademark of Mircosoft Corporation.

HyperTransport is a licenced trademark of the HyperTransport Technology Consortium.

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

# **Table of Contents**

| 1   | Overview                                                                 | 12 |  |  |  |
|-----|--------------------------------------------------------------------------|----|--|--|--|
| 1.1 | Intended Audience                                                        |    |  |  |  |
| 1.2 | Reference Documents                                                      |    |  |  |  |
| 1.3 |                                                                          |    |  |  |  |
|     | 1.3.1 Numbering                                                          |    |  |  |  |
|     | 1.3.2 Arithmetic And Logical Operators                                   | 13 |  |  |  |
| 1.4 | Definitions                                                              | 13 |  |  |  |
| 1.5 | Changes Between Revisions and Product Variations                         | 18 |  |  |  |
|     | 1.5.1 Major Changes For Revision A Relative to Family 0Fh Processors     |    |  |  |  |
|     | 1.5.2 Supported Feature Variations                                       | 20 |  |  |  |
| 2   | Functional Description                                                   | 21 |  |  |  |
| 2.1 |                                                                          |    |  |  |  |
| 2.2 |                                                                          |    |  |  |  |
| 2.3 | ·                                                                        |    |  |  |  |
|     | 2.3.1 BSP initialization                                                 | 22 |  |  |  |
|     | 2.3.2 AP initialization                                                  | 23 |  |  |  |
|     | 2.3.3 Cache Initialization For General Storage During Boot               |    |  |  |  |
|     | 2.3.3.1 Generalized Usage Requirements                                   |    |  |  |  |
|     | 2.3.4 Multiprocessing Capability Detection                               |    |  |  |  |
|     | 2.3.5 BIOS Requirements For 64-Bit Operation                             | 24 |  |  |  |
| 2.4 | Power Management                                                         | 25 |  |  |  |
|     | 2.4.1 Processor Power Planes And Voltage Control                         | 25 |  |  |  |
|     | 2.4.1.1 VID Pins And Interface Selection                                 | 26 |  |  |  |
|     | 2.4.1.2 Internal VID Registers                                           |    |  |  |  |
|     | 2.4.1.3 MinVid and MaxVid Check                                          | 27 |  |  |  |
|     | 2.4.1.4 PSI_L                                                            |    |  |  |  |
|     | 2.4.1.5 Alternative Voltage (Altvid)                                     |    |  |  |  |
|     | 2.4.1.6 VID Encodings                                                    |    |  |  |  |
|     | 2.4.1.6.1 Boot VID Encodings                                             |    |  |  |  |
|     | 2.4.1.6.2 Parallel VID Interface (PVI) Encodings                         |    |  |  |  |
|     | 2.4.1.6.3 Serial VID (SVI) Encodings                                     |    |  |  |  |
|     | 2.4.1.7 BIOS Requirements for Power Plane Initialization                 |    |  |  |  |
|     | 2.4.1.8 Hardware-Initiated Voltage Transitions                           |    |  |  |  |
|     | 2.4.1.9 Software-Initiated Voltage Transitions                           |    |  |  |  |
|     | 2.4.1.9.1 Software-Initiated NB Voltage Transitions                      |    |  |  |  |
|     | 2.4.1.9.2 Software-Initiated CPU Voltage Transitions                     |    |  |  |  |
|     | 2.4.1.10 SVI Protocol                                                    |    |  |  |  |
|     | 2.4.2 P-states                                                           |    |  |  |  |
|     | 2.4.2.1 Core P-states                                                    |    |  |  |  |
|     | 2.4.2.1.1 Core P-state Control                                           |    |  |  |  |
|     | 2.4.2.2 P-state Limits                                                   |    |  |  |  |
|     | 2.4.2.3 P-state Bandwidth Requirements                                   |    |  |  |  |
|     | 2.4.2.4 P-state Transition Behavior                                      |    |  |  |  |
|     | 2.4.2.5 BIOS Requirements for P-State Initialization and Transitions     |    |  |  |  |
|     | 2.4.2.6 BIOS Northbridge COF and VID Configuration                       |    |  |  |  |
|     | 2.4.2.6.1 BIOS NB COF and VID Configuration for Single-Plane PVI Systems | 35 |  |  |  |

|     |       | 2.4.2.6.2   | BIOS NB COF and VID Configuration for Dual-Plane PVI Systems  | 36 |
|-----|-------|-------------|---------------------------------------------------------------|----|
|     | 2.4   | 1.2.7 Proce | essor-Systemboard Power Delivery Compatibility Check          | 36 |
|     | 2.4   | 1.2.8 Mixe  | ed-Frequency and Power P-State Configuration                  | 38 |
|     |       | 2.4.2.8.1   | Mixed Power P-State Configuration Sequence                    | 38 |
|     |       | 2.4.2.8.2   | Mixed Frequency and Power P-State Configuration Rules         | 38 |
|     |       | 2.4.2.8.3   | Mixed Frequency and Power P-State Configuration Sequence      |    |
|     | 2.4   | 1.2.9 ACP   | I Processor P-State Objects                                   |    |
|     |       | 2.4.2.9.1   | _PCT (Performance Control)                                    |    |
|     |       | 2.4.2.9.2   | _PSS (Performance Supported States)                           |    |
|     |       | 2.4.2.9.3   | _PPC (Performance Present Capabilities)                       |    |
|     |       | 2.4.2.9.4   | _PSD (P-State Dependency)                                     |    |
|     |       | 2.4.2.9.5   | Fixed ACPI Description Table (FADT) Entries                   | 45 |
|     | 2.4   | 1.2.10 XPS  | S (Microsoft® Extended PSS) Object                            |    |
|     |       |             | S COF and VID Requirements After Warm Reset                   |    |
|     |       | 2.4.2.11.1  | CPU Core Maximum P-State Transition Sequence After Warm Reset |    |
|     |       | 2.4.2.11.2  | •                                                             |    |
|     |       | 2.4.2.11.3  | •                                                             |    |
|     | 2.4.3 | C-states    |                                                               |    |
|     | 2.4   |             | Enhanced State (C1E)                                          |    |
|     |       | 2.4.3.1.1   | SMI Initiated C1E                                             |    |
|     |       | 2.4.3.1.2   | BIOS Requirements to Initialize SMI Initiated C1E             |    |
|     |       | 2.4.3.1     | •                                                             |    |
|     | 2.4.4 |             | pend to RAM State (S3)                                        |    |
| 2.5 | Proc  |             | Fransition Sequences                                          |    |
|     | 2.5.1 |             | er State Transitions                                          |    |
| 2.6 | The   |             | (NB)                                                          |    |
|     | 2.6.1 | -           | e (NB) Architecture                                           |    |
|     | 2.6.2 |             | , , , , , , , , , , , , , , , , , , ,                         |    |
|     | 2.6.3 |             | usion Vectors (DEV)                                           |    |
|     | 2.6.4 |             | e Routing                                                     |    |
|     |       |             | ress Space Routing                                            |    |
|     |       | 2.6.4.1.1   | •                                                             |    |
|     |       | 2.6.4.1.2   | IO Space                                                      |    |
|     |       | 2.6.4.1.3   | Configuration Space                                           |    |
|     | 2.6   |             | erTransport <sup>TM</sup> Technology Routing                  |    |
|     |       | 2.6.4.2.1   | Routing Table Configuration                                   |    |
|     |       | 2.6.4.2.2   | BIOS Requirements for Systems with Mixed Processor Families   |    |
|     |       | 2.6.4.2.3   | Link Traffic Distribution                                     |    |
|     |       | 2.6.4.2.4   | F0x[5C:40]Display Refresh And IFCM                            |    |
|     | 2.6.5 |             | 3 Cache (L3)                                                  |    |
|     | 2.6.6 |             | crubbers                                                      |    |
|     | 2.6.7 | •           | ddress Space                                                  |    |
|     | 2.6.8 |             | ldress Map                                                    |    |
| 2.7 |       | •           |                                                               |    |
|     | 2.7.1 |             | lization                                                      |    |
|     |       |             | ging And Unganging                                            |    |
|     |       |             | ging Detection And Control                                    |    |
|     |       |             | Type Detect                                                   |    |
|     |       |             | l Topologies                                                  |    |
|     |       |             | on and Compensation.                                          |    |
|     |       |             |                                                               |    |

|     | 2.7.3 | Equalization                                                                 | 57    |
|-----|-------|------------------------------------------------------------------------------|-------|
|     | 2.7.4 | Link Bandwidth Requirements                                                  | 58    |
|     | 2.7.5 | Link Retry                                                                   | 58    |
|     | 2.7.6 | Link LDTSTOP_L Disconnect-Reconnect                                          |       |
|     | 2.7.7 | LDTSTOP Requirements.                                                        | 58    |
|     | 2.7.8 | Response Ordering                                                            |       |
|     | 2.7.9 | Link Testing, BIST, and ILM                                                  |       |
|     |       |                                                                              |       |
| 2.8 |       | AM Controllers (DCTs)                                                        |       |
|     | 2.8.1 | DCT Configuration Registers                                                  |       |
|     | 2.8.2 | Support For Multiple Unbuffered Logical DIMMs                                |       |
|     | 2.8.3 | Burst Length                                                                 |       |
|     | 2.8.4 | Ganged or Unganged Mode Considerations                                       |       |
|     | 2.8.5 | Routing DRAM Requests                                                        |       |
|     | 2.8.6 | DRAM Data Burst Mapping                                                      |       |
|     | 2.8.7 | DCT/DRAM Initialization.                                                     |       |
|     |       | 3.7.1 Phy and Controller Mode Configuration                                  |       |
|     |       | 8.7.2 Phy compensation initialization                                        |       |
|     |       | 3.7.3 SPD ROM-Based Configuration                                            |       |
|     |       | 8.7.4 Non-SPD ROM-Based Configuration                                        |       |
|     | 2.0   | 2.8.7.4.1 Trdrd (Read to Read Timing)                                        |       |
|     |       | 2.8.7.4.2 Twrwr (Write to Write Timing)                                      |       |
|     |       | 2.8.7.4.3 Twrrd (Write to Read DIMM Termination Turn-around)                 |       |
|     |       | 2.8.7.4.4 TrwtTO (Read-to-Write Turnaround for Data, DQS Contention)         |       |
|     |       | 2.8.7.4.5 TrwtWB (Read-to-Write Turnaround for Opportunistic Write Bursting) |       |
|     |       | 2.8.7.4.6 FourActWindow (Four Bank Activate Window or tFAW)                  |       |
|     |       | 2.8.7.4.7 DRAM ODT Control                                                   |       |
|     |       | 2.8.7.4.7 DRAM ODT Control                                                   |       |
|     | 2.8   | 3.7.5 DRAM Device Initialization                                             |       |
|     | 2.0   | 2.8.7.5.1 Software DDR2 Device Initialization                                |       |
|     |       | 2.8.7.5.1 Software DDR2 Device Initialization                                |       |
|     |       | 2.8.7.5.2.1 Software Control Word Initialization                             |       |
|     | 2 8   | 3.7.6 Phy Fence programming                                                  |       |
|     |       | B.7.7 DRAM Channel Frequency Change                                          |       |
|     |       | 3.7.8 DRAM Training                                                          |       |
|     | 2.0   | 2.8.7.8.1 DDR3 Training                                                      |       |
|     |       | 2.8.7.8.1.1 Phy Assisted Write Levelization                                  |       |
|     |       | 2.8.7.8.1.2 BIOS Based Write Levelization Training                           |       |
|     |       | 2.8.7.8.2 DDR2 DRAM Training                                                 |       |
|     |       | 2.8.7.8.2.1 Phy Assisted DQS Receiver Enable Training                        |       |
|     |       | 2.8.7.8.2.2 BIOS Based DQS Receiver Enable Training                          |       |
|     |       | 2.8.7.8.2.3 DQS Position Training                                            |       |
|     |       | · · · · · · · · · · · · · · · · · · ·                                        |       |
|     |       | $\mathcal{E}$                                                                |       |
|     |       | 2.8.7.8.4 Calculating MaxRdLatency                                           |       |
|     |       | 2.8.7.8.4.1 MaxRdLatency Training                                            |       |
|     | 200   | 2.8.7.8.5 Continuous Pattern Generation                                      |       |
|     | 2.8.8 | Memory Interleaving Modes                                                    |       |
|     |       | 8.8.1 Chip Select Interleaving                                               |       |
|     |       | 8.8.2 Node Interleaving                                                      |       |
|     | 4.0.7 | 1VIGHIOLY 11018HH2                                                           | . 104 |

| 2.8.9.1         | DramHoleOffset Programming                                  | 105 |
|-----------------|-------------------------------------------------------------|-----|
| 2.8.9.2         | DctSelBaseOffset Programming                                |     |
|                 |                                                             |     |
|                 | ine Spare                                                   |     |
|                 | On-Line Spare and CS Interleaving                           |     |
|                 | 1.4.11                                                      |     |
|                 | al Address Space                                            |     |
|                 | Cores and Downcoring                                        |     |
|                 | ss Type Determination                                       |     |
| 2.9.3.1         | Memory Access to the Physical Address Space                 |     |
| 2.9.3           | $\mathcal{E}$                                               |     |
|                 | .1.2 Determining The Access Destination for CPU Accesses    |     |
|                 | rs                                                          |     |
| 2.9.5 APIC      | 7                                                           |     |
| 2.9.5.1         | ApicId Enumeration Requirements                             | 109 |
| 2.10 Thermal Fu | nctions                                                     | 110 |
| 2.10.1 The      | Ictl Temperature Scale.                                     | 110 |
| 2.10.2 Then     | mal Diode                                                   | 110 |
| 2.10.3 Temp     | perature-Driven Logic                                       | 110 |
|                 | PROCHOT_L and Hardware Thermal Control (HTC)                |     |
| 2.10.3.2        |                                                             |     |
| 2.10.3.3        | THERMTRIP                                                   |     |
|                 | ion Space                                                   |     |
|                 | O Configuration Coding Requirements.                        |     |
|                 | O Configuration Ordering                                    |     |
|                 | essor Configuration Space                                   |     |
|                 | port                                                        |     |
| 0 1             | uilt In Self Test (BIST)                                    |     |
|                 | dvanced Server Features                                     |     |
|                 | nine Check Architecture                                     |     |
|                 | Machine Check Registers                                     |     |
|                 | Machine Check Errors                                        |     |
| 2.13.1.2        |                                                             |     |
| · - ·           | 1.2.2 Machine Check Error Logging Overwrite During Overflow |     |
|                 | Handling Machine Check Exceptions                           |     |
|                 | Error Thresholding                                          |     |
|                 | M Considerations for ECC                                    |     |
|                 |                                                             |     |
|                 | Unganged Interleaving                                       |     |
|                 | ECC Syndromes                                               |     |
|                 | pand Interface (SBI)                                        |     |
| 2.13.3.1        |                                                             |     |
| •               |                                                             |     |
|                 | 1 APIC                                                      |     |
|                 | Physical Destination Mode                                   |     |
| 2.14.1.2        | Logical Destination Mode                                    |     |
| 2.14.1.3        | Interrupt Delivery                                          |     |
|                 | Vectored Interrupt Handling                                 |     |
|                 | Interrupt Masking                                           |     |
| 2.14.1.6        | Spurious Interrupts                                         |     |
| 2.14.           |                                                             |     |
| 2.14.1.7        | Lowest-Priority Interrupt Arbitration                       | 123 |

|   | 2.14.1.8       | Inter-Processor Interrupts                                      | . 124 |
|---|----------------|-----------------------------------------------------------------|-------|
|   | 2.14.1.9       | APIC Timer Operation                                            | . 124 |
|   | 2.14.1.10      | Generalized Local Vector Table                                  | . 124 |
|   | 2.14.1.11      | State at Reset                                                  | . 124 |
|   | 2.14.2 Syste   | em Management Mode (SMM)                                        | 124   |
|   | 2.14.2.1       | SMM Overview                                                    | . 124 |
|   | 2.14.2.2       | Operating Mode and Default Register Values                      | . 125 |
|   | 2.14.2.3       | SMI Sources And Delivery                                        | . 125 |
|   | 2.14.2.4       | SMM Initial State                                               | . 126 |
|   | 2.14.2.5       | SMM Save State                                                  |       |
|   | 2.14.2.6       | Exceptions and Interrupts in SMM                                | . 132 |
|   | 2.14.2.7       | The Protected ASeg and TSeg Areas                               |       |
|   | 2.14.2.8       | SMM Special Cycles                                              |       |
|   |                | Locking SMM                                                     |       |
| 2 |                | tual Machine Mode (SVM)                                         |       |
|   |                | S support for SVM Disable                                       |       |
| 2 |                | truction                                                        |       |
|   |                | i-Core Support                                                  |       |
|   |                | ache Support                                                    |       |
| 2 |                | ee Monitoring                                                   |       |
|   |                | rmance Monitor Counters                                         |       |
|   | 2.17.2 Instru  | action Based Sampling (IBS)                                     | 133   |
| 3 | Registers      |                                                                 | 135   |
|   |                | escriptions and Mnemonics                                       |       |
|   | -              | abridge MSRs In Multi-Core Products                             |       |
| 3 |                | egisters                                                        |       |
| 3 |                | HyperTransport <sup>TM</sup> Technology Configuration Registers |       |
| 3 |                | Address Map Registers                                           |       |
| 3 |                | DRAM Controller Registers                                       |       |
| 3 |                | Miscellaneous Control Registers                                 |       |
| 3 | .7 Function 4  | Link Control Registers                                          | 255   |
| 3 | .8 APIC Regis  | sters                                                           | 273   |
| 3 | .9 CPUID Inst  | truction Registers                                              | 283   |
| 3 | .10 MSRs - MS  | SR0000_xxxx                                                     | 291   |
| 3 | .11 MSRs - MS  | SRC000_0xxx                                                     | 309   |
| 3 | .12 MSRs - MS  | SRC001_0xxx                                                     | 311   |
| 3 | .13 MSRs - MS  | SRC001_1xxx                                                     | 331   |
| 3 | .14 Performanc | ee Counter Events                                               | 337   |
|   | 3.14.1 Float   | ing Point Events                                                | 337   |
|   | 3.14.2 Load    | /Store and TLB Events                                           | 338   |
|   | 3.14.3 Data    | Cache Events                                                    | 340   |
|   | 3.14.4 L2 C    | ache and System Interface Events                                | 343   |
|   | 3.14.5 Instru  | action Cache Events                                             | 345   |
|   | 3.14.6 Exect   | ution Unit Events                                               | 347   |
|   | 3.14.7 Mem     | ory Controller Events                                           | 350   |
|   |                | sbar Events                                                     | 355   |
|   |                | Events                                                          | 359   |
|   | 3.14.10 L3 C   | ache Events                                                     | 359   |
| 4 | Register List  |                                                                 | 361   |
| - | Trobustri Tipe |                                                                 | ~ 01  |

# **List of Figures**

| Figure 1:  | A processor                                                     | 21  |
|------------|-----------------------------------------------------------------|-----|
| Figure 2:  | System diagram                                                  |     |
| Figure 3:  | Sample four-node configuration                                  | 53  |
| Figure 4:  | Link DC termination mode.                                       | 57  |
| Figure 5:  | Link AC termination mode.                                       | 57  |
| Figure 6:  | DDR3 Registered DIMM (non-planar)                               | 97  |
| Figure 7:  | DDR3 Registered DIMM (planar)                                   | 97  |
| Figure 8:  | Example cases for programming DramHoleOffset                    | 105 |
| Figure 9:  | Example cases for programming DctSelBaseOffset                  | 106 |
| Figure 10: | Example of line interleaving from x4 DRAM in unganged DRAM mode | 119 |
| Figure 11: | Address/Command Timing at the Processor Pins                    | 189 |
| Figure 12: | Link phy recovered clock and sample clock                       | 259 |

# **List of Tables**

| Table 1:  | Supported features                                                                                       | 20  |
|-----------|----------------------------------------------------------------------------------------------------------|-----|
| Table 2:  | Power management support                                                                                 | 25  |
| Table 3:  | Boot VID codes                                                                                           | 28  |
| Table 4:  | PVI VID codes                                                                                            | 28  |
| Table 5:  | SVI and internal VID codes                                                                               | 29  |
| Table 6:  | Representative mixed frequency P-state table example (step 2)                                            | 39  |
| Table 7:  | Representative mixed frequency P-state table example (step 3)                                            | 40  |
| Table 8:  | Representative mixed frequency P-state table example (step 4)                                            | 40  |
| Table 9:  | Representative mixed frequency P-state table example (step 6)                                            | 41  |
| Table 10: | Representative mixed frequency P-state table example (step 7)                                            | 42  |
| Table 11: | Representative mixed frequency P-state table example (final)                                             | 43  |
| Table 12: | Representative mixed frequency _PSS object example                                                       | 43  |
| Table 13: | Link disconnect controls                                                                                 | 58  |
| Table 14: | Supported link operational modes                                                                         | 60  |
| Table 15: | DDR2 Unbuffered and Registered DIMM Support (per channel)                                                | 61  |
| Table 16: | DDR2 and DDR3 Trdrd settings                                                                             | 68  |
| Table 17: | DDR2 and DDR3 Twrwr settings                                                                             | 68  |
| Table 18: | DDR2 Twrrd settings                                                                                      | 69  |
| Table 19: | DDR3 Twrrd settings                                                                                      | 69  |
| Table 20: | DDR2 TrwtTO settings                                                                                     | 71  |
| Table 21: | DDR3 TrwtTO settings                                                                                     | 71  |
| Table 22: | DDR2 Four Bank Activate Window Values                                                                    | 72  |
| Table 23: | Processor and DDR2 DIMM ODT Settings                                                                     | 72  |
| Table 24: | Processor and DDR3 DIMM ODT Settings                                                                     | 73  |
| Table 25: | Processor and QR-DDR3 DIMM ODT Settings                                                                  | 73  |
| Table 26: | DDR2 Unbuffered DIMM Address Timings and Drive Strengths for the AM2r2 Package                           | 74  |
| Table 27: | DDR2 Registered DIMM Address Timings and Drive Strengths for Fr2(1207) Package (4 DIMMs per channel)     | 76  |
| Table 28: | DDR2 Registered DIMM Address Timings and Drive Strengths for the Fr2(1207) Package (2 DIMMs per channel) | 76  |
| Table 29: | DDR3 Unbuffered DIMM Address Timings and Drive Strengths                                                 | 77  |
| Table 30. | DDR3 RDIMM Register Control Word Values                                                                  | 84  |
| Table 31: | DIMM to timing register mapping <sup>2</sup> for revision B                                              | 95  |
| Table 32. | DDR2 swapped normalized address lines for interleaving for a 64-bit interface                            | 101 |
| Table 33. | DDR2 swapped normalized address lines for CS interleaving for a 128-bit interface                        | 102 |
| Table 34. | DDR3 swapped normalized address lines for interleaving for a 64-bit interface                            | 102 |
| Table 35. | DDR3 swapped normalized address lines for CS interleaving for a 128-bit interface                        | 102 |
| Table 36: | MCA register cross-reference table                                                                       | 114 |
| Table 37: | MC0 and MC4 Overwrite Priorities                                                                         | 116 |
| Table 38: | MC1, MC2, and MC3 Overwrite Priorities                                                                   | 116 |
| Table 39: | ECC correctable syndromes                                                                                | 120 |
|           |                                                                                                          |     |

| Table 40: | SMM initial state                                              | 126 |
|-----------|----------------------------------------------------------------|-----|
| Table 41: | SMM Save State                                                 | 126 |
| Table 42: | Terminology in register descriptions                           | 135 |
| Table 43: | DIMM support per package                                       | 167 |
| Table 44: | Logical DIMM, Chip Select, CKE, ODT, and Register Mapping      | 167 |
| Table 45: | DDR2 DRAM address mapping                                      | 171 |
| Table 46: | DDR3 DRAM address mapping                                      | 172 |
| Table 47: | Error codes: transaction type                                  | 212 |
| Table 48: | Error codes: cache level                                       | 212 |
| Table 49: | Error codes: memory transaction type                           | 212 |
| Table 50: | Error codes: participation processor                           | 212 |
| Table 51: | Error codes: memory or IO                                      | 212 |
| Table 52: | NB error descriptions                                          | 213 |
| Table 53: | NB error signatures, part 1                                    | 214 |
| Table 54: | NB error signatures, part 2                                    | 216 |
| Table 55: | Default MCA NB Address Register default encoding               | 219 |
| Table 56: | MCA NB Address Low Register encoding for Link Protocol Errors  | 219 |
| Table 57: | MCA NB Address Low Register encoding for L3 Protocol Errors    | 220 |
| Table 58: | MCA NB Address Low Register encoding for NB Array Errors       | 221 |
| Table 59: | MCA NB Address Register encoding for L3 Array Errors           | 222 |
| Table 60: | MCA NB Address Low Register encoding for Watchdog Timer Errors | 222 |
| Table 61: | ACPI Power State Control Register SMAF Settings                | 231 |
| Table 63: | DC error descriptions                                          | 300 |
| Table 64: | DC error signatures                                            | 300 |
| Table 65: | DC error data; address register                                | 301 |
| Table 66: | IC error descriptions                                          | 302 |
| Table 67: | IC error signatures                                            | 303 |
| Table 68: | IC error data; address register                                | 303 |
| Table 69: | BU error descriptions                                          | 304 |
| Table 70: | BU error signatures                                            | 305 |
| Table 71: | BU error data; address register                                | 306 |
| Table 72: | LS error signatures                                            | 306 |
| Table 73: | FR error signatures                                            | 308 |

# **Revision History**

# **Revision 3.00**

• Initial public release.

#### 1 Overview

The AMD family 10h processor (in this document referred to as *the processor*) is a processing unit that supports x86-based instruction sets. The processor includes (a) up to four independent central processing unit cores (referred to as *CPU cores*), (b) up to four high-speed communication interfaces (referred to as *links*) that may be configured for HyperTransport<sup>TM</sup> technology (referred to as *IO links*) or for AMD-proprietary interprocessor communication (referred to as *coherent links*), and (c) up to two double-data rate 2 (DDR2) or 3 (DDR3) system memory DRAM interfaces.

AMD family 10h processors are distinguished by the combined ExtFamily and BaseFamily fields of the CPUID instruction (see CPUID Fn[8000\_0001, 0000\_0001]\_EAX in section 3.9 [CPUID Instruction Registers] on page 283).

#### 1.1 Intended Audience

This document provides the processor behavioral definition and associated design notes. It is intended for platform designers and for programmers involved in the development of low-level BIOS (basic input/output system) functions, drivers, and operating system kernel modules. It assumes prior experience in personal computer platform design, microprocessor programming, and legacy x86 and AMD64 microprocessor architecture. The reader should also have familiarity with various platform technologies, such as DDR DRAM.

#### 1.2 Reference Documents

- Advanced Configuration and Power Interface (ACPI) Specification. www.acpi.info.
- AMD64 Architecture Programmer's Manual Volume 1: Application Programming, #24592.
- AMD64 Architecture Programmer's Manual Volume 2: System Programming, #24593.
- AMD64 Architecture Programmer's Manual Volume 3: Instruction-Set Reference, #24594.
- AMD64 Architecture Programmer's Manual Volume 4: 128-Bit Media Instructions, #26568.
- AMD64 Architecture Programmer's Manual Volume 5: 64-Bit Media and x87 Floating-Point Instructions, #26569.
- CPUID Specification, #25481.
- AMD Socket F (1207) Processor Functional Data Sheet, #31118.
- AMD Socket Fr2 (1207) Processor Functional Data Sheet, #41698.
- AMD Socket AM2 Processor Functional Data Sheet, #31117.
- AMD Socket AM2r2 Processor Functional Data Sheet, #41697.
- AMD Socket AM3 Processor Functional Data Sheet, #40778.
- AMD Family 10h Processor Electrical Data Sheet, #40014.
- Revision Guide for AMD Family 10h Processors, #41322
- AMD Voltage Regulator Specification, #40182.
- HyperTransport<sup>TM</sup> I/O Link Specification. www.hypertransport.org.
- PCI local bus specification. www.pcisig.org.
- System Management Bus (SMBus) specification. www.smbus.org.
- SBI Temperature Sensor Interface (SB-TSI) Specification, #40821.

#### 1.3 Conventions

# 1.3.1 Numbering

- Binary numbers. Binary numbers are indicated by appending a "b" at the end, e.g., 0110b.
- **Decimal numbers**. Unless specified otherwise, all numbers are decimal. Note: this rule does not apply to the register mnemonics described in section 3.1 [Register Descriptions and Mnemonics] on page 135; register mnemonics all utilize hexadecimal numbering.
- Hexadecimal numbers. hexadecimal numbers are indicated by appending an "h" to the end, e.g., 45f8h.
- **Underscores in numbers**. Underscores are used to break up numbers to make them more readable. They do not imply any operation. E.g., 0110\_1100b.

# 1.3.2 Arithmetic And Logical Operators

In this document, formulas follow some Verilog conventions for logic equations.

- {} Curly brackets are used to indicate a group of bits that are concatenated together. Each set of bits is separated by a comma. E.g., {Addr[3:2], Xlate[3:0]} represents a 6-bit value; the two MSBs are Addr[3:2] and the four LSBs are Xlate[3:0].
- Logical OR operator.
- & Logical AND operator.
- ^ Logical exclusive-OR operator; sometimes used as "raised to the power of" as well, as indicated by the context in which it is used.
- ~ Logical NOT operator.
- == Logical "is equal to" operator.
- != Logical "is not equal to" operator.
- <= Less than or equal operator.
- >= Greater than or equal operator.
- \* Arithmetic multiplied-by operator.

The order in which logical operators are applied is: ~ first, & second, and | last.

For example, the equation:

```
Output [3:0] = \{A[1:0], B[3:2]\} \& C[3:0] \mid \sim D[3:0] \& E[9:6], is translated as:

Output [3] = (A[1] \& C[3]) \mid (\sim D[3] \& E[9]);

Output [2] = (A[0] \& C[2]) \mid (\sim D[2] \& E[8]);

Output [1] = (B[3] \& C[1]) \mid (\sim D[1] \& E[7]);

Output [0] = (B[2] \& C[0]) \mid (\sim D[0] \& E[6]);
```

#### 1.4 Definitions

- **AC coupled**. Refers to the method used for link termination. See section 2.7.2 [Termination and Compensation] on page 56.
- **Altvid**. Alternate voltage ID. Refers to a lower VID code that may be applied to power planes during C3 or C1E. See F3x[84:80] [ACPI Power State Control Registers] on page 231.
- AP. Application processor. See section 2.3 [Processor Initialization] on page 22.
- APML. Advanced Platform Management Link. See section 2.13.3 [Sideband Interface (SBI)] on page 121.
- BCS. Base configuration space. See section 2.11 [Configuration Space] on page 112.

- **BERT**. Bit error rate tester. A piece of test equipment that generates arbitrary test patterns and checks that a device under test returns them without errors.
- **BIST**. Built-in self-test. Hardware within the processor that generates test patterns and verifies that they are stored correctly (in the case of memories) or received without error (in the case of links).
- **Boot VID**. Boot voltage ID. This is the VDD and VDDNB voltage level that the processor requests from the external voltage regulator during the initial phase of the cold boot sequence.
- **BSP**. Boot strap processor. See section 2.3 [Processor Initialization] on page 22.
- C0, C1, C2, and C3. These are ACPI-defined CPU core power states. C0 is operational. C1 is when the core is in halt. C2 and C3 are stop-grant states. See section 2.4 [Power Management] on page 25.
- C1E. C1 enhanced state. Power-savings mode that is employed when all CPU cores of a CMP processor are in the halt state. See [The Interrupt Pending and CMP-Halt Register] MSRC001\_0055.
- Channel. See DRAM channel.
- Channel interleaved mode. Mode in which DRAM address space is interleaved between DRAM channels. See section 2.8.8 [Memory Interleaving Modes] on page 100.
- CMP. Chip multi-processing. Refers to processors that include multiple CPU cores. See section 2.1 [Processor Overview] on page 21.
- Coherent fabric. The coherent fabric includes the DRAM controllers and caches of the system. Normally, this refers to the nodes, system memory, and coherent links used for communication between the nodes. See section 2.2 [System Overview] on page 21.
- Coherent link or coh link. A link configured for coherent inter-processor traffic between nodes.
- **COF**. Current operating frequency of a given clock domain. See section 2.4.2 [P-states] on page 31.
- **Cold reset**. PWROK is deasserted and RESET\_L is asserted. See section 2.3 [Processor Initialization] on page 22.
- Canonical address. An address in which the state of the most-significant implemented bit is duplicated in all the remaining higher-order bits, up to bit 63.
- Chipkill ECC. An error correcting code which can recover from DRAM device failures. See section 2.13.2 [DRAM Considerations for ECC] on page 118.
- **CPU or CPU core**. The instruction execution unit(s) of the processor. See section 2.1 [Processor Overview] on page 21.
- **CpuCoreNum**. Specifies the CPU core number. See section 2.9.2 [CPU Cores and Downcoring] on page 107.
- **CPUID function X**. Refers to the CPUID instruction when EAX is preloaded with X. See section 3.9 [CPUID Instruction Registers] on page 283.
- CS. Chip select. See F2x[1, 0][5C:40] [DRAM CS Base Address Registers] on page 166.
- **DC coupled**. Refers to the method used for link termination. See section 2.7.2 [Termination and Compensation] on page 56.
- DCT. DRAM controller. See section 2.8 [DRAM Controllers (DCTs)] on page 60.
- **DEV**. DMA exclusion vector. See section 2.6.3 [DMA Exclusion Vectors (DEV)] on page 51.
- **DID**. Divisor identifier. Specifies the post-PLL divisor used to reduce the COF. See section 2.4.2 [P-states] on page 31.
- **Display refresh**. Traffic used for display refresh in UMA systems. See section 2.6.4.2.4 [F0x[5C:40]Display Refresh And IFCM] on page 54.
- **Doubleword**. A 32-bit value.
- **Downcoring**. Removal of CPU cores. See section 2.9.2 [CPU Cores and Downcoring] on page 107.
- DRAM channel. The part of the DRAM interface that connects to a 64-bit DIMM. For example, a processor

with a 128-bit DRAM interface is said to support two DRAM channels. See section 2.8 [DRAM Controllers (DCTs)] on page 60.

- **DS**. Downstream. Refers to the direction of data on a link.
- **Dual-Plane**. Refers to a processor or systemboard where VDD and VDDNB are separate and may operate at independent voltage levels. Refer to 2.4.1 [Processor Power Planes And Voltage Control] on page 25.
- **DW or DWORD**. Doubleword. A 32-bit value.
- ECS. Extended configuration space. See section 2.11 [Configuration Space] on page 112.
- EDS. Electrical data sheet. See section 1.2 [Reference Documents] on page 12.
- **FDS**. Functional data sheet; there is one FDS for each package type. See section 1.2 [Reference Documents] on page 12.
- **FID**. Frequency identifier. Specifies the PLL frequency multiplier for a given clock domain. See section 2.4.2 [P-states] on page 31.
- Ganged. A link, memory channel, or voltage regulator in which all portions are controlled as one.
- **GB or Gbyte**. Gigabyte; 1,073,741,824 bytes.
- **Gen1**. Refers to older revisions of the link specification and, in particular, link data rates from 0.4 to 2.0 GT/s. See section 2.7 [Links] on page 55.
- **Gen3**. Refers to revision 3.00 of the link specification and, in particular, link data rates from 2.4 to 5.2 GT/s. See section 2.7 [Links] on page 55.
- #GP. A general-protection exception.
- #GP(0). Notation indicating a general-protection exception (#GP) with error code of 0.
- **GT/s**. Giga-transfers per second.
- HTC. Hardware thermal control. See section 2.10.3.1 [PROCHOT\_L and Hardware Thermal Control (HTC)] on page 111.
- HTC-active state. Hardware-controlled lower-power, lower-performance state used to reduce temperature. See section 2.10.3.1 [PROCHOT\_L and Hardware Thermal Control (HTC)] on page 111.
- I2C. Protocol on which the SVI interface timing is based. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25, and section 1.2 [Reference Documents] on page 12.
- **IBS**. Instruction based sampling. See section 2.16.2 [L3 Cache Support] on page 133.
- **IFCM**. Isochronous flow-control mode, as defined in the *HyperTransport*™ *I/O Link Specification*. See section 2.6.4.2.4 [F0x[5C:40]Display Refresh And IFCM] on page 54.
- ILM. Internal loopback mode. Mode in which the link receive lanes are connected directly to the transmit lanes of the same link for testing and characterization. See [The Link Extended Control Registers] F0x[18C:170].
- **IO configuration**. Access to configuration space through IO ports CF8h and CFCh. See section 2.11 [Configuration Space] on page 112.
- **IO Hub**. This is the platform device that contains the bridge to the system BIOS.
- IO link. A link configured for non-coherent traffic, per the HyperTransport<sup>TM</sup> I/O Link Specification.
- IORRs. IO range registers. See [The IO Range Registers Base (IORR\_BASE[1:0])] MSRC001\_00[18, 16].
- **Isoc**. Isochronous. Isochronous is defined by the link specification.
- **KB** or **Kbyte**. Kilobyte; 1024 bytes.
- L1 caches. The level 1 caches of the CPU core including the instruction cache and the data cache.
- L2 cache. The level 2 cache of each CPU core.
- L3 cache. The level 3 cache that is shared by each of the CPU cores.
- Link. Generic term that may refer to an IO link or a coherent link.

- LINT. Local interrupt.
- Logical DIMM. Either one 64-bit DIMM or two identical DIMMs in parallel to create a 128-bit interface. See section 2.8 [DRAM Controllers (DCTs)] on page 60.
- LVT. Local vector table. A collection of APIC registers that define interrupts for local events. E.g., [The Extended Interrupt [3:0] Local Vector Table Registers] APIC[530:500].
- Master abort. This is a PCI-defined term that is applied to transactions on other than PCI busses. It indicates that the transaction is terminated without affecting the intended target; reads return all 1's; writes are discarded; the master abort error code is returned in the response, if applicable; master abort error bits are set if applicable.
- MB or Mbyte. Megabyte; 1024 Kbytes.
- MCT. Memory controller. See section 2.6.1 [Northbridge (NB) Architecture] on page 50.
- MCQ. Memory controller queue. See section 2.6.1 [Northbridge (NB) Architecture] on page 50.
- **MEMCLK**. Refers to the clock signals, M[B, A][3:0]\_CLK, that are driven from the processor to DDR DIMMs.
- MMIO. Memory-mapped input-output range. This is physical address space that is mapped to the IO functions such as the IO links or MMIO configuration. The IO link MMIO ranges are specified by [The Memory Mapped IO Base/Limit Registers] F1x[BC:80].
- **MMIO configuration**. Access to configuration space through memory space. See section 2.11 [Configuration Space] on page 112.
- MOF. Maximum operating frequency of the CPU core(s). Normally this is the CPU core COF in P-state 0. See section 2.4.2 [P-states] on page 31.
- MSR. Model specific register. The CPU includes several MSRs for general configuration and control. See section 3.10 [MSRs MSR0000\_xxxx] on page 291 for the beginning of the MSR register definitions.
- MTRR. Memory-type range register. The MTRRs specify the type of memory associated with various memory ranges. See MSR0000\_00FE, MSR0000\_02[0F:00], MSR0000\_02[6F:68, 59, 58, 50], and MSR0000\_02FF.
- **NB**. Northbridge. The transaction routing block of the node. See section 2.1 [Processor Overview] on page 21.
- NCLK. The main Northbridge clock. The NCLK frequency is the NB COF.
- Node ID. The identifier assigned to each node, [The Node ID Register] F0x60[NodeId].
- Node. See section 2.1 [Processor Overview] on page 21.
- **Normalized address**. Addresses used by DCTs. See section 2.6.1 [Northbridge (NB) Architecture] on page 50.
- Octword. A 128-bit value.
- **ODM**. On-DIMM mirroring. See F2x[1, 0][5C:40][OnDimmMirror].
- **ODT**. On-die termination, which is applied DRAM interface signals.
- **ODTS**. DRAM On-die thermal sensor.
- Operational frequency. The frequency at which the processor operates. See section 2.4 [Power Management] on page 25.
- **PDS**. Product data sheet. See section 1.2 [Reference Documents] on page 12.
- PRBS. Pseudo-random bit sequence.
- **Processor**. See section 2.1 [Processor Overview] on page 21.
- **P-state**. Performance state. See section 2.4 [Power Management] on page 25.
- PTE. Page table entry.

- PVI. Parallel VID interface. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25.
- Quadword. A 64-bit value.
- **RAS**. Reliability, availability and serviceability (industry term). See section 2.13 [RAS and Advanced Server Features] on page 113.
- RX. Receiver.
- **SBI**. Sideband Interface. Also referred to as APML. See section 2.13.3 [Sideband Interface (SBI)] on page 121
- Scrubber. Background memory checking logic. See section 2.6.6 [Memory Scrubbers] on page 54.
- **Shutdown**. A state in which the affected core waits for either INIT, RESET, or NMI. When shutdown state is entered, a shutdown special cycle is sent on the IO links.
- **Single-Plane**. Refers to a processor or systemboard where VDD and VDDNB are tied together and operate at the same voltage level. Refer to 2.4.1 [Processor Power Planes And Voltage Control] on page 25.
- **Slam**. Refers to change the voltage to a new value in one step (as opposed to stepping). See section 2.4.1.8 [Hardware-Initiated Voltage Transitions] on page 30.
- **SMAF**. System management action field. This is the code passed from the SMC to the processors in STP-CLK assertion messages. The action taken by the processors in response to this message is specified by [The ACPI Power State Control Registers] F3x[84:80].
- **SMBus**. System management bus. Refers to the protocol on which the serial VID interface (SVI) commands and SBI are based. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25, 2.13.3 [Sideband Interface (SBI)] on page 121, and section 1.2 [Reference Documents] on page 12.
- **SMC**. System management controller. This is the platform device that communicates system management state information to the processor through an IO link, typically the system IO Hub.
- SMI. System management interrupt. See section 2.14.2.1 [SMM Overview] on page 124.
- SMM. System management mode. See section 2.14.2 [System Management Mode (SMM)] on page 124.
- Southbridge. Same as IO Hub.
- **Speculative event**. A performance monitor event counter that counts all occurrences of the event even if the event occurs during speculative code execution.
- STC. Software thermal control. See section 2.10.3.2 [Software Thermal Control (STC)] on page 111.
- **STC-active state**. Software-controlled lower-power, lower-performance state used to reduce temperature. See section 2.10.3.2 [Software Thermal Control (STC)] on page 111.
- **STC thermal zone**. Temperature range which may be programmed to generate interrupts and special bus cycles. See section 2.10.3.2 [Software Thermal Control (STC)] on page 111.
- **Sublink**. An 8-bit-or-less (CAD) block of link signals of a link; each sublink of a link may connect to a different device. See section 2.7 [Links] on page 55.
- SVI. Serial VID interface. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25.
- SVM. secure virtual machine. See section 2.15 [Secure Virtual Machine Mode (SVM)] on page 132.
- Sync flood. The propagation of continuous sync packets to all links. See the link specification.
- TCB. Trace capture buffer.
- TCC. Temperature calculation circuit. See section 2.10 [Thermal Functions] on page 110.
- Tctl. Processor temperature control value. See section 2.10.3 [Temperature-Driven Logic] on page 110.
- **Thermal diode**. A diode connected to the THERMDA and THERMDC pins used for thermal measurements. See section 2.10.2 [Thermal Diode] on page 110.
- **Token.** A scheduler entry used in various Northbridge queues to track outstanding requests. See [The SRI to XCS Token Count Register] F3x140 on Page 461.

- TX. Transmitter.
- UI. Unit interval. This is the amount of time equal to one half of a clock cycle.
- **Unganged**. A link, memory channel, or voltage regulator in which portions are controlled separately.
- US. Upstream. Refers to the direction of data on a link.
- usec. Microsecond.
- **VDD**. Main power supply to the processor core logic.
- **VDDNB**. Main power supply to the processor NB logic.
- VID. Voltage level identifier. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25.
- Virtual CAS. The clock in which CAS is asserted for the burst, N, plus the burst length (in MEMCLKs), minus 1; so the last clock of virtual CAS = N + BL/2 1.
- VRM. voltage regulator module.
- Warm reset. RESET\_L is asserted only (while PWROK stays high). See section 2.3 [Processor Initialization] on page 22.
- WDT. Watchdog timer. A timer that detects activity and triggers an error if a specified period of time expires
  without the activity. For example, see [The CPU Watchdog Timer Register (CpuWdTmrCfg)]
  MSRC001 0074.
- **XBAR**. Cross bar; command packet switch. See section 2.6.1 [Northbridge (NB) Architecture] on page 50.

## 1.5 Changes Between Revisions and Product Variations

#### 1.5.1 Major Changes For Revision A Relative to Family 0Fh Processors

- CPU core additions:
  - Support for up to 4 CPU cores in product variations.
  - High-performance (128-bit internal data path) floating point unit (per CPU core) in product variations.
  - SSE4A instructions.
  - Advanced bit manipulation (ABM) instructions.
  - MWAIT and MONITOR instructions.
  - Misaligned SSE mode.
  - Power management state invariant time stamp counter (TSC).
  - Number of extended LVT interrupts in APIC increased to 4.
  - Increase in the number of large TLB page entries.
  - 1 Gbyte large paging supported.
  - Physical address space increased to 48 bits.
  - All local sources of SMIs (including sources from the CPU cores and from the NB) are broadcast to all CPU cores of all nodes in the system.
- Memory controller (MCT) and DRAM controllers (DCTs) additions:
  - Support for DDR2/DDR3 DIMMs in product variations.
  - DIMMs controlled through two independent DRAM controllers.
  - Write burst and DRAM prefetching performance improvements.
  - Read and write burst support, as required for DRAM training.
- Links and IO additions:
  - HyperTransport<sup>TM</sup> 3.00 Technology, including support for DC- and AC-coupled modes.
  - Link unganging support.
  - Link-defined extended address capability to support up to 64-bit IO addresses.
  - Link-defined UnitID clumping.
  - Link-defined error retry.
  - Link-defined isochronous flow control mode.

- Link-defined INTx support.
- Support for independent ordering between requests with different non-zero SeqID values.
- Asynchronous link support (with different oscillator sources generating the reference clock on both sides of the link).

#### • RAS-related additions:

- CPU core disable capability.
- New error thresholding support for errors associated with links, and the L3 cache; all the thresholding registers are additionally accessible through configuration space.
- New configurable responses to link errors: data error to target abort; master abort to no error; configuration space master abort to no error; sync flood on data errors; sync flood on target aborts.
- Added another MCA bank for a CPU watchdog timer.
- MCA control mask registers control logging in addition to reporting of errors.
- Link protocol checking.
- Ability to convert machine check exceptions into vectored interrupts or SMIs.

#### • General Northbridge additions:

- Support for an L3 cache, shared between CPU cores, in product variations.
- BIOS-initiated system memory clear command.
- MMIO-based access to configuration space and support for extended configuration space; this includes support for SMI traps to these accesses as well.
- SMBus-based access to internal processor state called sideband interface (SBI) also referred to as APML.
- Mode whereby the IO request response order matches the IO request order.
- VGA space decoding to MMIO-space mapping registers.
- Support for multiple, simultaneous GART/DEV table walks.
- Support for evenly distributed traffic in systems that connect multiple links between the same processors.
- More DEV protection domains and a larger DEV cache.
- Ability to force all IO requests to system memory (except display refresh) to probe the cache, in support of nested paging.
- Combined link status register for all links.

#### • Power management:

- Simple "fire and forget" operating system interface for P-state changes.
- Separate CPU core and Northbridge power and clock planes.
- Support for up to 5 independent P-states for each CPU core.
- Support for P-state limits controlled by sideband interface (SBI), thermal limits (HTC), or host software; used to limit the P-state requested by the operating system in order to reduce power.
- Support for Northbridge and CPU core alternate voltages (altvid) during C3.

# **1.5.2** Supported Feature Variations

The following table specifies the first revision of the processor that is expected to be productized for each feature (blank entries indicate that the feature is not supported) and the first revision of the processor a feature is expected to be removed.

**Table 1: Supported features** 

| Feature                                                                      |                  | First Revision |
|------------------------------------------------------------------------------|------------------|----------------|
|                                                                              | Supported        | Removed        |
| Unbuffered DDR2 DIMM interface up to 800 MT/s                                | В                |                |
| Unbuffered DDR2 DIMM interface up to 1067 MT/s                               | В                |                |
| Registered DDR2 DIMM interface up to 800 MT/s                                | В                |                |
| Gen3 link and retry DC-coupled mode (coherent links)                         | В                |                |
| Gen3 link and retry DC-coupled mode (non-coherent links)                     | В                |                |
| Link unganging support                                                       |                  |                |
| Narrow (2-bit and 4-bit) link                                                |                  | В              |
| Thermal diode (THERMDA and THERMDC)                                          | В                |                |
| SMBus-based sideband thermal sensor interface (SB-TSI)                       | В                |                |
| Even traffic distribution across multiple links connected between the same 2 | В                |                |
| nodes                                                                        |                  |                |
| PVI regulator interface                                                      | В                |                |
| SVI regulator interface                                                      | В                |                |
| Single-plane compatible                                                      | В                |                |
| Dual-plane compatible                                                        | В                |                |
| Triple-plane compatible                                                      |                  |                |
| C1E                                                                          | В                |                |
| Thermal clock throttling (SMC controlled)                                    | $\mathbf{B}^{1}$ |                |
|                                                                              | •                | •              |

<sup>1.</sup> AMD recommends using PROCHOT\_L for thermal throttling and not implementing stop clock based throttling.

#### **2** Functional Description

#### 2.1 Processor Overview

The *processor* is a package that contains one node. A *node*, is an integrated circuit device that includes (1) one to four CPU cores, (2) up to four links for general-purpose communication to other devices, (3) one or two 64-bit DDR DRAM interfaces for communication to system memory, and (4) one communication packet routing block referred to as the *Northbridge* (NB).



Figure 1: A processor.

Each *CPU core* includes x86 instruction execution logic, a first-level (L1) data cache, a first-level instruction cache, and a second level (L2) general-purpose cache. There is a set of model-specific registers (MSRs) and APIC registers associated with each CPU core. Nodes that include multiple CPU cores are said to incorporate *chip multi-processing* or CMP.

Each link can be configured to operate under the rules of one of the following interface specifications: (1) AMD proprietary, coherent inter-processor link; or (2) non-coherent HyperTransport<sup>TM</sup> IO link. When a link is configured for non-coherent IO traffic, it is referred to as an *IO link*.

Each DRAM interface supports a 64-bit DDR2 or DDR3 registered or unbuffered DIMM channel.

The NB routes transactions between the CPU cores, the links, and the DRAM interfaces. It includes the configuration register space for the device. It may include an L3 cache as well.

# 2.2 System Overview

The following diagram illustrates the expected system architecture. Smaller systems may not include multiple processors or multiple IO links. Larger systems may include many more processors. Each processor in the coherent fabric communicates with other processors through the coherent link protocol. Processors communicate with the IO subsystem through IO links.



Figure 2: System diagram.

#### 2.3 Processor Initialization

This section describes the initialization sequence after a cold reset.

The core 0 of the BSP begins executing code from the reset vector. Core 0 on all other nodes do not fetch code until their [The Link Initialization Control Register] F0x6C[ReqDis] bit is cleared. The remaining cores do not fetch code until their enable bits are set ([The Link Transaction Control Register] F0x68 [Cpu1En] for core 1 and [The Extended Link Transaction Control Register] F0x168[Cpu2En], [Cpu2En] for core 2 and 3).

#### 2.3.1 BSP initialization

The BSP must perform the following tasks as part of POST.

- Store BIST information from the EAX register into an unused processor register.
- If supported, determine the type of this reset. One method is to use [The Link Initialization Control Register] F0x6C[InitDet] bit. If this boot sequence was caused by an INIT then BIOS vectors away from the cold/warm reset initialization path.
- Determine type of startup using the [The Link Initialization Control Register] F0x6C [ColdRstDet] bit. If this is a cold reset then BIOS must clear the [MCi\_STATUS] MSRs (MSR0000\_0401, MSR0000\_0405, MSR0000\_0409, MSR0000\_040D, MSR0000\_0411, MSR0000\_0415). If this is a warm reset then BIOS may check for valid MCA errors and if present save the status for later use (see 2.13.1.3 [Handling Machine Check Exceptions] on page 117).
- Enable the cache, program the MTRRs for Cache-as-RAM and initialize the Cache-as-RAM, as described in 2.3.3 [Cache Initialization For General Storage During Boot] on page 23.
- Setup of APIC (2.9.5.1 [ApicId Enumeration Requirements] on page 109).
- Perform coherent link enumeration (routing table and NodeID), as described in 2.6.4.2 [HyperTransport<sup>TM</sup> Technology Routing] on page 52.

- Configure all I/O-link devices.
  - Set configuration-base and -limit ([The Configuration Map Registers] F1x[EC:E0] [BusNumBase], [BusNumLimit]) and assign BUID.
  - Device enumeration for all I/O-link devices (see link specification).
- If required, reallocate data and flow control buffers of the links (see [The Link Base Channel Buffer Count Registers] F0x[F0, D0, B0, 90] and [The Link Isochronous Channel Buffer Count Registers] F0x[F4, D4, B4, 94]) and issue system warm reset.
- Configure links speed and link width (see link specification).
- Configure processor power management (see 2.4 [Power Management] on page 25).
- If supported, allow other cores to beginning fetching instructions by clearing [The Link Initialization Control Register] F0x6C [ReqDis] in the PCI configuration space of all other nodes and setting [The Link Transaction Control Register] F0x68[Cpu1En] and [The Extended Link Transaction Control Register] F0x168[Cpu2En], [Cpu3En] in the PCI configuration space of all nodes.

#### 2.3.2 AP initialization

All other processor cores other than core 0 of node 0 begin executing code from the reset vector. They must perform the following tasks as part of POST.

- Store BIST information from the eax register into an unused processor register.
- If supported, determine the type of startup from either the keyboard controller or the [The Link Initialization Control Register] F0x6C[InitDet] bit. If this boot sequence was caused by a nn INIT then BIOS vectors away from the cold/warm reset initialization path.
- Determine the history of this reset using the [The Link Initialization Control Register] F0x6C [ColdRstDet] bit. If this is a cold reset then BIOS must clear the [MCi\_STATUS] MSRs (MSR0000\_0401, MSR0000\_0405, MSR0000\_0409, MSR0000\_040D, MSR0000\_0411, MSR0000\_0415). If this is a warm reset then BIOS may check for valid MCA errors and if present save the status for use later (see 2.13.1.3 [Handling Machine Check Exceptions] on page 117).
- Setup of local APIC (2.9.5.1 [ApicId Enumeration Requirements] on page 109).
- Configure processor power management (see 2.4 [Power Management] on page 25).

# 2.3.3 Cache Initialization For General Storage During Boot

Prior to initializing the DRAM controller for system memory, the processor cache subsystem may be initialized for use by BIOS as general storage. The following steps should be taken to set up the cache in the boot core of the BSP to supply 48K bytes of read/write storage, including a stack:

- Initialize [The DRAM Base/Limit Registers] F1x[1, 0][7C:40] to a temporary value that allocates DRAM to the BSP in a range which includes the range of 000C\_0000h to 000C\_FFFFh (Due to register constraints some BIOS specified overlap of the required range is necessary).
- Clear all the MTRRs.
- Set [The System Configuration Register (SYS\_CFG)] MSRC001\_0010[MtrrFixDramEn, MtrrFixDram-ModEn, and MtrrVarDramEn].
- Enable cache through CR0.
- Use MTRRs to specify the write-back dram attribute (WB) to a 48 kilobyte portion of the memory map, starting at address 0C4000h.
- Read exactly 48 kilobytes of memory starting at 0C4000h, using the REP MOV instruction.
- Set SS=0C400h.
- Set SP=0BFFCh. The first push operation should not push more than a double word of data on the stack.

# 2.3.3.1 Generalized Usage Requirements

When using cache as general storage the BIOS must ensure that no data lines are evicted from the cache prior to the DRAM controller being initialized. The CLFLUSH and WBINVD must not be used before DRAM initialization when using cache as general storage.

The BIOS must not use 3DNow!<sup>TM</sup>, SSE, or MMX<sup>TM</sup> instructions prior to the DRAM controller being initialized, with the exception of the following list: MOVD, MOVQ, MOVDQA, MOVQ2DQ, MOVDQ2Q.

The BIOS must not enable exceptions, page-faults, and other interrupts to occur prior to the DRAM controller being initialized.

When the BIOS is done using the cache as general storage, an INVD instruction should be executed on each core that used cache as general storage. If DRAM is initialized and there is data in the cache that needs to get moved to main memory, CLFLUSH or WBINVD may be used instead of INVD, but software must insure that needed data in main memory is not overwritten.

# 2.3.4 Multiprocessing Capability Detection

The multiprocessing capability of the processor is determined by F3xE8[MPCap].

During POST, the BIOS checks the multiprocessing capability of all processors, and configures the system accordingly.

Multiprocessing capability detection is not required in a single processor systems.

All processors must be dual-processor (DP) capable or multipcocessor (MP) capable in a DP system. If any processor is not at least DP capable, the BIOS must configure the BSP as a uni-processor (UP), and must not initialize the AP.

All processors must be MP capable in an MP system. If any processor is not MP capable, the BIOS must configure the BSP as a UP processor, and must not initialize APs.

If all processors do not have adequate multiprocessing capability for a DP or an MP system, the BIOS must display the following message:

```
****** Warning: non-MP Processor ********
```

The processor(s) installed in your system are not multiprocessing capable. Now your system will halt.

If all processors have adequate multiprocessing capability for a DP or an MP system, but have different model numbers or operate at different frequencies, see 2.4.2.8 [Mixed-Frequency and Power P-State Configuration] on page 38.

#### 2.3.5 BIOS Requirements For 64-Bit Operation

Refer to the AMD64 Architecture Programmer's Manual for a description of 64-bit operation.

## 2.4 Power Management

The processor supports operational performance states, called P-states, ACPI power-savings states, and HTC. Processor power consumption may be altered in any of these states through control over clocking and voltage. Operational states are defined as states in which the processor is executing instructions, running software. During ACPI power-saving states, the processor does not execute instructions. Table 2 provides a summary of each power management state and indicates whether it is supported. Refer to F3x[84:80] [ACPI Power State Control Registers] on page 231 for processor configuration settings for power management.

**Table 2: Power management support** 

| ACPI/Power Management State                                                                                | Supported <sup>1</sup> | Description                                                            |
|------------------------------------------------------------------------------------------------------------|------------------------|------------------------------------------------------------------------|
| G0/S0/C0: Working                                                                                          | Yes                    |                                                                        |
| G0/S0/C0: Core P-state transitions under OS control                                                        | Yes                    | 2.4.2.1 [Core P-states] on page 32                                     |
| G0/S0/C0: Hardware thermal control (HTC)                                                                   | Yes                    | 2.10.3.1 [PROCHOT_L and Hardware<br>Thermal Control (HTC)] on page 111 |
| G0/S0/C0: Thermal clock throttling (SMC controlled)                                                        | Yes <sup>2</sup>       |                                                                        |
| G0/S0/C1: Halt                                                                                             | Yes                    |                                                                        |
| G0/S0/C2: Stop-grant Caches snoopable                                                                      | No                     |                                                                        |
| G0/S0/C3: Stop-grant Caches not snoopable (single-core devices only)                                       | No                     |                                                                        |
| G0/S0/C1E: Stop-grant Caches not snoopable using MSRC001_0055[C1eOnCmpHlt] (single and multi-core devices) | No                     |                                                                        |
| G0/S0/C1E: Stop-grant Caches not snoopable using MSRC001_0055[SmiOnCmpHlt] (single and multi-core devices) | Yes                    | 2.4.3.1 [C1 Enhanced State (C1E)] on page 47                           |
| G1/S1: Stand By (Powered On Suspend)                                                                       | Yes                    |                                                                        |
| G1/S3: Stand By (Suspend to RAM)                                                                           | Yes                    | 2.4.4 [ACPI Suspend to RAM State (S3)]<br>on page 48                   |
| G1/S4, S5: Hibernate (Suspend to Disk), Shut Down (Soft Off)                                               | Yes                    |                                                                        |
| G3 Mechanical Off                                                                                          | Yes                    |                                                                        |

- 1. Entries in the 'Supported' column indicate the following:
  - 'Yes' indicates the described ACPI state is supported in all packages.
  - 'No' indicates the described ACPI state is not supported in any package.
- 2. AMD recommends using PROCHOT\_L for thermal throttling and not implementing stop clock based throttling.

3.

# 2.4.1 Processor Power Planes And Voltage Control

The processor includes the following power planes:

- VDDIO: used for the DRAM and miscellaneous pins on DDR products only. Voltage level is nominally 1.8V or 1.9V in support of DDR2; 1.5V in support of DDR3. This plane is powered during S3 (suspend to RAM).
- VTT: used for the DDR DRAM interface. Voltage level is specified to be half of the VDDIO level. This plane is powered during S3 (suspend to RAM). See section 2.4.4 [ACPI Suspend to RAM State (S3)] on page 48.
- VLDT: used for each of the links. Voltage level is nominally 1.2V.
- VDDA: filtered PLL supply. Voltage level is nominally 2.5V.
- VDD or VDD[1:0]: main supply for core logic. "VDD" refers generically to the core voltage plane(s). Voltage level is specified by the VID interface.
- VDDNB: main supply for NB logic. Voltage level specified by the VID interface.

The voltage level of VDD and VDDNB may be altered in various states to control power consumption. All the

other supplies are fixed. Refer to the EDS for power plane sequencing requirements.

The processor includes two interfaces, intended to control external voltage regulators, called the parallel VID (voltage level identifier) interface (PVI) and the serial VID interface (SVI). The PVI is a simple 6-bit VID code provided on 6 pins. The SVI encodes voltage regulator control commands, including the VID code, using SMBus protocol over two pins, SVD and SVC, to generate write commands to external voltage regulators. The processor is the master and the voltage regulator(s) are the slave(s). Both pins are outputs of the master; SVD is driven by the slave as well. SVC is a clock that strobes the data pin, SVD, on the rising edge. Refer to the AMD Design Guide for Voltage Regulator Controllers Accepting Serial VID Codes for details on SVI protocol. See section 1.2 [Reference Documents] on page 12.

The processor supports:

- Single-plane platforms in which all the VDD and VDDNB power planes are connected together on the systemboard and controlled as a single power plane through the PVI (F3xA0[PviMode]=1) interface.
- Dual-plane platforms in which the VDD and VDDNB planes are isolated on the systemboard and controlled as separate voltages through the SVI or PVI interface.

#### 2.4.1.1 VID Pins And Interface Selection.

The VID interfaces use pins VID[5:0]. While PWROK is deasserted, the processor tristates VID[1] so that it may be used to select the VID interface; VID[1] is expected to be strapped high or low through a resistor on the systemboard. When PWROK asserts, the processor samples VID[1] and captures the state in [The Power Control Miscellaneous Register] F3xA0[PviMode].

VID[5:0] are controlled as follows:

- If PWROK = 0, VID[1] is an input to the processor.
  - VID[5:2, 0] are in push-pull mode (outputs are driving high or low).
  - If VID[1] = 1, VID[5:2, 0] =the PVI boot VID value.
  - If VID[1] = 0:
    - VID[5:4, 0] = output a valid, undefined state.
    - VID[3:2] = the SVI boot VID value (see section 2.4.1.6.3 [Serial VID (SVI) Encodings] on page 28).
- If PWROK = 1:
  - If F3xA0[PviMode] = 1: VID[5:0] are all driven and controlled as needed by the boot process.
  - If F3xA0[PviMode] = 0:
    - VID[5, 4, 1] are driven low.
    - VID[3] becomes the SVC pin of the SVI. VID[2] becomes the SVD pin of the SVI. Transition from push-pull mode to open-drain mode occurs some time between the assertion of PWROK and the first SVI command.

#### 2.4.1.2 Internal VID Registers

The registers within the processor that contain VID fields all use 7-bit VID encodings (see Table 5), regardless of whether the processor is in SVI mode or PVI mode. Processor hardware translates to the 6-bit VID encoding if [The Power Control Miscellaneous Register] F3xA0[PviMode]=1. The translation from the 7-bit VID code, SviVid, to the 6-bit VID code, PviVid, is as follows:

- In a single-plane system the P-state VID is dictated by MSRC001\_00[68:64][NbVid] of the CPU-core in the highest-performance P-state.
- In a dual-plane system
  - The VID for VDDNB is dictated by MSRC001\_00[68:64][NbVid] of the CPU-core in the highest-performance P-state.
  - The VID for VDD is dictated by MSRC001\_00[68:64][CpuVid] of the CPU-core in the highest-performance P-state.

#### 2.4.1.3 MinVid and MaxVid Check

The allowed limits of MinVid and MaxVid are provided in [The COFVID Status Register] MSRC001\_0071. Prior to generating VID-change commands to either the PVI or SVI, the processor filters the InputVid value to the OutputVid as follows:

- If InputVid < MaxVid, OutputVid=MaxVid.
  - Else if (InputVid > MinVid) & (MinVid != 00h), OutputVid=MinVid.
  - Else OutputVid=InputVid.

This filtering is applied regardless of the source of the VID-change command.

# 2.4.1.4 PSI\_L

The processor supports indication of whether the processor is in a low-voltage state or not, which may be used by the regulator to place itself into a more power efficient mode. This is supported by the PSI\_L pin when F3xA0[PviMode]=1 and by a bit in the data field of the SVI command when F3xA0[PviMode]=0; in SVI mode, the PSI\_L pin is always high. It is enabled through F3xA0[PsiVidEn]. PSI\_L is asserted if the processor selects a VID code that is lower than the level specified in F3xA0[PsiVid].

# 2.4.1.5 Alternative Voltage (Altvid)

In order to save power, a lower alternative voltage (altvid) may be applied while in either the C3 or C1E state. Separate altvid values may be applied to the CPU cores and the NB. Altvids are controlled by F3x[84:80][AltVidEn], F3xD8, F3xDC[AltVid], F3x1F0[ClkDivAltVid].

Altvids are not supported in multi-node or multi-link systems.

# 2.4.1.6 VID Encodings

The following sections provide VID encoding to VDD translations. Section 2.4.1.6.1 [Boot VID Encodings] on page 27 defines the VID to VDD translation for both protocols prior to PWROK assertion. Sections 2.4.1.6.2 [Parallel VID Interface (PVI) Encodings] on page 28 and 2.4.1.6.3 [Serial VID (SVI) Encodings] on page 28 define the VID to VDD translation following PWROK assertion and protocol initialization (if required).

# 2.4.1.6.1 Boot VID Encodings

Prior to PWROK assertion the VID pins drive the Boot VID value in the manner specified by section 2.4.1.1 [VID Pins And Interface Selection.] on page 26. There are 4 possible VDD values that can be requested by the Boot VID. The following table shows the Boot VID to VDD translation for both SVI and PVI protocol.

In an SVI system each regulator is specified to drive a voltage corresponding to the Boot VID value after PWROK is asserted until an SVI command addressed to that regulator changes the requested voltage.

**Table 3: Boot VID codes** 

| PVI<br>VID[5:0] | SVI<br>VID[3:2] | VDD   |
|-----------------|-----------------|-------|
| 01_0010b        | 00b             | 1.100 |
| 01_0110b        | 01b             | 1.000 |
| 01_1010b        | 10b             | 0.900 |
| 01_1110b        | 11b             | 0.800 |

# 2.4.1.6.2 Parallel VID Interface (PVI) Encodings

The 6-bit VID code programmed into the regulator, PviVid[5:0], is expected to be encoded by the regulator as follows:

```
If PviVid >= 20h, voltage = 0.7625V - 0.0125V * (PviVid-20h);
else voltage = 1.550V - 0.025V * PviVid;
```

I.e, 12.5mV resolution from 0.3875V (3Eh) to 0.775V (1Fh) and 25mV resolution from 0.775V to 1.55V (00h). The following table provides the same information.

Table 4: PVI VID codes

| VID[5:0] | VDD   | VID[5:0] | VDD   | VID[5:0] | VDD    | VID[5:0] | VDD    |
|----------|-------|----------|-------|----------|--------|----------|--------|
| 00_000b  | 1.550 | 01_0000b | 1.150 | 10_000b  | 0.7625 | 11_0000b | 0.5625 |
| 00_0001b | 1.525 | 01_0001b | 1.125 | 10_0001b | 0.7500 | 11_0001b | 0.5500 |
| 00_0010b | 1.500 | 01_0010b | 1.100 | 10_0010b | 0.7375 | 11_0010b | 0.5375 |
| 00_0011b | 1.475 | 01_0011b | 1.075 | 10_0011b | 0.7250 | 11_0011b | 0.5250 |
| 00_0100b | 1.450 | 01_0100b | 1.050 | 10_0100b | 0.7125 | 11_0100b | 0.5125 |
| 00_0101b | 1.425 | 01_0101b | 1.025 | 10_0101b | 0.7000 | 11_0101b | 0.5000 |
| 00_0110b | 1.400 | 01_0110b | 1.000 | 10_0110b | 0.6875 | 11_0110b | 0.4875 |
| 00_0111b | 1.375 | 01_0111b | 0.975 | 10_0111b | 0.6750 | 11_0111b | 0.4750 |
| 00_1000b | 1.350 | 01_1000b | 0.950 | 10_1000b | 0.6625 | 11_1000b | 0.4625 |
| 00_1001b | 1.325 | 01_1001b | 0.925 | 10_1001b | 0.6500 | 11_1001b | 0.4500 |
| 00_1010b | 1.300 | 01_1010b | 0.900 | 10_1010b | 0.6375 | 11_1010b | 0.4375 |
| 00_1011b | 1.275 | 01_1011b | 0.875 | 10_1011b | 0.6250 | 11_1011b | 0.4250 |
| 00_1100b | 1.250 | 01_1100b | 0.850 | 10_1100b | 0.6125 | 11_1100b | 0.4125 |
| 00_1101b | 1.225 | 01_1101b | 0.825 | 10_1101b | 0.6000 | 11_1101b | 0.4000 |
| 00_1110b | 1.200 | 01_1110b | 0.800 | 10_1110b | 0.5875 | 11_1110b | 0.3875 |
| 00_1111b | 1.175 | 01_1111b | 0.775 | 10_1111b | 0.5750 | 11_1111b | 0.3750 |

# 2.4.1.6.3 Serial VID (SVI) Encodings

The 7-bit VID code programmed into the regulator, SviVid[6:0], is expected to be encoded by the regulator as follows:

```
If SviVid[6:0] == 7Fh through 7Ch, voltage = 0V;
else voltage = 1.550V - 0.0125V * SviVid[6:0];
```

The following table provides the same information.

Table 5: SVI and internal VID codes

|           |        | 1 122 00000 |        |           |        |           |        |
|-----------|--------|-------------|--------|-----------|--------|-----------|--------|
| VID[6:0]  | VDD    | VID[6:0]    | VDD    | VID[6:0]  | VDD    | VID[6:0]  | VDD    |
| 000_000b  | 1.5500 | 010_0000b   | 1.1500 | 100_0000b | 0.7500 | 110_0000b | 0.3500 |
| 000_0001b | 1.5375 | 010_0001b   | 1.1375 | 100_0001b | 0.7375 | 110_0001b | 0.3375 |
| 000_0010b | 1.5250 | 010_0010b   | 1.1250 | 100_0010b | 0.7250 | 110_0010b | 0.3250 |
| 000_0011b | 1.5125 | 010_0011b   | 1.1125 | 100_0011b | 0.7125 | 110_0011b | 0.3125 |
| 000_0100b | 1.5000 | 010_0100b   | 1.1000 | 100_0100b | 0.7000 | 110_0100b | 0.3000 |
| 000_0101b | 1.4875 | 010_0101b   | 1.0875 | 100_0101b | 0.6875 | 110_0101b | 0.2875 |
| 000_0110b | 1.4750 | 010_0110b   | 1.0750 | 100_0110b | 0.6750 | 110_0110b | 0.2750 |
| 000_0111b | 1.4625 | 010_0111b   | 1.0625 | 100_0111b | 0.6625 | 110_0111b | 0.2625 |
| 000_1000b | 1.4500 | 010_1000b   | 1.0500 | 100_1000b | 0.6500 | 110_1000b | 0.2500 |
| 000_1001b | 1.4375 | 010_1001b   | 1.0375 | 100_1001b | 0.6375 | 110_1001b | 0.2375 |
| 000_1010b | 1.4250 | 010_1010b   | 1.0250 | 100_1010b | 0.6250 | 110_1010b | 0.2250 |
| 000_1011b | 1.4125 | 010_1011b   | 1.0125 | 100_1011b | 0.6125 | 110_1011b | 0.2125 |
| 000_1100b | 1.4000 | 010_1100b   | 1.0000 | 100_1100b | 0.6000 | 110_1100b | 0.2000 |
| 000_1101b | 1.3875 | 010_1101b   | 0.9875 | 100_1101b | 0.5875 | 110_1101b | 0.1875 |
| 000_1110b | 1.3750 | 010_1110b   | 0.9750 | 100_1110b | 0.5750 | 110_1110b | 0.1750 |
| 000_1111b | 1.3625 | 010_1111b   | 0.9625 | 100_1111b | 0.5625 | 110_1111b | 0.1625 |
| 001_0000b | 1.3500 | 011_0000b   | 0.9500 | 101_0000b | 0.5500 | 111_0000b | 0.1500 |
| 001_0001b | 1.3375 | 011_0001b   | 0.9375 | 101_0001b | 0.5375 | 111_0001b | 0.1375 |
| 001_0010b | 1.3250 | 011_0010b   | 0.9250 | 101_0010b | 0.5250 | 111_0010b | 0.1250 |
| 001_0011b | 1.3125 | 011_0011b   | 0.9125 | 101_0011b | 0.5125 | 111_0011b | 0.1125 |
| 001_0100b | 1.3000 | 011_0100b   | 0.9000 | 101_0100b | 0.5000 | 111_0100b | 0.1000 |
| 001_0101b | 1.2875 | 011_0101b   | 0.8875 | 101_0101b | 0.4875 | 111_0101b | 0.0875 |
| 001_0110b | 1.2750 | 011_0110b   | 0.8750 | 101_0110b | 0.4750 | 111_0110b | 0.0750 |
| 001_0111b | 1.2625 | 011_0111b   | 0.8625 | 101_0111b | 0.4625 | 111_0111b | 0.0625 |
| 001_1000b | 1.2500 | 011_1000b   | 0.8500 | 101_1000b | 0.4500 | 111_1000b | 0.0500 |
| 001_1001b | 1.2375 | 011_1001b   | 0.8375 | 101_1001b | 0.4375 | 111_1001b | 0.0375 |
| 001_1010b | 1.2250 | 011_1010b   | 0.8250 | 101_1010b | 0.4250 | 111_1010b | 0.0250 |
| 001_1011b | 1.2125 | 011_1011b   | 0.8125 | 101_1011b | 0.4125 | 111_1011b | 0.0125 |
| 001_1100b | 1.2000 | 011_1100b   | 0.8000 | 101_1100b | 0.4000 | 111_1100b | 0.0000 |
| 001_1101b | 1.1875 | 011_1101b   | 0.7875 | 101_1101b | 0.3875 | 111_1101b | 0.0000 |
| 001_1110b | 1.1750 | 011_1110b   | 0.7750 | 101_1110b | 0.3750 | 111_1110b | 0.0000 |
| 001_1111b | 1.1625 | 011_1111b   | 0.7625 | 101_1111b | 0.3625 | 111_1111b | 0.0000 |
|           |        |             |        |           |        |           |        |

# 2.4.1.7 BIOS Requirements for Power Plane Initialization

- In single-plane systems BIOS is required to place the lower VID code (higher voltage) specified in the MSRC001\_00[68:64][NbVid and CpuVid] fields into both of these fields. Repeat this operation for all enabled P-states.
- Configure F3xA0[SlamVidMode] and F3xD8[VSRampTime or VSSlamTime] based on the platform requirements.

- Configure F3xD4[PowerStepUp, PowerStepDown].
- Optionally configure F3xA0[PsiVidEn and PsiVid]. Refer to section 2.4.1.4 [PSI\_L] on page 27 for additional details.

#### 2.4.1.8 Hardware-Initiated Voltage Transitions

VDD and VDDNB voltage levels may be transitioned during state changes involving boot, reset, P-state, and stop-grant. In some cases, the voltage is *slammed*; this means that the VID code passed to the voltage regulator changes from the old value to the new value without stepping through intermediate values. In other cases, the voltage is stepped; this means that the VID code is *stepped* one increment at a time and held at each value for a voltage-settling time based on [The Clock Power/Timing Control 1 Register] F3xD8[VSRampTime]. Voltages are transitioned as follows:

| First state   | Second state     | <u>Voltage transition</u>                                             |
|---------------|------------------|-----------------------------------------------------------------------|
| Voltage off   | PWROK assert     | Voltages slammed to a factory-specified boot VID (for parallel VID    |
|               |                  | interface) or strapped VID code (for serial VID interface).           |
| PWROK assert  | RESET_L deassert | Voltages slammed to a factory-specified start-up VID specified by     |
|               |                  | MSRC001_0071[StartupPstate].                                          |
| Any P-state   | Any P-state      | Voltage stepped or slammed (based on F3xA0[SlamVidMode]) to the       |
|               |                  | new P-state VID.                                                      |
| Any P-state   | Alternate VID    | Voltage stepped or slammed (based on F3xA0[SlamVidMode]) to           |
|               |                  | value programmed into F3xDC[AltVid].                                  |
| Alternate VID | Any P-state      | Voltage stepped or slammed (based on F3xA0[SlamVidMode]) to the       |
|               |                  | value captured from the P-state prior to application of the alternate |
|               |                  | VID.                                                                  |

#### 2.4.1.9 Software-Initiated Voltage Transitions

The processor supports direct software VID control using [The COFVID Control Register] MSRC001\_0070. The setting for F3xA0[SlamVidMode] determines the sequence used for direct VID control. Hardware P-state transitions using [The P-State Control Register] MSRC001\_0062 result in unpredictable behavior if software modifies the NbVid or CpuVid from the appropriate settings for the current P-state reported in [The P-State Status Register] MSRC001\_0063. If F3xA0[PviMode]=1b only changes to NbVid are driven on the PVI interface as defined in Section 2.4.1 [Processor Power Planes And Voltage Control] on page 25.

# 2.4.1.9.1 Software-Initiated NB Voltage Transitions

NewNbVid = the destination NB VID.

F3xA0[SlamVidMode]=1:

- 1. Write NewNbVid to all copies of MSRC001\_0070[NbVid].
- 2. Wait the specified F3xD8[VSSlamTime].

# F3xA0[SlamVidMode]=0:

- If NewNbVid > MSRC001\_0071[CurNbVid] write MSRC001\_0071[CurNbVid] + 1 to all copies of MSRC001\_0070[NbVid]; else write MSRC001\_0071[CurNbVid] - 1 to all copies of MSRC001\_0070[NbVid].
- 2. Wait the specified F3xD8[VSRampTime].
- 3. If MSRC001 0071[CurNbVid] != NewNbVid goto step 1.

#### 2.4.1.9.2 Software-Initiated CPU Voltage Transitions

NewCpuVid = the destination CPU VID.

F3xA0[SlamVidMode]=1:

- 1. Write NewCpuVid to MSRC001\_0070[CpuVid].
- 2. Wait the specified F3xD8[VSSlamTime].

#### F3xA0[SlamVidMode]=0:

Software must use the sequence for F3xA0[SlamVidMode]=0 defined in section 2.4.1.9.1 [Software-Initiated NB Voltage Transitions] on page 30 to control the single-plane through NbVid.

#### **2.4.1.10** SVI Protocol

The SVI protocol is specified in the AMD Voltage Regulator Specification, with the following exception:

• Only a 400kHz bus clock is supported.

#### 2.4.2 P-states

P-states are operational performance states (states in which the processor is executing instructions, running software) characterized by a unique frequency and voltage. The processor supports up to 5 P-states called P-states 0 through 4 or P0 though P4. P0 is the highest power, highest performance P-state; each ascending P-state number represents a lower-power, lower performance P-state than the prior P-state number. At least one enabled P-state (P0) is specified for all processors.

The processor supports dynamic P-state changes in up to 5 independently-controllable frequency planes: each CPU core (up to 4) and the NB; and up to 2 independently-controllable voltage planes: VDD, and VDDNB. Refer to section 2.4.1 [Processor Power Planes And Voltage Control] on page 25 for voltage plane definitions and section 1.5.2 [Supported Feature Variations] on page 20 for package/socket-specific information on voltage plane compatibility.

The following terminology applies to P-state definitions:

- FID: frequency ID. Specifies the PLL frequency multiplier, relative to the reference clock, for a given domain.
- DID: divisor ID. Specifies the post-PLL power-of-two divisor that may be used to reduce the operating frequency.
- COF: current operating frequency.
  - Refer to 2.4.2.1 [Core P-states] on page 32 for details on the reference clock frequency and allowed DIDs for core P-states. Refer to MSRC001\_00[68:64][CpuFid] for the CPU COF formula and details on allowed FIDs for core P-states.
  - Refer to F3xD4[NbFid] for the NB COF formula.
- MOF: maximum operating frequency. This is the maximum operating frequency that the product is intended to support; this is specified as the COF of P-state 0 found in MSRC001\_0064 (MSRC001\_00[68:64]) and F3xD4[NbFid] (for the NB) after a cold reset.
- VID: voltage ID. Specifies the voltage level for a given domain. Refer to 2.4.1.6 [VID Encodings] on page 27 for encodings.

Out of cold reset, the VID and FID of the NB and CPU cores is specified by [The Power Control Miscellaneous Register] F3xA0[CofVidProg] and [The COFVID Status Register] MSRC001 0071[StartupPstate].

The dynamic FID, DID, and VID values associated with P-state transitions for all frequency and voltage domains are specified by [The P-State [4:0] Registers] MSRC001\_00[68:64]. All FID and DID parameters must be programmed to equivalent values for all CPU cores and NBs in the coherent fabric. Refer to the MSRC001\_00[68:64] and F3xD4[NbFid] register definitions for further details on programming requirements. Processors with different default P-state definitions can be mixed in a multi-socket system and still satisfy the FID and DID programming requirements. Refer to section 2.4.2.8 [Mixed-Frequency and Power P-State Configuration] on page 38 for details on multi-socket, mixed-frequency and/or power initialization requirements.

#### **2.4.2.1** Core P-states

Dynamic core P-state support is indicated by more than one enabled selection in [The P-State [4:0] Registers] MSRC001\_00[68:64][PstateEn]. The FID, DID, and VID for each core P-state is specified in [The P-State [4:0] Registers] MSRC001\_00[68:64]. The COF for core P-states is a function of half the CLKIN frequency (nominally 100 MHz) and the DID may be 1, 2, 4, 8, and 16. Software controls the current core P-state request for each core independently using the hardware P-state control mechanism (a.k.a. fire and forget). Support for hardware P-state control is indicated by CPUID Fn8000\_0007[HwPstate]=1b. P-state transitions using the hardware P-state control mechanism are not allowed until the P-state initialization requirements defined in section 2.4.2.5 [BIOS Requirements for P-State Initialization and Transitions] on page 34 are complete.

#### 2.4.2.1.1 Core P-state Control

Core P-states are dynamically controlled by software and are exposed through ACPI objects (refer to section 2.4.2.9 [ACPI Processor P-State Objects] on page 44). Software requests a core P-state change by writing a 3 bit index corresponding to the desired core P-state number to [The P-State Control Register] MSRC001\_0062[PstateCmd] of the appropriate core. E.g. to request P3 for core 0 software would write 011b to core 0's MSRC001\_0062[PstateCmd]. Refer to [The P-State [4:0] Registers] MSRC001\_00[68:64] for mapping of P-state numbers (and corresponding 3 bit indexes) to P-state registers.

Hardware sequences the frequency and voltage changes necessary to complete a P-state transition as specified by 2.4.2.4 [P-state Transition Behavior] on page 33 with no additional software interaction required. Core P-states are changed without interaction with the external chipset. [The P-State Status Register] MSRC001\_0063[CurPstate] reflects the current frequency component (COF) of each core as a 3 bit index corresponding to the current P-state number. E.g. Core 1 MSRC001\_0063[CurPstate] = 010b indicates core 1 is at the P2 COF (specified by MSRC001\_0066[CpuFid and CpuDid]).

Hardware controls the VID for each voltage domain according to the highest requirement of the frequency domain(s) on each plane. The number of frequency domains in a voltage domain is package/platform specific. Refer to section 1.5.2 [Supported Feature Variations] on page 20 for package/platform specific voltage plane support. E.g. The VID for a 4-core single voltage plane system must be maintained at the highest level required for all 5 frequency domains (4 cores and NB). Refer to section 2.4.2.4 [P-state Transition Behavior] on page 33 for details on hardware P-state voltage control. Section 2.4.1.7 [BIOS Requirements for Power Plane Initialization] on page 29 specifies the processor initialization requirements for voltage plane control.

#### 2.4.2.2 P-state Limits

P-states may be limited to lower-performance values under certain conditions, including HTC and STC logic. Registers that control this are [The Hardware Thermal Control (HTC) Register] F3x64[HtcPstateLimit], and [The Software Thermal Control (STC) Register] F3x68[StcPstateLimit]. The current limit is provided in [The P-State Current Limit Register] MSRC001\_0061[CurPstateLimit]. Changes to the MSRC001\_0061[CurPstate-Limit] can be programmed to trigger interrupts through F3x64[PslApicLoEn and PslApicHiEn]. In addition, the maximum value P-state, regardless of the source, is limited as specified in MSRC001\_0061[PstateMax-

Val].

# 2.4.2.3 P-state Bandwidth Requirements

- The frequency relationship of (core COF / NB COF) <= 2 must be maintained for all supported P-state combinations. E.g., a core P0 COF of 2.4 GHz could not be combined with a NB P0 COF of 1.0 GHz; the NB P0 COF would have to be 1.2 GHz or greater; if the NB P0 COF is 1.2 GHz, then the NB P1 COF of 0.6 GHz may only be supported if the corresponding core P-state specify a COF of 1.2 GHz or less.
- All core P-states are required to be defined such that (NB COF/core COF) <= 32, for all NB/core P-state combinations. E.g., if the NB COF is 4.8 GHz then the core COF must be no less than 150 MHz.
- All core P-states must be defined such that:
  - CPU COF >= 400Mhz.

#### 2.4.2.4 P-state Transition Behavior

P-state changes normally include a COF change and a VID change. If the P-state number is increasing (to a lower-performance state), then the COF is changed first, followed by the VID change. If the P-state number is decreasing, then the VID is changed first followed by the COF. VID changes may be slammed or ramped; see section 2.4.1.8 [Hardware-Initiated Voltage Transitions] on page 30.

P-state changes that include VID changes may take 100's of microseconds to complete. Once the processor has initiated a VID change for a domain, it completes it regardless of what commands are received while the P-state change takes place. If multiple commands are issued that affect the P-state of a domain prior to when the processor initiates the change of the P-state of that domain, then the processor operates on the last one issued.

There is one set of P-state control registers in each CPU core. Each core may independently request to enter a different P-state. When lower-performance P-states are requested, the logic reduces the COF of the core; however, if that core shares its power plane with another core, the VID cannot change until the other core's P-state is reduced. For example, assume there are two CPU cores, both initially in P0 (along with the NB), and the NB is on a separate power plane:

- If a first command is issued to place CPU core 0 into P2, then:
  - If the CPU cores are on separate supplies, then CPU core 0's COF and VID are changed to P2.
  - If the CPU cores are on the same supply, then CPU core 0's COF is placed into P2, but the VID does not change.
- If a second command is issued placing CPU core 1 into P4, then:
  - If the CPU cores are on separate supplies, then CPU core 1's COF and VID are changed to P4.
  - If the CPU cores are on the same supply, then CPU core 1's COF is changed to P4 and then the VID is changed to P2 (the VID of the highest-performance core P-state on that power plane).
- If a third command is issued placing CPU core 1 back into P0, then:
  - If the CPU cores are on separate supplies, then CPU core 1's COF and VID are changed back to P0.
  - If the CPU cores are on the same supply, then the VID is changed to P0 and then CPU1's COF is changed to P0.

The following rules specify how P-states interact with other system or processor states:

- Once a P-state change starts, the P-state state machine (PSSM) continues through completion unless interrupted by a PWROK deassertion or RESET\_L assertion. If multiple P-state changes are requested concurrently, the PSSM may group the associated VID changes separately from the associated COF changes.
- Behavior during RESET L assertions:
  - If there is no P-state transition activity, then the cores and NB remain in the current P-state. If there is an

altvid applied:

- 1. If F3xDC[AltVid] applied, then the processor transitions the VID to the VID of the last P-state (slamming or stepping based on the state of F3xA0[SlamVidMode]).
- 2. The time specified by F3xD8[VSSlamTime] is allowed to transpire.
- 3. The CPUs and NB are brought back to the COF of the last P-state.
- If a RESET\_L assertion interrupts a P-state transition, then the COF remains in it's current state at the time RESET\_L is asserted (either the value of the old or the new P-state) and the VID remains in it's current state (perhaps at a VID between the old and the new P-states, if the VID was being stepped). BIOS is required to transition to valid COF and VID settings after a warm reset according to the sequence defined in section 2.4.2.11 [BIOS COF and VID Requirements After Warm Reset] on page 46.
- If F3xD4[NbFid] has changed, then the new value is applied to the NB PLL on the assertion of RESET\_L. It is assumed that BIOS adjusts the NB VID to the appropriate value prior to the warm reset. See also section 2.4.1.9 [Software-Initiated Voltage Transitions] on page 30.
- Behavior if an altvid is requested during a P-state transition:
  - If the VID is being stepped, then the processor continues stepping the VID until the plane reaches the destination VID code and applies that altvid value.
  - When exiting the altvid state, the processor places the VID at the last value prior to the altvid.
- If F3xA0[PviMode]=1, the P-state VID is dictated by MSRC001\_00[68:64][NbVid] of the CPU-core in the highest-performance P-state.
- The OS controls the P-state through [The P-State Control Register] MSRC001\_0062, independent of P-state limits described in [The Hardware Thermal Control (HTC) Register] F3x64[HtcPstateLimit], and [The Software Thermal Control (STC) Register] F3x68[StcPstateLimit]. P-state limits interact with OS-directed P-state transitions as follows:
  - Of all the active P-state limits, the one that represents the lowest-performance P-state number, at any given time, is treated as an upper limit on performance.
  - As the limit becomes active or inactive, or if it changes, the P-state for each core is placed in either the last OS-requested P-state or the new limit P-state, whichever is a lower performance P-state number.
    - If the resulting P-state number exceeds [The P-State Current Limit Register] MSRC001\_0061[PstateMaxVal], regardless of whether it is a limit or OS-requested, then the PstateMaxVal is used instead.
- The Altvid value specified by F3xDC[AltVid] may be applied in the C1E state. While in this state, this value is applied; when exiting this state, the VIDs associated with the current P-state of each power plane is applied.

#### 2.4.2.5 BIOS Requirements for P-State Initialization and Transitions

P-state transitions can be used only if they are supported by the processor and by the system. BIOS requirements are:

- 1. Configure the F3x[84:80] [ACPI Power State Control Registers] on page 231 according to the settings in Table 61.
- 2. Configure the Northbridge COF and VID for each processor appropriately based on the sequence described in 2.4.2.6 [BIOS Northbridge COF and VID Configuration] on page 35.
- 3. Complete the 2.4.1.7 [BIOS Requirements for Power Plane Initialization] on page 29.
- 4. Complete the 2.4.2.7 [Processor-Systemboard Power Delivery Compatibility Check] on page 36.
- 5. Determine the valid set of P-states:
  - Based on the sequence described in 2.4.2.8 [Mixed-Frequency and Power P-State Configuration] on page 38 for multi-processor systems.
  - Based on the enabled P-states indicated in [The P-State [4:0] Registers] MSRC001\_00[68:64][PstateEn] for single-processor systems.
- 6. If P-states are not supported, as indicated by only one enabled selection in [The P-State [4:0] Registers] MSRC001\_00[68:64][PstateEn], then BIOS must not generate ACPI-defined P-state objects described in

section 2.4.2.9 [ACPI Processor P-State Objects] on page 44. Otherwise, the ACPI objects should be generated to enable P-state support.

The following must also be completed before P-state transitions are allowed:

- If MSRC001\_00[68:64][CpuFid] is different between any two enabled P-states, the PLL lock time must be specified by [The Power Control Miscellaneous Register] F3xA0[PllLockTime].
- Configure F3xD4[NbClkDivApplyAll, NbClkDiv, and ClkRampHystSel].

# 2.4.2.6 BIOS Northbridge COF and VID Configuration

BIOS is responsible for initializing the NB COF and VID settings based on the power plane capabilities of the platform. F3xD4[NbFid] must be matched between all processors in the coherent fabric of a multi-socket system. The lowest setting from all processors in a multi-socket system (determined by using the following equations on each processor and selecting the lowest value) is used as the common NbFid. The NewNbVid values derived from the following equations are applied uniquely to each processor in the system and are not matched across processors.

# 2.4.2.6.1 BIOS NB COF and VID Configuration for Single-Plane PVI Systems

If F3x1FC[NbCofVidUpdate]=0 for all processors in the system and all processors in the system have equivalent values in F3xD4[NbFid], then no updates are required for the NB COF and VID configuration, and the following numbered sequence can be skipped. NewNbFid and NewNbVid are defined in section 2.4.2.6 [BIOS Northbridge COF and VID Configuration] on page 35.

- Copy the contents of the P-state register MSRC001\_00[68:64] pointed to by MSRC001\_0071[StartupPstate] to MSRC001\_0064 and MSRC001\_0065 for all cores on the local processor
- 2. Copy NewNbVid to MSRC001\_0064[NbVid] for all cores on the local processor.
- 3. Request a transition to P1 (Write MSRC001 0062[PstateCmd]=001b) for all cores on the local processor.
- 4. Request a transition to P0 (Write MSRC001\_0062[PstateCmd]=000b) on core 0 of the local processor.
- 5. Wait for MSRC001\_0063[CurPstate]=000b on core 0 of the local processor.
- 6. Copy NewNbFid to F3xD4[NbFid] and set F3xD4[NbFidEn] on the local processor.
- 7. Repeat steps 1 through 6 for each processor in the system.
- 8. A warm reset is required to cause the new F3xD4[NbFid] setting(s) to be applied.
- 9. Update MSRC001\_00[68:64][NbVid] according to F3x1FC[NbVidUpdateAll] as follows:
  - If F3x1FC[NbVidUpdateAll]=0 copy NewNbVid to MSRC001\_00[68:64][NbVid] where MSRC001\_00[68:64][NbDid]=0 and MSRC001\_00[68:64][PstateEn]=1.
  - If F3x1FC[NbVidUpdateAll]=1 copy NewNbVid to MSRC001\_00[68:64][NbVid] where MSRC001\_00[68:64][PstateEn]=1.

10. For each processor in the system, transition all cores to MSRC001\_0071[StartupPstate] using MSRC001\_0063[PstateCmd].

# 2.4.2.6.2 BIOS NB COF and VID Configuration for Dual-Plane PVI Systems

If the systemboard is dual-plane and F3xA0[PviMode]=1, then systemboard-specific control logic exists for the routing of the processor VID pins to the voltage regulators. Note that the devices used to route the processor VID[5:0] lines to the VDD and VDDNB regulators may not be transparent after cold or warm reset, but are required to be transparent when transitioning from S4 or S5 to S0. The steps in the following sequence that manipulate VID control logic on the systemboard affect all sockets. The following sequence is used to properly configure VDD and VDDNB:

- 1. Expose both the VDD and VDDNB regulator inputs to the VID code driven on the processor VID[5:0] lines.
- 2. Wait a sufficient time for the systemboard-specific control logic to pass the processor VID[5:0] value to the regulator inputs.
- 3. Latch the VID code driven on the processor VID[5:0] lines and preserve the value to the VDD regulator input while leaving the VDDNB regulator input exposed to transitions on the processor VID[5:0] lines.
- 4. Copy the contents of the P-state register MSRC001\_00[68:64] pointed to by MSRC001\_0071[StartupPstate] to MSRC001\_0064 and MSRC001\_0065 for all cores on the local processor.
- 5. Copy NewNbVid to MSRC001\_0064[NbVid] for all cores on the local processor.
- 6. Request a transition to P1 (Write MSRC001\_0062[PstateCmd]=001b) for all cores on the local processor.
- 7. Request a transition to P0 (Write MSRC001\_0062[PstateCmd]=000b) on core 0 of the local processor.
- 8. Wait for MSRC001\_0063[CurPstate]=000b on core 0 of the local processor.
- 9. Copy NewNbFid to F3xD4[NbFid] and set F3xD4[NbFidEn] on the local processor.
- 10. Repeat steps 4 through 9 for each processor in the system.
- 11. Latch the VID code driven on the processor VID[5:0] lines and preserve the value to the VDDNB regulator.
- 12. Request a transition to P1 (Write MSRC001 0062[PstateCmd]=001b) on core 0 of each processor.
- 13. Expose the VDD regulator inputs to the VID code driven on the processor VID[5:0] lines while leaving the VDDNB regulator input latched.
- 14. Issue a warm reset. This is required to cause the new F3xD4[NbFid] setting(s) to be applied and resets the values in MSRC001 00[68:64].
- 15. Copy MSRC001 00[68:64][CpuVid] to MSRC001 00[68:64][NbVid] for every core in the system.
- 16. For each processor in the system, transition all cores to MSRC001\_0071[StartupPstate] using MSRC001\_0063[PstateCmd].

#### 2.4.2.7 Processor-Systemboard Power Delivery Compatibility Check

BIOS must disable processor P-states that require higher power delivery than the systemboard can support. This power delivery compatibility check is designed to prevent system failures caused by exceeding the power delivery capability of the systemboard for the power plane(s) that contain the core(s). Refer to section 2.4.1 [Processor Power Planes And Voltage Control] on page 25 for power plane definitions and configuration information. BIOS should perform this check independently for each processor node in the coherent fabric. BIOS can optionally notify the user if P-states are detected that exceed the systemboard power delivery capability. Modifications to [The P-State [4:0] Registers] MSRC001\_00[68:64] must be applied equally to all cores on the same processor node. Note that this check does not guarantee functionality for all package/socket compatible processor/systemboard combinations.

MSRC001\_00[68:64][PstateEn] must be set to 0 for any P-state MSR where PstateEn=1 and the processor current requirement (ProcIddMax), defined by the following equation, is greater than the systemboard current

delivery capability.

```
ProcIddMax = MSRC001_00[68:64][IddValue] * 1/10^MSRC001_00[68:64][IddDiv] * (F3xE8[CmpCap]+1);
```

The power delivery check should be applied starting with P0 and continue with increasing P-state indexes (1, 2, 3, and 4) for all enabled P-states. Once a compatible P-state is found using the ProcIddMax equation the check is complete. All processor P-states with higher indexes are defined to be lower power and performance, and are therefore compatible with the systemboard.

Single or dual power plane P1 example:

- MSRC001\_0065[IddValue] = 32d
- MSRC001\_0065[IddDiv] = 0d
- F3xE8 [CmpCap] = 1d
- ProcIddMax = 32 \* 1 \* 2 \* 1 = 64 A per plane

The systemboard must be able to supply >= 64 A per plane for the unified core power plane in order to support P1 for this processor. If the systemboard current delivery capability is < 64 A per plane then BIOS must set MSRC001\_0065[PstateEn]=0 for all cores on this processor node, and continue by checking P2 in the same fashion.

If no P-states are disabled on a processor node while performing the power delivery compatibility check then BIOS does not need to take any action.

If at least one P-state is disabled on a processor node by performing the power delivery compatibility check and at least one P-state remains enabled for that processor node, then BIOS must perform the following steps:

- 1. If the P-state pointed to by MSRC001\_0063[CurPstate] is disabled by the power delivery compatibility check, then BIOS must request a transition to an enabled P-state using MSRC001\_0062[PstateCmd] and wait for MSRC001\_0063[CurPstate] to reflect the new value.
- 2. Copy the contents of the enabled P-state MSRs (MSRC001\_00[68:64]) to the highest performance P-state locations. E.g. if P0 and P1 are disabled by the power delivery compatibility check and P2 P4 remain enabled, then the contents of P2 P4 should be copied to P0 P2 and P3 and P4 should be disabled (PstateEn=0).
- 3. Request a P-state transition to the P-state MSR containing the COF/VID values currently applied. E.g. If MSRC001\_0063[CurPstate]=100b and P4 P-state MSR information is copied to P2 in step 2, then BIOS should write 010b to MSRC001\_0062[PstateCmd] and wait for MSRC001\_0063[CurPstate] to reflect the new value.
- 4. Adjust the following P-state parameters affected by the P-state MSR copy by subtracting the number of P-states that are disabled by the power delivery compatibility check. This calculation should not wrap, but saturate at 0. E.g. if P0 and P1 are disabled, then each of the following register fields should have 2 subtracted from them:
  - F3x64[HtcPstateLimit]
  - F3x68[StcPstateLimit]
  - F3xDC[PstateMaxVal]

If any processor node has all P-states disabled after performing the power delivery compatibility check, then BIOS must perform the following steps. Note that this does not guarantee operation, and that BIOS should notify the user of the incompatibility between the processor and systemboard if possible.

1. If MSRC001\_0063[CurPstate] != F3xDC[PstateMaxVal], then write F3xDC[PstateMaxVal] to MSRC001\_0062[PstateCmd] and wait for MSRC001\_0063[CurPstate] to reflect the new value.

- 2. If F3xDC[PstateMaxVal] != 000b copy the contents of the P-state MSR pointed to by F3xDC[PstateMax-Val] to MSRC001\_0064 and set MSRC001\_0064[PstateEn]; Write 000b to MSRC001\_0062[PstateCmd] and wait for MSRC001\_0063[CurPstate] to reflect the new value.
- 3. Adjust the following fields to 000b.
  - F3x64[HtcPstateLimit]
  - F3x68[StcPstateLimit]
  - F3xDC[PstateMaxVal]

### 2.4.2.8 Mixed-Frequency and Power P-State Configuration

Processors with different P-state CPU COFs and powers can be mixed in a system. All CPU cores must have the same number of P-states, and all equivalent P-states must have identical ACPI CoreFreq and Power settings. The CoreFreq and Power values are derived from MSRC001\_00[68:64][PstateEn, CpuFid, CpuDid, IddDiv, and IddValue] using the formulas described in section 2.4.2.9.2 [\_PSS (Performance Supported States)] on page 44.

- If MSRC001\_00[68:64][PstateEn, CpuFid, CpuDid, IddDiv, and IddValue] are identical for all processors, no BIOS modifications to [The P-State [4:0] Registers] MSRC001\_00[68:64] are necessary.
- If MSRC001\_00[68:64][PstateEn,CpuFid, or CpuDid] differs between processors, sections 2.4.2.8.2 [Mixed Frequency and Power P-State Configuration Rules] on page 38 and 2.4.2.8.3 [Mixed Frequency and Power P-State Configuration Sequence] on page 39 are used to determine the common set of P-states and define the required BIOS modifications to [The P-State [4:0] Registers] MSRC001\_00[68:64].
- If MSRC001\_00[68:64][IddDiv or IddValue] differs between processors and MSRC001\_00[68:64][PstateEn,CpuFid, and CpuDid] do not differ between processors, section 2.4.2.8.1 [Mixed Power P-State Configuration Sequence] on page 38 defines the required BIOS modifications to [The P-State [4:0] Registers] MSRC001\_00[68:64].

#### 2.4.2.8.1 Mixed Power P-State Configuration Sequence

BIOS must match the MSRC001\_00[68:64][IddDiv and IddValue] fields for each P-state across all processors using the following sequence. For each MSRC001\_00[68:64] with PstateEn=1:

- 1. Read IddDiv and IddValue for all processors.
- 2. Calculate the resulting power for each processor using the formula documented in 2.4.2.9.2 [\_PSS (Performance Supported States)] on page 44.
- 3. Identify the highest power for all processors.
- 4. Program IddDiv and IddValue for all processors equal to the values for the processor with the highest calculated power.

#### 2.4.2.8.2 Mixed Frequency and Power P-State Configuration Rules

- Processors with only one enabled P-state (F3xDC[PstateMaxVal]=000b) cannot be mixed in a system with processors with more than one enabled P-state (F3xDC[PstateMaxVal]!=000b).
- Processors with F3xE8[HTC Capable]=1 cannot be mixed in a system with processors with F3xE8[HTC Capable]=0.
- The maximum performance P-state (P0) CPU COF for the system is equivalent to the lowest P0 CPU COF for any processor in the system.
- The number of P-states for the system is equivalent to, or lower than, the least number of P-states for any processor in the system.
- All CPU COF calculations are rounded to the nearest 100 MHz frequency for the purposes of frequency

matching.

- The CPU COF for any enabled P-state can be lowered by modifying the MSRC001\_00[68:64][CpuFid] field from the cold reset value.
- The power for any enabled P-state can be modified by writing to MSRC001\_00[68:64][IddDiv, IddValue].
- P-states can be invalidated by setting MSRC001\_00[68:64][PstateEn]=0.
- MSRC001\_00[68:64][CpuDid, CpuVid, NbDid, NbVid] cold reset values are not modified by the mixed frequency P-state configuration sequence for any P-state.
- No P-state changes are allowed until all appropriate steps of the sequence are complete.

# 2.4.2.8.3 Mixed Frequency and Power P-State Configuration Sequence

- 1. Verify the rules in section 2.4.2.8.2 [Mixed Frequency and Power P-State Configuration Rules] on page 38 regarding F3xDC[PstateMaxVal] and F3xE8[HTC Capable] for all processors.
- 2. Match P0 CPU COF for all CPU cores to the lowest P0 CPU COF value in the coherent fabric, and match P0 power for all CPU cores to the highest P0 power value in the coherent fabric.
  - If all processors have only 1 enabled P-state BIOS must write the appropriate CpuFid value resulting from the matched CPU COF to all copies of MSRC001\_0070[CpuFid], and exit the sequence (no further steps are executed).

**Table 6: Representative mixed frequency P-state table example (step 2)** 

| MSR   |                              | Cold Reset                   |                              |                      |                              | Post-Step 2                  |                              |                      |  |
|-------|------------------------------|------------------------------|------------------------------|----------------------|------------------------------|------------------------------|------------------------------|----------------------|--|
| Marvi | Processor 0                  | Processor 1                  | Processor 2                  | Processor 3          | Processor 0                  | Processor 1                  | Processor 2                  | Processor 3          |  |
| P0    | 2.5 GHz                      | 2.7 GHz                      | 3.2 GHz                      | 2.5 GHz              | 2.5 GHz                      | 2.5 GHz                      | <b>2.5 GHz</b>               | 2.5 GHz              |  |
|       | 90 W                         | 90 W                         | 100 W                        | 70 W                 | 100 W                        | 100 W                        | 100 W                        | 100 W                |  |
| P1    | 2.2 GHz <sup>1</sup>         | 2.4 GHz                      | 3.0 GHz <sup>1</sup>         | 2.3 GHz <sup>1</sup> | 2.2 GHz <sup>1</sup>         | 2.4 GHz                      | 3.0 GHz <sup>1</sup>         | 2.3 GHz <sup>1</sup> |  |
|       | 80 W                         | 80 W                         | 90 W                         | 60 W                 | 80 W                         | 80 W                         | 90 W                         | 60 W                 |  |
| P2    | 1.8 GHz                      | 2.2 GHz <sup>1</sup>         | 2.4 GHz                      | 1.8 GHz              | 1.8 GHz                      | 2.2 GHz <sup>1</sup>         | 2.4 GHz                      | 1.8 GHz              |  |
|       | 70 W                         | 70 W                         | 80 W                         | 50 W                 | 70 W                         | 70 W                         | 80 W                         | 50 W                 |  |
| Р3    | 1.2 GHz                      | 1.0 GHz                      | 1.6 GHz                      | 500 MHz <sup>2</sup> | 1.2 GHz                      | 1.0 GHz                      | 1.6 GHz                      | 500 MHz <sup>2</sup> |  |
|       | 60 W                         | 60 W                         | 70 W                         | 40 W                 | 60 W                         | 60 W                         | 70 W                         | 40 W                 |  |
| P4    | 500 MHz <sup>2</sup><br>50 W | 600 MHz <sup>2</sup><br>50 W | 500 MHz <sup>2</sup><br>60 W | N/A <sup>3</sup>     | 500 MHz <sup>2</sup><br>50 W | 600 MHz <sup>2</sup><br>50 W | 500 MHz <sup>2</sup><br>60 W | N/A <sup>3</sup>     |  |

Refer to Table 11 for notes.

- 3. Match the CPU COF and power for P-states used by HTC:
  - Skip to step 4 if any processor reports F3xE8[HTC Capable]=0.
  - Set F3x64[HtcPstateLimit]=001b and F3x68[StcPstateLimit]=001b for processors with F3x64[HtcPstateLimit]=000b.
  - Identify the lowest CPU COF for all processors in the P-state pointed to by [The Hardware Thermal Control (HTC) Register] F3x64[HtcPstateLimit].
  - Modify the CPU COF pointed to by [The Hardware Thermal Control (HTC) Register] F3x64[HtcPstate-Limit] to the previously identified lowest CPU COF value.
  - Identify the highest power for all processors in the P-state pointed to by [The Hardware Thermal Control (HTC) Register] F3x64[HtcPstateLimit].
  - Modify the power pointed to by [The Hardware Thermal Control (HTC) Register] F3x64[HtcPstateLimit] to the previously identified highest power value.

| MSR |                              | Cold Reset                   |                              |                              |                              | Post-Step 3                  |                                         |                              |  |
|-----|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|-----------------------------------------|------------------------------|--|
| MSK | Processor 0                  | Processor 1                  | Processor 2                  | Processor 3                  | Processor 0                  | Processor 1                  | Processor 2                             | Processor 3                  |  |
| P0  | 2.5 GHz<br>90 W              | 2.7 GHz<br>90 W              | 3.2 GHz<br>100 W             | 2.5 GHz<br>70 W              | 2.5 GHz<br>100 W             | 2.5 GHz<br>100 W             | 2.5 GHz<br>100 W                        | 2.5 GHz<br>100 W             |  |
| P1  | 2.2 GHz <sup>1</sup><br>80 W | 2.4 GHz<br>80 W              | 3.0 GHz <sup>1</sup><br>90 W | 2.3 GHz <sup>1</sup><br>60 W | 2.2 GHz <sup>1</sup><br>90 W | 2.4 GHz<br>80 W              | <b>2.2</b> <i>GHz</i> <sup>1</sup> 90 W | 2.2 GHz <sup>1</sup><br>90 W |  |
| P2  | 1.8 GHz<br>70 W              | 2.2 GHz <sup>1</sup><br>70 W | 2.4 GHz<br>80 W              | 1.8 GHz<br>50 W              | 1.8 GHz<br>70 W              | 2.2 GHz <sup>1</sup><br>90 W | 2.4 GHz<br>80 W                         | 1.8 GHz<br>50 W              |  |
| Р3  | 1.2 GHz<br>60 W              | 1.0 GHz<br>60 W              | 1.6 GHz<br>70 W              | 500 MHz <sup>2</sup><br>40 W | 1.2 GHz<br>60 W              | 1.0 GHz<br>60 W              | 1.6 GHz<br>70 W                         | 500 MHz <sup>2</sup><br>40 W |  |
| P4  | 500 MHz <sup>2</sup><br>50 W | 600 MHz <sup>2</sup><br>50 W | 500 MHz <sup>2</sup><br>60 W | N/A <sup>3</sup>             | 500 MHz <sup>2</sup><br>50 W | 600 MHz <sup>2</sup><br>50 W | 500 MH <sup>2</sup> z<br>60 W           | N/A <sup>3</sup>             |  |

**Table 7: Representative mixed frequency P-state table example (step 3)** 

Refer to Table 11 for notes.

- 4. Match the CPU COF and power for the lowest performance P-state:
  - If F3xDC[PstateMaxVal] = F3x64[HtcPstateLimit] for any processor, set PstateEn=0 for all P-states greater than the P-state pointed to by F3x64[HtcPstateLimit] for all processors.
  - Identify the lowest CPU COF for all processors in the P-state pointed to by F3xDC[PstateMaxVal].
  - Modify the CPU COF for all processors in the P-state pointed to by F3xDC[PstateMaxVal] to the previously identified lowest CPU COF value.
  - Identify the highest power for all processors in the P-state pointed to by F3xDC[PstateMaxVal].
  - Modify the power for all processors in the P-state pointed to by F3xDC[PstateMaxVal] to the previously identified highest power value.

Table 8: Representative mixed frequency P-state table example (step 4)

| MSR |                              | Cold Reset                   |                              |                              |                                  | Post-Step 4                  |                                  |                                  |  |
|-----|------------------------------|------------------------------|------------------------------|------------------------------|----------------------------------|------------------------------|----------------------------------|----------------------------------|--|
| MSK | Processor 0                  | Processor 1                  | Processor 2                  | Processor 3                  | Processor 0                      | Processor 1                  | Processor 2                      | Processor 3                      |  |
| P0  | 2.5 GHz<br>90 W              | 2.7 GHz<br>90 W              | 3.2 GHz<br>100 W             | 2.5 GHz<br>70 W              | 2.5 GHz<br>100 W                 | 2.5 GHz<br>100 W             | 2.5 GHz<br>100 W                 | 2.5 GHz<br>100 W                 |  |
| P1  | 2.2 GHz <sup>1</sup><br>80 W | 2.4 GHz<br>80 W              | 3.0 GHz <sup>1</sup><br>90 W | 2.3 GHz <sup>1</sup><br>60 W | 2.2 GHz <sup>1</sup><br>90 W     | 2.4 GHz<br>80 W              | 2.2 <i>GHz</i> <sup>1</sup> 90 W | 2.2 GHz <sup>1</sup><br>90 W     |  |
| P2  | 1.8 GHz<br>70 W              | 2.2 GHz <sup>1</sup><br>70 W | 2.4 GHz<br>80 W              | 1.8 GHz<br>50 W              | 1.8 GHz<br>70 W                  | 2.2 GHz <sup>1</sup><br>90 W | 2.4 GHz<br>80 W                  | 1.8 GHz<br>50 W                  |  |
| Р3  | 1.2 GHz<br>60 W              | 1.0 GHz<br>60 W              | 1.6 GHz<br>70 W              | 500 MHz <sup>2</sup><br>40 W | 1.2 GHz<br>60 W                  | 1.0 GHz<br>60 W              | 1.6 GHz<br>70 W                  | 500 MHz <sup>2</sup> <b>60 W</b> |  |
| P4  | 500 MHz <sup>2</sup><br>50 W | 600 MHz <sup>2</sup><br>50 W | 500 MHz <sup>2</sup><br>60 W | N/A <sup>3</sup>             | 500 MHz <sup>2</sup> <b>60 W</b> | 500 MHz <sup>2</sup><br>60 W | 500 MHz <sup>2</sup><br>60 W     | N/A <sup>3</sup>                 |  |

Refer to Table 11 for notes.

- 5. Modify F3xDC[PstateMaxVal] to indicate the lowest performance P-state with PstateEn set for each processor (step 4 can disable P-states pointed to by F3xDC[PstateMaxVal]).
- 6. Match the CPU COF and power for upper intermediate P-states:
  - Upper intermediate P-states = P-states between (not including) P0 and F3x64[HtcPstateLimit].
  - If F3x64[HtcPstateLimit] = 001b for any processor, set PstateEn=0 for enabled upper intermediate P-

states for all processors with F3x64[HtcPstateLimit] > 001b and skip the remaining actions for this numbered step.

- Define each of the available upper intermediate P-states; for each processor concurrently evaluate the following loop; when any processor falls out of the loop (runs out of available upper intermediate P-states) all other processors have their remaining upper intermediate P-states invalidated (PstateEn=0); for (i = F3x64[HtcPstateLimit]-1; i > 0; i--)
  - Identify the lowest CPU COF for P(i).
  - Identify the highest power for P(i).
  - Modify P(i) CPU COF for all processors to the previously identified lowest CPU COF value.
  - Modify P(i) power for all processors to the previously identified highest power value.

Table 9: Representative mixed frequency P-state table example (step 6)

| MSR |                              | Cold                         | Reset                        |                              | Post-Step 6                  |                              |                              |                              |
|-----|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|
| MSK | Processor 0                  | Processor 1                  | Processor 2                  | Processor 3                  | Processor 0                  | Processor 1                  | Processor 2                  | Processor 3                  |
| P0  | 2.5 GHz<br>90 W              | 2.7 GHz<br>90 W              | 3.2 GHz<br>100 W             | 2.5 GHz<br>70 W              | 2.5 GHz<br>100 W             | 2.5 GHz<br>100 W             | 2.5 GHz<br>100 W             | 2.5 GHz<br>100 W             |
| P1  | 2.2 GHz <sup>1</sup><br>80 W | 2.4 GHz<br>80 W              | 3.0 GHz <sup>1</sup><br>90 W | 2.3 GHz <sup>1</sup><br>60 W | 2.2 GHz <sup>1</sup><br>90 W | <b>N/A</b> <sup>3</sup>      | 2.2 GHz <sup>1</sup><br>90 W | 2.2 GHz <sup>1</sup><br>90 W |
| P2  | 1.8 GHz<br>70 W              | 2.2 GHz <sup>1</sup><br>70 W | 2.4 GHz<br>80 W              | 1.8 GHz<br>50 W              | 1.8 GHz<br>70 W              | 2.2 GHz <sup>1</sup><br>90 W | 2.4 GHz<br>80 W              | 1.8 GHz<br>50 W              |
| Р3  | 1.2 GHz<br>60 W              | 1.0 GHz<br>60 W              | 1.6 GHz<br>70 W              | 500 MHz <sup>2</sup><br>40 W | 1.2 GHz<br>60 W              | 1.0 GHz<br>60 W              | 1.6 GHz<br>70 W              | 500 MHz <sup>2</sup><br>60 W |
| P4  | 500 MHz <sup>2</sup><br>50 W | 600 MHz <sup>2</sup><br>50 W | 500 MHz <sup>2</sup><br>60 W | N/A <sup>3</sup>             | 500 MHz <sup>2</sup><br>60 W | 500 MHz <sup>2</sup><br>60 W | 500 MHz <sup>2</sup><br>60 W | N/A <sup>3</sup>             |

Refer to Table 11 for notes.

#### Example description:

F3x64[HtcPstateLimit] = 001b for processors 0, 2, and 3. Therefore, the conditions of the first bullet are satisfied and processor 1 must have P1 invalidated (remaining upper intermediate P-state). Execution skips to the next numbered step.

- 7. Match the CPU COF and power for lower intermediate P-states:
  - Lower intermediate P-states = P-states between (not including) F3x64[HtcPstateLimit] and F3xDC[PstateMaxVal]
  - If F3xDC[PstateMaxVal] F3x64[HtcPstateLimit] < 2 for any processor, set PstateEn=0 for enabled lower intermediate P-states for all processors with F3xDC[PstateMaxVal] F3x64[HtcPstateLimit] > 1 and skip the remaining actions for this numbered step.
  - Define each of the available lower intermediate P-states; for each processor concurrently evaluate the following loop; when any processor falls out of the loop (runs out of available lower intermediate P-states) all other processors have their remaining lower intermediate P-states invalidated (PstateEn=0); for (i = F3xDC[PstateMaxVal]-1; i > F3x64[HtcPstateLimit]; i--)
    - Identify the lowest CPU COF for P(i).
    - Identify the highest power P(i).
    - Modify P(i) CPU COF for all processors to the previously identified lowest CPU COF value.
    - Modify P(i) power for all processors to the previously identified highest power value.

| MSR |                              | Cold Reset                   |                              |                              |                                  | Post-Step 7                  |                                  |                              |  |
|-----|------------------------------|------------------------------|------------------------------|------------------------------|----------------------------------|------------------------------|----------------------------------|------------------------------|--|
| MSK | Processor 0                  | Processor 1                  | Processor 2                  | Processor 3                  | Processor 0                      | Processor 1                  | Processor 2                      | Processor 3                  |  |
| P0  | 2.5 GHz<br>90 W              | 2.7 GHz<br>90 W              | 3.2 GHz<br>100 W             | 2.5 GHz<br>70 W              | 2.5 GHz<br>100 W                 | 2.5 GHz<br>100 W             | 2.5 GHz<br>100 W                 | 2.5 GHz<br>100 W             |  |
| P1  | 2.2 GHz <sup>1</sup><br>80 W | 2.4 GHz<br>80 W              | 3.0 GHz <sup>1</sup><br>90 W | 2.3 GHz <sup>1</sup><br>60 W | 2.2 GHz <sup>1</sup><br>90 W     | <i>N/A</i> <sup>3</sup>      | 2.2 <i>GHz</i> <sup>1</sup> 90 W | 2.2 GHz <sup>1</sup><br>90 W |  |
| P2  | 1.8 GHz<br>70 W              | 2.2 GHz <sup>1</sup><br>70 W | 2.4 GHz<br>80 W              | 1.8 GHz<br>50 W              | <i>N</i> / <i>A</i> <sup>3</sup> | 2.2 GHz <sup>1</sup><br>90 W | <b>N/A</b> <sup>3</sup>          | 1.0 GHz<br>70 W              |  |
| Р3  | 1.2 GHz<br>60 W              | 1.0 GHz<br>60 W              | 1.6 GHz<br>70 W              | 500 MHz <sup>2</sup><br>40 W | 1.0 GHz<br>70 W                  | 1.0 GHz<br><b>70 W</b>       | <b>1.0 GHz</b><br>70 W           | 500 MHz <sup>2</sup><br>60 W |  |
| P4  | 500 MHz <sup>2</sup><br>50 W | 600 MHz <sup>2</sup><br>50 W | 500 MHz <sup>2</sup><br>60 W | N/A <sup>3</sup>             | 500 MHz <sup>2</sup><br>60 W     | 500 MHz <sup>2</sup><br>60 W | 500 MHz <sup>2</sup><br>60 W     | N/A <sup>3</sup>             |  |

**Table 10: Representative mixed frequency P-state table example (step 7)** 

Refer to Table 11 for notes.

## Example description:

F3xDC[PstateMaxVal] - F3x64[HtcPstateLimit] > 1 for all processors. Therefore, the conditions of the first bullet are not met and execution continues to bullet two.

Loop index i initializes to:

P3 for processors 0, 1, and 2

P2 for processor 3

On the first iteration of the loop processor 1 has the lowest CPU COF of 1.0 GHz for P(i), and processor 2 has the highest power of 70 W for P(i). The P(i) values of each processor are modified to 1.0 GHz and 70 W. The loop index i is decremented for all processors.

Processor 1 fails the loop index test of i > F3x64[HtcPstateLimit] with i = 2 and F3x64[HtcPstateLimit] = 2. Processor 3 fails the loop index test of i > F3x64[HtcPstateLimit] with i = 1 and F3x64[HtcPstateLimit] = 1. P2 is invalidated for processors 0 and 2 (remaining lower intermediate P-state).

Execution skips to the next numbered step.

- 8. Place all cores into a valid COF and VID configuration corresponding to an enabled P-state:
  - Select an enabled P-state != to the P-state pointed to by MSRC001\_0063[CurPstate] for each core.
  - Transition all cores to the selected P-states by writing the Control value from the \_PSS object corresponding to the selected P-state to MSRC001\_0062[PstateCmd].
  - Wait for all cores to report the Status value from the \_PSS object corresponding to the selected P-state in MSRC001\_0063[CurPstate].

| MSR   |                              | Cold Reset                   |                              |                              |                              | Post-Algorithm                   |                                  |                              |  |
|-------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|----------------------------------|----------------------------------|------------------------------|--|
| MISIX | Processor 0                  | Processor 1                  | Processor 2                  | Processor 3                  | Processor 0                  | Processor 1                      | Processor 2                      | Processor 3                  |  |
| P0    | 2.5 GHz<br>90 W              | 2.7 GHz<br>90 W              | 3.2 GHz<br>100 W             | 2.5 GHz<br>70 W              | 2.5 GHz<br>100 W             | 2.5 GHz<br>100 W                 | 2.5 GHz<br>100 W                 | 2.5 GHz<br>100 W             |  |
| P1    | 2.2 GHz <sup>1</sup><br>80 W | 2.4 GHz<br>80 W              | 3.0 GHz <sup>1</sup><br>90 W | 2.3 GHz <sup>1</sup><br>60 W | 2.2 GHz <sup>1</sup><br>90 W | <i>N</i> / <i>A</i> <sup>3</sup> | 2.2 GHz <sup>1</sup><br>90 W     | 2.2 GHz <sup>1</sup><br>90 W |  |
| P2    | 1.8 GHz<br>70 W              | 2.2 GHz <sup>1</sup><br>70 W | 2.4 GHz<br>80 W              | 1.8 GHz<br>50 W              | <i>N/A</i> <sup>3</sup>      | 2.2 GHz <sup>1</sup><br>90 W     | <i>N</i> / <i>A</i> <sup>3</sup> | 1.0 GHz<br>70 W              |  |
| Р3    | 1.2 GHz<br>60 W              | 1.0 GHz<br>60 W              | 1.6 GHz<br>70 W              | 500 MHz <sup>2</sup><br>40 W | 1.0 GHz<br>70 W              | 1.0 GHz<br>70 W                  | 1.0 GHz<br>70 W                  | 500 MHz <sup>2</sup><br>60 W |  |
| P4    | 500 MHz <sup>2</sup><br>50 W | 600 MHz <sup>2</sup><br>50 W | 500 MHz <sup>2</sup><br>60 W | N/A <sup>3</sup>             | 500 MHz <sup>2</sup><br>60 W | 500 MHz <sup>2</sup><br>60 W     | 500 MHz <sup>2</sup><br>60 W     | N/A <sup>3</sup>             |  |

**Table 11: Representative mixed frequency P-state table example (final)** 

### Notes:

- 1) Indicates the P-state pointed to by F3x64[HtcPstateLimit].
- 2) Indicates the P-state pointed to by F3xDC[PstateMaxVal].
- 3) N/A indicates a P-state with MSRC001\_00[68:64][PstateEn]=0.

Italics indicates values modified by the mixed frequency P-state algorithm from the cold reset value.

**Bold Italics** indicates values modified by this step of the mixed frequency P-state algorithm from the cold reset value.

MSRC001\_00[68:64][CpuVid, NbVid, NbDid] are not modified by the mixed frequency P-state algorithm and are not shown.

Table 12: Representative mixed frequency \_PSS object example

| P-state | Post-Algorithm _PSS                                          |                                                              |                                                              |                                                              |  |  |  |  |
|---------|--------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------|--|--|--|--|
| r-state | Processor 0                                                  | Processor 1                                                  | Processor 2                                                  | Processor 3                                                  |  |  |  |  |
| 0       | CoreFreq = 2.5 GHz<br>Power = 100 W<br>Control = Status = 0h | CoreFreq = 2.5 GHz<br>Power = 100 W<br>Control = Status = 0h | CoreFreq = 2.5 GHz<br>Power = 100 W<br>Control = Status = 0h | CoreFreq = 2.5 GHz<br>Power = 100 W<br>Control = Status = 0h |  |  |  |  |
| 1       | CoreFreq = 2.2 GHz* Power = 90 W Control = Status = 1h       | CoreFreq = 2.2 GHz*<br>Power = 90 W<br>Control = Status = 2h | CoreFreq = 2.2 GHz* Power = 90 W Control = Status = 1h       | CoreFreq = 2.2 GHz*<br>Power = 90 W<br>Control = Status = 1h |  |  |  |  |
| 2       | CoreFreq = 1.0 GHz<br>Power = 70 W<br>Control = Status = 3h  | CoreFreq = 1.0 GHz<br>Power = 70 W<br>Control = Status = 3h  | CoreFreq = 1.0 GHz<br>Power = 70 W<br>Control = Status = 3h  | CoreFreq = 1.0 GHz<br>Power = 70 W<br>Control = Status = 2h  |  |  |  |  |
| 3       | CoreFreq = 500 MHz $Power = 60 W$ $Control = Status = 4h$    | CoreFreq = 500 MHz<br>Power = 60 W<br>Control = Status = 4h  | CoreFreq = 500 MHz $Power = 60 W$ $Control = Status = 4h$    | CoreFreq = 500 MHz<br>Power = 60 W<br>Control = Status = 3h  |  |  |  |  |

#### Notes:

Refer to section 2.4.2.9.2 [\_PSS (Performance Supported States)] on page 44 for details on \_PSS object creation and field definitions for CoreFreq, Power, Control, and Status.

TransitionLatency and BusMasterLatency are not modified by the by the mixed frequency P-state algorithm and are not shown.

<sup>\*</sup> Indicates the P-state pointed to by F3x64[HtcPstateLimit] at cold reset.

Units are not indicative of the conventions required by the ACPI \_PSS object. Refer to section 2.4.2.9.2 [\_PSS (Performance Supported States)] on page 44 for details on \_PSS object creation.

# 2.4.2.9 ACPI Processor P-State Objects

ACPI 2.0 and ACPI 3.0 processor performance control for processors reporting CPUID Fn8000\_0007[HwP-state]=1 is implemented through two objects whose presence indicates to the OS that the platform and CPU are capable of supporting multiple performance states. Processor performance states are not supported with ACPI 1.0b. BIOS must provide the \_PCT object, \_PSS object, and define other ACPI parameters to support operating systems that provide native support for processor P-state transitions. Other optional ACPI objects are also described in the following sections.

The following rules apply to BIOS generated ACPI objects. Refer to the appropriate ACPI specification (http://www.acpi.info) for additional details:

- In a multiprocessing environment, all CPUs must support the same number of performance states
- Each processor performance state must have identical performance and power-consumption parameters
- Performance objects must be present under each processor object in the system

### **2.4.2.9.1 PCT** (Performance Control)

BIOS must declare the performance control object parameters as functional fixed hardware. This definition indicates the processor driver understands the architectural definition of the P-state interface associated with CPUID Fn8000\_0007[HwPstate]=1.

- Perf Ctrl Register = Functional Fixed Hardware
- Perf\_Status\_Register = Functional Fixed Hardware

### 2.4.2.9.2 PSS (Performance Supported States)

A unique \_PSS entry is created for each P-state. BIOS must loop through each of [The P-State [4:0] Registers] MSRC001\_00[68:64] applying the formulas for CoreFreq and Power, and assigning Control and Status appropriately for enabled P-states (PstateEn=1). The TransitionLatency and BusMasterLatency values can be calculated once for each processor and applied to all PSS entries for CPU cores on that processor.

The value contained in the Control field is written to [The P-State Control Register] MSRC001\_0062 to request a P-state change to the CoreFreq of the associated \_PSS object. The value in the Control field is a direct indication of the P-state register (MSRC001\_00[68:64]) that contains the COF and VID settings for the associated P-state. The value contained in [The P-State Status Register] MSRC001\_0063 can be used to identify the \_PSS object of the current P-state by equating MSRC001\_0063[CurPstate] to the value of the Status field. Refer to section 2.4.2 [P-states] on page 31 for further details on P-state definition and behavior.

- CoreFreq (MHz) = Calculated using the formula for 'CPU COF' documented in MSRC001\_00[68:64][Cpu-Fid]. All CoreFreq values must be rounded to the nearest 100 MHz frequency resulting in a maximum of 50 MHz frequency difference between the reported CoreFreq and calculated CPU COF.
- Power (mW)
  - Convert MSRC001\_00[68:64][CpuVid] to a voltage by referring to section 2.4.1.6 [VID Encodings] on page 27
  - Power(mW) = voltage \* MSRC001\_00[68:64][IddValue] \* 1/10^MSRC001\_00[68:64][IddDiv] \* 1000

- TransitionLatency (us) and BusMasterLatency (us)
  - If MSRC001\_00[68:64][CpuFid] is the same value for all P-states where MSRC001\_00[68:64][PstateEn]=1: TransitionLatency = BusMasterLatency = (15 steps \* F3xD4[PowerStepDown] ns/step / 1000 us/ns) + (15 steps \* F3xD4[PowerStepUp] ns/step / 1000 us/ns)
  - If MSRC001\_00[68:64][CpuFid] is different for any P-states where MSRC001\_00[68:64][PstateEn]=1: TransitionLatency = BusMasterLatency = (15 steps \* F3xD4[PowerStepDown] ns/step / 1000 us/ns) + F3xA0[PllLockTime] us + (15 steps \* F3xD4[PowerStepUp] ns/step / 1000 us/ns)

#### Example:

```
MSRC001\_00[68:64][CpuFid] = 4h (2000 MHz) for P0, P3, and P4
```

 $MSRC001\_00[68:64][CpuFid] = 3h (1800 MHz)$ for P1

 $MSRC001\_00[68:64][CpuFid] = 2h (1600 MHz)$ for P2

F3xD4[PowerStepDown] = F3xD4[PowerStepUp] = 8h (50 ns/step)

F3xA0[PllLockTime] = 011b (4 us)

TransitionLatency = BusMasterLatency = (15 steps \* 50 ns/step / 1000 us/ns) + 4 us + (15 steps \* 50 ns/step / 1000 us/ns) = 5.5 us (round up to 6 us)

- Control
  - If MSRC001\_0064 (P0): Control = 0000\_0000h
  - If MSRC001\_0065 (P1): Control = 0000\_0001h
  - If MSRC001\_0066 (P2): Control = 0000\_0002h
  - If MSRC001\_0067 (P3): Control = 0000\_0003h
  - If MSRC001\_0068 (P4): Control = 0000\_0004h
- Status
  - If MSRC001 0064 (P0): Status = 0000 0000h
  - If MSRC001\_0065 (P1): Status = 0000\_0001h
  - If MSRC001\_0066 (P2): Status = 0000\_0002h
  - If MSRC001 0067 (P3): Status = 0000 0003h
  - If MSRC001\_0068 (P4): Status = 0000\_0004h

## **2.4.2.9.3 PPC** (Performance Present Capabilities)

The PPC object is optional. Refer to the ACPI specification for details on use and content.

# 2.4.2.9.4 \_PSD (P-State Dependency)

The ACPI 3.0 PSD object is required be generated for each CPU core as follows:

- NumberOfEntries = 5.
- Revision = 0.
- Domain = CPUID Fn0000\_0001\_EBX[LocalApicId].
- CoordType = FDh. (SW ANY)
- NumProcessors = 1.

## 2.4.2.9.5 Fixed ACPI Description Table (FADT) Entries

BIOS must declare the following FADT entries as 0. BIOS-controlled P-state transitions, if any, must be performed near the beginning of the POST routine before control is passed to the operating system. All subsequent transitions are made by system software not the BIOS. System Management Mode is not used for P-state control.

- PSTATE CNT = 00h
- CST\_CNT = 00h

# 2.4.2.10 XPSS (Microsoft® Extended PSS) Object

Some Microsoft<sup>®</sup> operating systems require an XPSS object to make P-state changes function properly. A BIOS that implements an XPSS object has special requirements for the \_PCT object. See the Microsoft *Extended PSS ACPI Method Specification* for the detailed requirements to implement these objects.

#### 2.4.2.11 BIOS COF and VID Requirements After Warm Reset

Warm reset is asynchronous and can interrupt P-state transitions leaving the processor in a COF and VID state not specified in [The P-State [4:0] Registers] MSRC001\_00[68:64]. Refer to section 2.4.2.4 [P-state Transition Behavior] on page 33 for P-state transition behavior when RESET\_L is asserted. BIOS is required to transition the processor to valid COF and VID settings corresponding to an enabled P-state following warm reset. The CPU cores may be transitioned to either the maximum or minimum P-state COF and VID settings using the sequences defined in section 2.4.2.11.1 [CPU Core Maximum P-State Transition Sequence After Warm Reset] on page 46 and 2.4.2.11.2 [CPU Core Minimum P-State Transition Sequence After Warm Reset] on page 46. Transitioning to the minimum P-state after warm reset is recommended to prevent undesired system behavior if a warm reset occurs before the 2.4.2.7 [Processor-Systemboard Power Delivery Compatibility Check] on page 36 is complete. BIOS is not required to manipulate NB COF and VID settings following warm reset if the warm reset was issued by BIOS to update F3xD4[NbFid].

### 2.4.2.11.1 CPU Core Maximum P-State Transition Sequence After Warm Reset

- If F3xA0[PviMode]=0 transition MSRC001\_0070[CpuVid] to MSRC001\_0064[CpuVid]; else transition MSRC001\_0070[NbVid] to the lowest VID (greatest voltage) of MSRC001\_0064[CpuVid] and MSRC001\_0064[NbVid]. Refer to section 2.4.1.9 [Software-Initiated Voltage Transitions] on page 30 for additional rules.
- 2. Write 000b to MSRC001 0062[PstateCmd].
- 3. Wait for MSRC001\_0071[CurCpuFid] = MSRC001\_0064[CpuFid] and MSRC001\_0071[CurCpuDid] = MSRC001\_0068[CpuDid].
- 4. If required, transition the NB COF and VID to MSRC001\_0064[NbDid, NbVid] using the sequence defined in section 2.4.2.11.3 [NB COF and VID Transition Sequence After Warm Reset] on page 46.

## 2.4.2.11.2 CPU Core Minimum P-State Transition Sequence After Warm Reset

- 1. Copy F3xDC[PstateMaxVal] to MSRC001 0062[PstateCmd].
- 2. Wait for MSRC001\_0071[CurCpuFid] = CpuFid from [The P-State [4:0] Registers] MSRC001\_00[68:64] pointed to by F3xDC[PstateMaxVal] and MSRC001\_0071[CurCpuDid] = CpuDid from [The P-State [4:0] Registers] MSRC001\_00[68:64] pointed to by F3xDC[PstateMaxVal].
- 3. If F3xA0[PviMode]=0 transition MSRC001\_0070[CpuVid] to CpuVid from [The P-State [4:0] Registers] MSRC001\_00[68:64] pointed to by F3xDC[PstateMaxVal]; else transition MSRC001\_0070[NbVid] to the lowest VID (highest voltage) of NbVid and CpuVid from [The P-State [4:0] Registers] MSRC001\_00[68:64] pointed to by F3xDC[PstateMaxVal]. Refer to section 2.4.1.9 [Software-Initiated Voltage Transitions] on page 30 for additional rules.
- 4. If required, transition the NB COF and VID to NbDid and NbVid from [The P-State [4:0] Registers] MSRC001\_00[68:64] pointed to by F3xDC[PstateMaxVal] using the sequence defined in section 2.4.2.11.3 [NB COF and VID Transition Sequence After Warm Reset] on page 46.

## 2.4.2.11.3 NB COF and VID Transition Sequence After Warm Reset

If the destination NbDid=0:

1. Transition MSRC001\_0070[NbVid] to the destination NbVid using the sequence defined in section 2.4.1.9

[Software-Initiated Voltage Transitions] on page 30.

- 2. Write 0 to MSRC001\_0070[NbDid].
- 3. Wait for MSRC001\_0071[NbDid]=0.

#### If the destination NbDid=1:

- 1. Write 1 to MSRC001 0070[NbDid].
- 2. Wait for MSRC001\_0071[NbDid]=1.
- 3. Repeat steps 1 and 2 for all cores.
- 4. Transition MSRC001\_0070[NbVid] to the destination NbVid using the sequence defined in section 2.4.1.9 [Software-Initiated Voltage Transitions] on page 30.

### **2.4.3** C-states

C-states are processor power states in which the processor is powered but may or may not execute instructions. C0 is the operational state in which instructions are executed. All other C-states are low-power states in which instructions are not executed. The actions taken by the processor when a low-power state is entered are defined by [The ACPI Power State Control Registers] F3x[84:80]. C0 and C1 are ACPI-defined states, see the ACPI specification for details. C1E is an AMD specific state.

### **2.4.3.1 C1 Enhanced State (C1E)**

The C1 enhanced state (C1E) is a stop-grant state supported by the processor. The C1E state is characterized by the following properties:

- All cores are in the halt (C1) state.
- The ACPI-defined P LVL3 register has been accessed.
- The chipset has issued a STPCLK assertion message with the appropriate SMAF for C1E entry. Note that [The ACPI Power State Control Registers] F3x[84:80] specify the processor clocking and voltage behavior in response to the C1E SMAF.
- The processor has issued a STOP\_GRANT message to the chipset.

## General requirements for C1E:

- The ACPI-defined C2 and C3 states must not be declared to the operating system.
- C1E should only be enabled when the platform is in ACPI power management mode.
- C1E is only supported on single node systems.

### **2.4.3.1.1 SMI Initiated C1E**

When C1E is enabled and the processor detects that all cores have entered the halt state, the processor sends an IO write to the SMI command port in the chipset. This causes the chipset to generate an SMI. It is expected that the SMI targets all cores and therefore all cores enter SMM. The SMM handler may or may not place the system into the C1E state. See section 2.4.3.1.2.1 [SMM Handler Requirements for C1E] on page 48 for a description.

#### 2.4.3.1.2 BIOS Requirements to Initialize SMI Initiated C1E

#### On all cores:

- MSRC001 0055[SmiOnCmpHalt] = 1.
- $MSRC001\_0055[IORd] = 0$ .
- MSRC001\_0055[IOMsgAddr] = Address of the chipset's SMI command port.
- MSRC001 0055[IOMsgData] = Unique number used by the SMI handler to identify this SMI source.
- BIOS must also setup the SMM handler as described below.

# 2.4.3.1.2.1 SMM Handler Requirements for C1E

The system may have other SMM handler functions in addition to the C1E handler. If this is the case, they may be executed before or after the C1E handler.

The SMM handler on each AP should:

```
Read a value from the SMI command port
if (value == MSRC001_0055[IOMsgData])
{
   Wait for indication from the BSC to continue
}
Resume from SMM
```

The SMM handler on the BSC should:

```
Read a value from the SMI command port
if (value == MSRC001_0055[IOMsgData])
 Read SMMFEC9[HLT] on all cores
  if (SMMFEC9[HLT] == 1 on all cores)
   Set the BM RLD bit (bit 1) of the ACPI-defined PM1 control register
   Read the BM STS bit (bit 4) of the ACPI-defined PM1 status register
   if (BM STS == 1)
      Clear the BM_STS bit
     Store the value of the ACPI timer
      Issue IO read to the ACPI-defined P_LVL2 register
   else
     Read ACPI timer and compare to the last stored timer value
      if (time since last store value < 20ms)
        Issue IO read to the ACPI-defined P LVL2 register
      }
      else
        Set the ARB DIS bit (bit 0) of the ACPI-defined PM2 control register
        Issue an IO read to the ACPI-defined P_LVL3 register
  }
Resume from SMM
```

### 2.4.4 ACPI Suspend to RAM State (S3)

The processor supports the ACPI-defined S3 state. Software is responsible for restoring the state of the processor's registers when resuming from S3. All registers in the processor that BIOS initialized during the initial boot must be restored. The method used to restore the registers is system specific.

During S3 entry, system memory enters self-refresh mode. Software is responsible for bringing memory out of self-refresh mode when resuming from S3.

The following sequence must performed on each node. Steps 1 and 2 should only be performed once per node. When the DRAM controllers are operating in ganged mode (F2x110[DctGangEn]=1):

- Steps 3, 4, 5, 7, and 8 should only be performed on DCT0.
- Steps 6, 9 and 10 should be performed on both DCT0 and DCT1.
- 1. Restore [The DRAM Controller Select Low Register] F2x110.
- 2. Restore the following registers.
  - [The DRAM Base/Limit Registers] F1x[1, 0][7C:40]
  - [The DRAM Hole Address Register] F1xF0
  - [The DRAM Base System Address Register] F1x120
  - [The DRAM Limit System Address Register] F1x124
  - [The DRAM Controller Select High Register] F2x114
  - [The Memory Controller Configuration Low Register] F2x118
  - [The Memory Controller Configuration High Register] F2x11C
  - [The MCA NB Configuration Register] F3x44
  - [The Variable-Size MTRRs (MTRRphysBasen and MTRRphysMaskn)] MSR0000\_02[0F:00]
  - [The Fixed-Size MTRRs (MTRRfixn)] MSR0000\_02[6F:68, 59, 58, 50]
  - [The MTRR Default Memory Type Register (MTRRdefType)] MSR0000\_02FF
  - [The System Configuration Register (SYS CFG)] MSRC001 0010
  - [The Top Of Memory Register (TOP\_MEM)] MSRC001\_001A
  - [The Top Of Memory 2 Register (TOM2)] MSRC001\_001D
  - [The Northbridge Configuration Register (NB\_CFG)] MSRC001\_001F
- 3. Restore the following DCT registers.
  - [The DRAM CS Base Address Registers] F2x[1, 0][5C:40]
  - [The DRAM CS Mask Registers] F2x[1, 0][6C:60]
  - [The DRAM Control Register] F2x[1, 0]78
  - [The DRAM Initialization Register] F2x[1, 0]7C
  - [The DRAM Bank Address Mapping Register] F2x[1, 0]80
  - [The DRAM MRS Register] F2x[1, 0]84
  - [The DRAM Timing Low Register] F2x[1, 0]88
  - [The DRAM Timing High Register] F2x[1, 0]8C
  - [The DRAM Configuration Low Register] F2x[1, 0]90
  - [The DRAM Configuration High Register] F2x[1, 0]94
  - [The DRAM Controller Miscellaneous Register] F2x[1, 0]A0
  - [The DRAM Controller Miscellaneous Register 2] F2x[1, 0]A8
- 4. Restore F2x[1, 0]94[MemClkFreq] and F2x[1, 0]94[MemClkFreqVal].
- 5. Wait for F2x[1, 0]94[FreqChgInPrg]=0.
- 6. Restore F2x[1, 0]9C\_x00, F2x[1, 0]9C\_x04, F2x9C\_x0A, and F2x[1, 0]9C\_x0C.
- 7. Set F2x[1, 0]90[ExitSelfRef].
- 8. Wait for F2x[1, 0]90[ExitSelfRef]=0.
- 9. Restore the following registers before any accesses to DRAM are made:
  - [The DRAM Write Data Timing [High:Low] Registers] F2x[1, 0]9C\_x[102:101, 02:01]
  - [The DRAM Write ECC Timing Register] F2x[1, 0]9C\_x[103, 03]
  - [The DRAM Read DQS Timing Control [High:Low] Registers] F2x[1, 0]9C\_x[106:105, 06:05]
  - [The DRAM Read DQS ECC Timing Control Register] F2x[1, 0]9C\_x[107, 07]
  - [The DRAM Phy Predriver Calibration Register] F2x9C x0A
  - [The DRAM Phy Miscellaneous Register] F2x[1, 0]9C\_x0C
- 10. For DDR3, restore the following registers before any accesses to DRAM are made:

- [The DRAM DQS Receiver Enable Timing Control Registers] F2x[1, 0]9C\_x[2B:10]
- [The DRAM DQS Write Timing Control Registers] F2x[1, 0]9C\_x[45:30]
- [The DRAM Phase Recovery Control Register [High:Low] Registers] F2x[1, 0]9C\_x[51:50]
- [The DRAM ECC Phase Recovery Control Register] F2x[1, 0]9C\_x52
- [The Write Levelization Error Register] F2x[1, 0]9C\_x53

Many of the systemboard power planes for the processor are powered down during S3. Refer to section 2.4.1 [Processor Power Planes And Voltage Control] on page 25 for power plane descriptions. Refer to the EDS for S3 processor power plane sequencing requirements and system signal states for both inputs (e.g. PWROK, RESET\_L, and LDTSTOP\_L) and outputs (e.g. VID[\*], PSI\_L, THERMTRIP\_L, etc.) during S3. Refer to the HyperTransport<sup>TM</sup> link specification for signal sequencing requirements for PWROK, RESET\_L, and LDTSTOP\_L during S3 entry and exit, and system management message sequencing for S3 entry and exit.

#### 2.5 Processor State Transition Sequences

#### **2.5.1 ACPI Power State Transitions**

# 2.6 The Northbridge (NB)

Each processor includes a single Northbridge that provides the interface to the local CPU core(s), the interface to system memory, the interface to other processors, and the interface to system IO devices. The NB includes all power planes except VDD; see section 2.4.1 [Processor Power Planes And Voltage Control] on page 25 for more information.

The NB of each node is responsible for routing transactions sourced from CPU cores and links to the appropriate CPU core, cache, DRAM, or link. See section 2.9.3 [Access Type Determination] on page 107 for more information.

### 2.6.1 Northbridge (NB) Architecture

Major NB blocks are: System Request Interface (SRI), Memory Controller (MCT), DRAM Controllers (DCTs), L3 cache, and Cross Bar (XBAR). SRI interfaces with the CPU core(s). MCT maintains cache coherency and interfaces with the DCTs; MCT maintains a queue of incoming requests called MCQ. XBAR is a switch that routes packets between SRI, MCT, and the links.

The MCT operates on physical addresses. Before passing transactions to the DCTs, the MCT converts physical addresses into *normalized* addresses that correspond to the values programmed into [The DRAM CS Base Address Registers] F2x[1, 0][5C:40]. Normalized addresses include only address bits within the DCTs' range. The normalized address varies based on DCT interleave and hoisting settings in [The DRAM Controller Select Low Register] F2x110 and [The DRAM Controller Select High Register] F2x114 as well as node interleaving based on [The DRAM Base/Limit Registers] F1x[1, 0][7C:40].

#### **2.6.2** The GART

The GART is a device that translates a range of physical address space, called the GART aperture, to a logical address based on page tables in system memory. The GART also includes a cache for the page table translations. The registers that specify GART behavior are:

- [The GART Aperture Control Register] F3x90.
- [The GART Aperture Base Register] F3x94.
- [The GART Table Base Register] F3x98.
- [The GART Cache Control Register] F3x9C.

### 2.6.3 DMA Exclusion Vectors (DEV)

The DEV is a set of protection tables in system memory that inhibit IO accesses to ranges of system memory. The tables specify link-defined UnitIDs that are allowed access to physical memory space on a 4 Kbyte page basis. Multiple protection domains are supported, each with independent DEV tables and supported UnitIDs. See [The DEV Capability Header Register] F3xF0 for more details.

# 2.6.4 Northbridge Routing

There are two types of routing the NB performs to determine where to route a transaction: (1) address space routing determines which node the transaction is routed to, and (2) HyperTransport<sup>TM</sup> transaction routing determines the path in the coherent fabric that the transaction follows to reach its destination.

### 2.6.4.1 Address Space Routing

There are four main types of address space routed by the NB: (1) memory space targeting system DRAM, (2) memory space targeting IO (MMIO), (3) IO space, and (4) configuration space. The NB includes two sets of routing registers for each of these:

- Base map registers accessed through function 1, offsets 40 through F4. These are normally adequate for smaller systems.
- Extended map registers, accessed through [The Extended Address Map Data Port] F1x114. These may be needed to support larger systems.

There are no restrictions which, or both, of these map registers are enabled. If both are enabled, then the base map registers take precedence over the extended map registers.

# 2.6.4.1.1 DRAM and MMIO Memory Space

For memory-space transactions, the physical address, cacheability type, access type, and DRAM/MMIO destination type (as specified in section 2.9.3.1.2 [Determining The Access Destination for CPU Accesses] on page 108) are presented to the NB for further processing as follows:

- Regardless of the access DRAM/MMIO destination, if supplied, the physical address is checked against the NB's AGP-aperture range-registers F3x90 and F3x94, if enabled; if the address matches, the NB translates the physical address through the AGP GART. A match in the AGP aperture overrides any match to [The DRAM Base/Limit Registers] F1x[1, 0][7C:40], and [The Memory Mapped IO Base/Limit Registers] F1x[BC:80].
  - For accesses from IO devices, the cacheability attribute from the GART entry's "Coherent" bit, as specified in [The GART Table Base Register] F3x98[GartTblBaseAddr], is applied.
  - For accesses from a CPU, the attribute already applied by the CPU core is used and the "Coherent" bit is ignored. (System software should ensure that the cacheability attribute assigned to an AGP aperture matches the "Coherent" bit in the matching GART entry.)
- IO-device accesses that do not match the AGP aperture and post-GART translated addresses are compared against:
  - If the access matches [The Memory Mapped IO Base/Limit Registers] F1x[BC:80], then the transaction is routed to the specified link;
  - Else, if the access matches [The Extended MMIO Address Base Registers] F1x114\_x2 and [The Extended MMIO Address Mask Registers] F1x114\_x3, then the access is routed to the specified link;
  - Else, if the access matches [The DRAM Base/Limit Registers] F1x[1, 0][7C:40], then the access is routed to the specified link or DCT;
  - Else, the access is routed to the node or link that contains compatibility (subtractive) address space, specified by [The Node ID Register] F0x60[SbNode] and [The Unit ID Register] F0x64[SbLink].
- For CPU core accesses that do not match the AGP aperture, the routing is determined based on the

#### DRAM/MMIO destination:

- If the destination is DRAM:
  - If the access matches [The DRAM Base/Limit Registers] F1x[1, 0][7C:40], then the transaction is routed to the specified link;
  - Else, the access is routed to the node or link that contains compatibility (subtractive) address space, specified by [The Node ID Register] F0x60[SbNode] and [The Unit ID Register] F0x64[SbLink].
- If the destination is MMIO:
  - If the access matches [The Memory Mapped IO Base/Limit Registers] F1x[BC:80], then the transaction is routed to the specified link;
  - Else, if the access matches [The Extended MMIO Address Base Registers] F1x114\_x2 and [The Extended MMIO Address Mask Registers] F1x114\_x3, then the access is routed to the specified link;
  - Else, the access is routed to the node or link that contains compatibility (subtractive) address space, specified by [The Node ID Register] F0x60[SbNode] and [The Unit ID Register] F0x64[SbLink].

## 2.6.4.1.2 **IO Space**

IO-space transactions from IO links or CPU cores are routed as follows:

- If the access matches [The IO-Space Base/Limit Registers] F1x[DC:C0], then the transaction is routed to the specified link;
- Else, the access is routed to the node or link that contains compatibility (subtractive) address space, specified by [The Node ID Register] F0x60[SbNode] and [The Unit ID Register] F0x64[SbLink].

#### 2.6.4.1.3 Configuration Space

Configuration-space transactions from IO links are master aborted. Configuration-space transactions from CPU cores are routed as follows:

- If the access targets the configuration space of an existing node (based on the configuration-space address and F0x60[NodeCnt]), then it is routed to that node.
- Else, if the access matches [The Configuration Map Registers] F1x[EC:E0], then the transaction is routed to the specified link;
- Else, the access is routed to the node or link that contains compatibility (subtractive) address space, specified by [The Node ID Register] F0x60[SbNode] and [The Unit ID Register] F0x64[SbLink].

### 2.6.4.2 HyperTransport<sup>TM</sup> Technology Routing

There are three types of HyperTransport<sup>TM</sup> transactions routed by the NB: (1) broadcast transactions, (2) request transactions, and (3) response transactions. The NB includes routing registers for each node that specify the link to route each transaction type accessed through [The Routing Table Registers] F0x[5C:40].

# 2.6.4.2.1 Routing Table Configuration

The routing table registers must be configured correctly in multi-node systems to ensure that probes are only delivered once to each node and to ensure that the routing table is deadlock free.

A routing table is deadlock free if it contains no open-paths and no two-hop cycles.

An open-path is a routing path between nodes that traverse one or more nodes that contains a subpath that is not a routing path in the routing table. For example if the routing path between nodes 0 and 2 in Figure 3 was Node 0->Node 1->Node 3->Node 2 and the routing path between Nodes 3 and 2 was not Node 3->Node 2 then the routing path between Nodes 0 and 2 would be open because the subpath Node 3->Node 2 is not a path in the routing table.



Figure 3: Sample four-node configuration

A two-hop cycle is a group of two hop routing paths (routing paths between two nodes that pass through a third node) such that the first and second nodes in the each two hop routing path are also the second and third nodes in a two hop routing path in the group.

Consider the four node configuration shown in Figure 3. A two-hop cycle would occur in this configuration if the routing table was configured with the following routing paths:

- The routing path from Node 0 to Node 3 is: Node 0->Node 1->Node 3.
- The routing path from Node 1 to Node 2 is: Node 1->Node 3->Node 2.
- The routing path from Node 2 to Node 1 is: Node 2->Node 0->Node 1.
- The routing path from Node 3 to Node 0 is: Node 3->Node 2->Node 0.

To break this cycle at least one but no more than three of these routing paths must be modified to use a different intermediate node. Reconfiguring the routing paths as follows eliminates the 2-hop cycle.

- The routing path from Node 0 to Node 3 is: Node 0->Node 1->Node 3.
- The routing path from Node 1 to Node 2 is: Node 1->Node 3 to Node 2.
- The routing path from Node 2 to Node 1 is: Node 2->Node 0->Node 1.
- The routing path from Node 3 to Node 0 is: Node 3->Node 1->Node 0.

### 2.6.4.2.2 BIOS Requirements for Systems with Mixed Processor Families

Processors that are not Family 10h processor are not supported on coherent links by Family 10h processors. BIOS must ensure that all nodes in the coherent fabric are Family 10h processors by reading [The CPUID Family/Model Register] F3xFC before initializing the node. If a node that is not a Family 10h processor is discovered the following BIOS must configure the BSP routing tables as a single processor system.

The BIOS may continue the boot process in order to display an error message on the screen if the BSP has DRAM attached and the display adapter is connected to an IO link accessible to the BSP. If these conditions are not met the BIOS may signal an error in a implementation specific manner. The BIOS must not continue the boot process after the error has been reported.

### 2.6.4.2.3 Link Traffic Distribution

Link traffic distribution is a mechanism to reduce coherent link congestion by distributing the traffic over multiple links. It supports 2-node systems in which multiple coherent links are connected between the nodes. For example, a 2-node system may connect 2 or 3 coherent links between the two nodes in order to increase bandwidth between them. Note: all links connected between the two nodes should be the same width (either 16-bit ganged links or 8-bit unganged sublinks). The mode is enabled by [The Coherent Link Traffic Distribution Register] F0x164. The following requirement must be met:

• For any virtual channels that are enabled for distribution, the corresponding routing table entry in F0x[5C:40] is required to select one of the links specified for distribution in F0x164[DstLnk].

# 2.6.4.2.4 F0x[5C:40]Display Refresh And IFCM

*Display refresh* traffic is traffic generated by UMA graphics chipsets. It targets system memory for the purpose of refreshing the display. Link display refresh packets are defined as follows:

- 1. IO-initiated, non-posted read requests with the isochronous bit, PassPW bit, and RespPassPW bit set, and the coherent bit cleared. The SeqID must be zero and the request must be addressed outside the GART aperture.
- 2. The corresponding response to these requests.

The NB prioritizes these packets such that display refresh latency and bandwidth goals may be met. To support display refresh traffic, [The Link Transaction Control Register] F0x68[DispRefModeEn] is set.

Alternatively, if supported by the chipset, link-defined isochronous flow control mode (IFCM) may be employed. IFCM is enabled through [The Link Control Registers] F0x[E4, C4, A4, 84][IsocEn]. If this bit is set for any link, then F0x68[DispRefModeEn] must be clear.

- The processor does not support peer-to-peer accesses in isochronous virtual channels. Upstream isochronous requests that target IO space are passed to the IO device in the base channel (the Isoc bit in the request packet is low); however, the Isoc bit in the downstream response to the requester is still set in such a case.
- In non-IFCM, the link-defined Isoc bit in the request packet is cleared as it is reflected downstream in a peer-to-peer access as well.

See also [The Link Base Channel Buffer Count Registers] F0x[F0, D0, B0, 90] for IFCM buffer requirements and [The SRI to XCS Token Count Register] F3x140 for IFCM and display refresh token requirements.

### **2.6.5** The Level 3 Cache (L3)

The NB may include an L3 cache as specified by [The L2/L3 Cache and L2 TLB Identifiers] CPUID Fn8000\_0006\_EDX.

When the L3 is enabled, the following register settings are required:

• [The Hardware Configuration Register (HWCR)] MSRC001 0015[INVD WBINVD]=1.

### 2.6.6 Memory Scrubbers

The processor includes memory scrubbers specified in [The Scrub Rate Control Register] F3x58 and F3x5C. The scrubbers ensure that all cachelines in memory within or connected to the processor are periodically read and, if correctable errors are discovered, they are corrected. The system memory scrubber is also employed as specified in [The On-Line Spare Control Register] F3xB0[SwapEn0].

Server systems that enable scrubbing should ensure that data-cache and L2 scrubbing operate, even when the CPU core is halted (in the ACPI-defined C1 state). This is accomplished by programming [The ACPI Power State Control Registers] F3x[84:80][ClkDivisor] associated with C1 to a divisor no deeper than divide-by-16; divisors of 16, 8, 4, 2, and 1 support scrubbing while the CPU core is halted.

## 2.6.7 Physical Address Space

The processor supports 48 address bits of coherent memory space (256 terabytes) as indicated by [The Address Size And Physical Core Count Information] CPUID Fn8000\_0008\_EAX. The processor master aborts the following upper-address transactions (to address PhysAddr):

- IO link requests with non-zero PhysAddr[63:48].
- IO link or CPU requests with non-zero PhysAddr[47:40] where F0x68[CHtExtAddrEn]=0.
- IO link or CPU requests with non-zero PhysAddr[47:40] which targets an IO link for which the appropriate F0x[E4, C4, A4, 84][Addr64BitEn]=0.
- IO link requests with non-zero PhysAddr[47:40] received from an IO link for which the appropriate F0x[E4, C4, A4, 84][Addr64BitEn]=0.

# 2.6.8 System Address Map

System software must not map memory in the reserved HyperTransport<sup>TM</sup> technology address regions. The *HyperTransport*<sup>TM</sup> *I/O Link Specification* details the address map available to system hosts and devices. Downstream host accesses to reserved HyperTransport<sup>TM</sup> address regions result in a page fault. Upstream system device accesses to reserved HyperTransport<sup>TM</sup> address regions result in undefined operation.

#### 2.7 Links

A *link* is a block of link signals, including 16 CAD signals, 2 CTL signals, and 2 CLK signals. Links may support *unganged* modes in which subgroups of link signals--or *sublinks*--are connected to separate devices, as specified by [The Northbridge Capabilities Register] F3xE8[UnGangEn]. Links may operate per coherent protocol or IO protocol. The electrical definition is per various revisions of the *HyperTransport*<sup>TM</sup> *I/O Link Specification*; the terminology for these modes is as follows:

- Gen1: refers to link rates of 0.4 to 1.6 GT/s in the revision 1 specification or 2.0 GT/s in the revision 2 specification.
- Gen3: refers to link rates of 2.4 to 5.2 GT/s in the revision 3 specification. Note: 2.4 GT/s and 2.8 GT/s are supported as specified in the revision 3 specification only, not as specified in the revision 2 specification.

#### 2.7.1 Link Initialization

### 2.7.1.1 Ganging And Unganging

The following combinations of maximum bit widths (it is always possible to connect to a device using a supported, narrower bit width), protocols, and frequencies are supported:

- One 16-bit link (ganged); either IO or coherent protocol; any supported link frequency. In ganged mode, the link may or may not be left unconnected. In ganged mode, registers that control sublink 0 control the entire link; registers that control sublink 1 are reserved.
- Two 8-bit links (unganged); the two sublinks may be configured for any combination of IO or coherent protocol, AC- or DC-coupled mode (although AC-coupled IO links are not supported); if the two link frequencies are the same, then they may be any supported frequency; if the two link frequencies are different, then they are required to be one of the following ratios to each other: 8:1, 6:1, 4:1, 2:1; legal combinations are {2.4, 0.4}, {4.8, 0.8}, {4.8, 2.4}, {4.8, 1.2}, {4.0, 2.0}, {3.2, 1.6}, {3.2, 0.8}, {3.2, 0.4}, {2.4, 1.2}, {1.6, 0.8}, {1.6, 0.4}, and {0.8, 0.4} GT/s). In unganged mode, neither, either, or both of the two 8-bit sublinks may be left unconnected. In unganged mode, sublink 0 refers to the link associated with CLK[0], CTL[0], and CAD[7:0]; sublink 1 refers to the link associated with CLK[1], CTL[1], and CAD[15:8].

#### 2.7.1.2 Ganging Detection And Control

If unganging is not supported by the processor (F3xE8[UnGangEn]), then the links always cold boot to the ganged state.

Otherwise, the ganged state of DC-coupled links at cold boot is based on the state of CTL[1]. If CTL[1]=0, then the link powers up unganged. If CTL[1]=1, then the link powers up ganged. If CTL[1] is connected

between the processor and another devices (such as another processor) that supports the Gen3 link specification, then the link cold boots to the unganged state.

If unganging is supported, AC-coupled links always cold boot to the unganged state.

If both sublinks of an unganged link connect the same two devices, then initialization software may be used to place these sublinks into the ganged state (F0x[18C:170][Ganged]).

# 2.7.1.3 Link Type Detect

The link may be initialized in one of the following states during cold reset:

- The link may be ganged or unganged.
- The link/sublink is connected to another device via DC-coupled termination.
- The link/sublink is connected to another device via AC-coupled termination.
- The link/sublink is not connected with inputs terminated to the proper state to indicate this.
- The link/sublink is not connected with inputs floating (as with a connection to an unpopulated socket).
- If the processor does not support AC-coupled mode, the phy transitions to the PHY OFF state and declares the link unconnected as soon as DC detect fails.

The processor follows the protocol described in the Gen3 link specification to determine the cold boot state of F0x[18C:170][Ganged and AC] and F0x[E4, C4, A4, 84][TransOff and EndOfChain]. F0x[E4, C4, A4, 84][TransOff and EndOfChain] are set when the link is unconnected, as follows:

- Unterminated link: no AC-coupled or DC-coupled device is detected on the other side of the link.
- DC-coupled links: link is strapped in the unconnected state per the link specification.

#### 2.7.1.4 Legal Topologies

The link may be connected in these configurations:

- 16-bit Gen3 device connected (CTL[1] connected)
- 16-bit Gen1 device connected (CTL[1] terminated)
- Unganged:
  - Two 8-bit devices connected
  - One 8-bit device connected to either sublink and the other sublink with inputs terminated
  - One 8-bit device connected to either sublink and the other sublink with inputs floating
- Link inputs terminated
- Link inputs floating

#### 2.7.2 Termination and Compensation

The links are designed to operate either in AC- or DC-termination mode as follows.



Figure 4: Link DC termination mode.



Figure 5: Link AC termination mode.

Ron and Rtt are constructed with an array of parallel resistors that can be enabled or disabled to vary the resulting resistance. Each parallel resistor is referred to as a *tap*. Precision external resistors are used by the processor to determine the number of taps that must be enabled in order to match Ron and Rtt to the proper target values. The results of this compensation circuitry are observable in [The Link Phy Compensation Control Register] F4x1[9C, 94, 8C, 84]\_xE0[RonRawCal] and [The Link Phy Compensation Control Register] F4x1[9C, 94, 8C, 84]\_xE0[RttRawCal]. Other fields in these registers are provided to offset the raw calculated compensation values or override them.

Compensation updates start after PWROK becomes valid (and occur while RESET\_L is asserted).

When F0x[18C:170][AC]=0, the transmitter and receiver tristate in the PHY OFF state, as entered by F0x[E4, C4, A4, 84][TransOff]=1. When AC=1, both the transmitter and receiver terminate to ground in PHY OFF, as required by the *HyperTransport*<sup>TM</sup> *I/O Link Specification*.

### 2.7.3 Equalization

A high speed data stream passing through the channel distorts due to various effects. The processor employs equalization to counter this problem and to improve electrical fidelity of the links. Equalization is employed by changing the voltage level transmitted before and after bit transitions. The transmitter can be attenuated to levels that vary based on bit history, as specified by [The Link Phy Deemphasis Value Registers] F4x1[9C, 94, 8C, 84]\_x[D5, C5]. Equalization is not used at Gen1 frequencies.

### 2.7.4 Link Bandwidth Requirements

The bandwidth of a link may not exceed the bandwidth capacity of the nodes NB. The requirements are as follows:

- Where NCLK is the NB COF and HTCLK is the frequency of the link clock:
  - 16-bit, ganged links or any ganged links running link BIST: NCLK >= HTCLK.
  - 8-bit or less, ganged links: NCLK >= HTCLK / 2.
  - All unganged links: NCLK >= HTCLK.

# 2.7.5 Link Retry

The links support the error-retry mode described by the *HyperTransport*<sup>TM</sup> *I/O Link Specification*, controlled by [The Link Retry Registers] F0x[14C:130] and [The Link Global Retry Control Register] F0x150. Some requirements for operation in this mode:

- The processor does not support error-retry mode over links operating at Gen1 frequencies.
- IO links operating at Gen3 frequencies are required to have error-retry enabled.
- Coherent links operating at Gen3 frequencies are expected to have error-retry enabled. However, the processor logically supports operation of coherent links at Gen3 frequencies without error-retry for test and debug purposes.
- If any coherent links have error-retry enabled, then all coherent links are required to be have it enabled after the coherent fabric has been configured. Until the warm reset to enable retry on all links, only configuration space cycles may be used in the coherent fabric.
- The retry history buffer for each ganged link supports up to 32 packets (each packet may include command and data), 16 packets for each unganged sublink.

## 2.7.6 Link LDTSTOP\_L Disconnect-Reconnect

When disconnected for an LDTSTOP\_L assertion, the state of the link and the reconnect time is a function of the link generation (Gen1 or Gen3) being used (or that the link is changing to, as a result of the LDTSTOP\_L assertion), F0x[E4, C4, A4, 84][LdtStopTriEn], and F0x[18C:170][LS2En] as follows:

Table 13: Link disconnect controls

| Link Gen | LdtStopTriEn | LS2En | CLK                   | CAD, CTL              | Reconnect delay                         |
|----------|--------------|-------|-----------------------|-----------------------|-----------------------------------------|
| Gen1     | 0            | X     | $L0^1$                | $L0^1$                | Fast (about 1 microsecond) <sup>4</sup> |
| Gen1     | 1            | 0     | L01                   | High imp <sup>3</sup> | Fast (about 1 microsecond) <sup>4</sup> |
| Gen1     | 1            | 1     | High imp <sup>3</sup> | High imp <sup>3</sup> | F3xD8[ReConDel] <sup>4</sup>            |
| Gen3     | X            | 0     | L01                   | $EI^2$                | F0x16C[T0Time]                          |
| Gen3     | X            | 1     | $EI^2$                | $EI^2$                | F0x16C[T0Time]                          |

- 1. L0 represents the active, driven state.
- 2. Electrical idle.
- 3. High impedance.
- 4. F0x[E4, C4, A4, 84][ExtCTL]=1 adds 50us after CTL asserts.

### 2.7.7 LDTSTOP Requirements

- The processor requires additional minimum LDTSTOP\_L assertion time for certain system configurations.
  - If any of the following system configuration properties are true the minimum LDTSTOP\_L assertion time required by the processor is 10 microseconds:
    - The system includes links operating at 200 MHz, 400 MHz, or 600 MHz (see [The Link Fre-

quency/Revision Registers] F0x[E8, C8, A8, 88][Freq]).

- The system connects to registered DIMMs (see [The DRAM Configuration Low Register] F2x[1, 0]90[UnbuffDimm]).
- For all other configurations the minimum LDTSTOP\_L assertion time is as specified by the link specification (1 microsecond).
- For all cases of LDTSTOP\_L assertion (including link width/frequency changes, S1-based power management, and stutter mode) LDTSTOP\_L must not deassert less than 10 microseconds after the processor broadcasts the STOPGRANT message.
- The processor requires a minimum LDTSTOP\_L deassertion time of 3 microseconds.
- Note that narrow and slow links and use of F0x[E4, C4, A4, 84][ExtCTL] can greatly increase the time for a Gen1 link to disconnect and reconnect, so the time between LDTSTOP assertions must be increased appropriately as required by section 8.3 of the *HyperTransport*<sup>TM</sup> *I/O Link Specification*.

## 2.7.8 Response Ordering

The processor supports non-standard response ordering, not required by the link specification. If the processor receives multiple IO-sourced memory read requests with certain attributes, then the processor ensures that the order of the responses to these requests is the same as the order in which the requests were received. The required attributes are:

- The requests have the same UnitID value (or *logical* UnitID if multiple UnitIDs are clumped; see [The Link Clumping Enable Registers] F0x[11C, 118, 114, 110]).
- The requests have the same, non-zero SeqID value.
- The requests have the same PassPW bit value.
- The requests have the same Coherent (snoop) bit value.
- The requests have the same RespPassPW bit value.
- The requests have the same Normal/Isochronous bit value.

This feature may allow IO devices to be designed that do not require re-order buffers. This behavior may be disabled through [The Northbridge Configuration Register (NB\_CFG)] MSRC001\_001F[DisOrderRdRsp].

### 2.7.9 Link Testing, BIST, and ILM

The processor includes a link-defined BIST engine for each link. The control registers are found starting at [The Link BIST Control Register] F4x1[9C, 94, 8C, 84]\_x100. See the link specification for more information.

The processor also supports link-defined internal loopback mode (ILM), controlled by [The Link Extended Control Registers] F0x[18C:170][ILMEn].

#### 2.7.10 Miscellaneous Behaviors and Requirements

- The processor does not support the link-defined Atomic read-modify-write command and returns target abort for any that are received.
- The processor does not support Device Messages and returns master abort for any that are received.
- The processor ignores the Chain bit.
- The processor checks for differential signaling on CTL[1:0] and disabled unused sublinks.
- Software initiated link width and frequency changes are only supported during link initialization.
- The processor register space does not include the Gen3 link-defined UCC bit or CPIC bit. However, functionally, the initial revisions of the processor would have these bits set to indicate that unthrottled command generation from IO links is supported (i.e., setting LinkTrain[DisCmdThrt] on the other side of the link) and command packet insertion from IO links is supported (i.e., setting LinkTrain[CPIEn] on the other side of the

- link). However, no assurances are made regarding future processor revisions; they may rely on throttling and disabled command packet insertion to operate.
- While transmitting to an IO link, the processor does not ever insert commands (other than NOPs) into data packets and the processor supports throttling command generation based on the state of F0x168[DisNcHtC-mdThrottle].
- The processor logically supports link-defined mode combinations as follows (however electrical requirements may limit some options):

| Frequency            | 200-1000MHz | 1            | 200-2600MHz  |             |
|----------------------|-------------|--------------|--------------|-------------|
| Coupling/            | DC          | DC           | DC           | AC coherent |
| Link Type            |             | non-coherent | coherent or  |             |
|                      |             | operational  | non-coherent |             |
|                      |             |              | test/debug   |             |
| Termination          | RXDIFF      | RXDIFF       | RXDIFF       | RXGNDTRM    |
| 8b10b                | No          | No           | No           | Optional    |
| Scrambling           | No          | Yes          | Optional     | Optional    |
| <b>Gen3 Training</b> | No          | Yes          | Yes          | Yes         |
| Retry                | No          | Required     | Optional     | Required    |

**Table 14: Supported link operational modes** 

- The processor supports link-defined INTx messages. It emulates the ORing of INTx assertions throughout the system and broadcasts the result. To accomplish this, the processor uses separate counters for each of the four interrupts (INTA, INTB, INTC, and INTD) which track INTx assertions and deassertions received by the coherent fabric. Each assertion causes the counter to increment and each deassertion causes the counter to decrement. As each counter transitions from 0 to 1, the interrupt assertion message is broadcast. As each counter transitions from 1 to 0, the interrupt deassertion message is broadcast.
- The processor reflects system management messages E2h to FFh for vendor-defined virtual wire messages. Devices that send or receiver them must have programmable registers to control the command encodings used so that different devices can interoperate.
- Ganged links leave the upper sublink driven after cold reset (per F0x16C[InLnSt]) unless the lower sublink is unconnected. If the lower sublink of a ganged link is unconnected, the entire link is disabled.
- The processor cannot be used in a system where the sideband signal (RESET# or LDTSTOP#) skew between devices is greater than 100us.

## 2.8 DRAM Controllers (DCTs)

The DCTs support DDR2 DIMMs or DDR3 DIMMs. Products may be configurable between DDR2 and DDR3 operation.

A *DRAM channel* is the group of the DRAM interface pins that connect to one series of DIMMs. The processor supports two DDR channels. The processor includes two DCTs. Each DCT controls one 64-bit DDR DIMM channel.

For DDR products, DCT0 controls channel A DDR pins and DCT1 controls channel B DDR pins. However, the processor may be configured: (1) to behave as a single dual-channel DCT; this is called *ganged mode*; or (2) to behave as two single-channel DCTs; this is called *unganged mode*.

A *logical DIMM* is either one 64-bit DIMM (as in unganged mode) or two identical DIMMs in parallel to create a 128-bit interface (as in ganged mode). See section 1.5.2 [Supported Feature Variations] on page 20 for information about supported package/DRAM configurations.

For DDR products, when the DCTs are in ganged mode, as specified by [The DRAM Controller Select Low Register] F2x110[DctGangEn], then each logical DIMM is two channels wide. Each physical DIMM of a 2-channel logical DIMM is required to be the same size and use the same timing parameters. Both DCTs must be programmed with the same information (see section 2.8.1 [DCT Configuration Registers] on page 61). When the DCTs are in 64-bit mode, a logical DIMM is equivalent to a 64-bit physical DIMM and each channel is controlled by a different DCT.

There are restrictions on the configuration and types of DIMMs supported on the DCTs at any one time:

- All DIMMs connected to a node are required to operate at the same MEMCLK frequency, regardless of which channel they are connected to. Both DCTs must be programmed to the same frequency.
- The DCTs do not support different DRAM types (DDR2 and DDR3) on the same channel or between channels.
- The DCTs do not support the mixing of unbuffered and registered DIMMs on the same channel or between channels.
- The DCTs do not support the mixing of ECC and non-ECC DIMMs on the same channel or between channels.

Table 15 below list the DIMM speeds supported by the processor for different configurations. See section 2.8.7.4.8 [DRAM Address Timing and Output Driver Compensation Control] on page 74 for detailed information on supported memory bus loads and for configuration settings based on loads.

| DIMM  | DIMMs  | DIMMs<br>(by type <sup>1</sup> ) |             | Frequency (MT/s)                |                                       |  |
|-------|--------|----------------------------------|-------------|---------------------------------|---------------------------------------|--|
| Slots |        | QR                               | SR or<br>DR | Unbuffered DIMMs on motherboard | Registered<br>DIMMs on<br>motherboard |  |
| 1     | 1      | 0                                | 1           | 1066                            | 800                                   |  |
|       |        | 1                                | 0           | -                               | 533                                   |  |
| 2     | 1      | 0                                | 1           | 1066                            | 800                                   |  |
|       |        | 1                                | 0           | -                               | 533                                   |  |
|       | 2      | 0                                | 2           | 800                             | 800                                   |  |
|       |        | 1 or 2                           | 1 or 0      | -                               | 533                                   |  |
| 4     | 1 or 2 | -                                | any         | -                               | 800                                   |  |
| 4     | 3 or 4 | -                                | any         | -                               | 533                                   |  |

**Table 15: DDR2 Unbuffered and Registered DIMM Support (per channel)** 

# 2.8.1 DCT Configuration Registers

DCT configuration registers range from F2x[1, 0][5C:40] through F2x[1, 0]A8 and F2x110 through F2x11C. F2x0XX registers are associated with DCT0 and F2x1XX registers are associated with DCT1.

If the BIOS is not required to be in compatibility mode with the NPT Family 0Fh memory controller, BIOS must program F2x[1, 0]94[LegacyBiosMode]=0.

When the DCTs are ganged, as specified by [The DRAM Controller Select Low Register] F2x110[DctGangEn], then most of the DCT configuration registers behave as follows: only writes the DCT0 set of registers (F2x0XX) are captured (and applied to both channels); reads to the DCT0 set of registers return the value cap-

tured in the DCT0 channel registers; writes to the DCT1 set of registers (F2x1XX) are ignored and reads return all 0's. The exception is the DCT phy registers, F2x[1, 0]98, F2x[1, 0]9C, and all the associated indexed registers; these all remain independently accessible between the two DCTs when the DCTs are ganged.

## 2.8.2 Support For Multiple Unbuffered Logical DIMMs

There is one copy of command and address pins for each DRAM channel supported by the package. It is expected that the electrical requirements for unbuffered DIMMs necessitate that slow access mode ([The DRAM Configuration High Register] F2x[1, 0]94[SlowAccessMode]) be enabled when there is more than one unbuffered logical DIMM installed to a DRAM controller.

# 2.8.3 Burst Length

Some IO applications such as graphics may access system memory with many 32-byte transactions. In these cases, placing the DRAM controller into 32-byte burst mode ([The DRAM Configuration Low Register] F2x[1, 0]90[BurstLength32]) may improve DRAM efficiency. When a DRAM controller is programmed for 128-bit logical DIMMs (F2x[1, 0]90[Width128]) processors then only 64-byte bursts are supported.

# 2.8.4 Ganged or Unganged Mode Considerations

Typical systems built from multi-core products benefit from the additional parallelism generated by using the two DCTs in unganged mode. Single core products or products that require additional ECC correction capabilities (see 2.13.2 [DRAM Considerations for ECC] on page 118) should implement ganged mode.

When enabling two DCTs in unganged mode, BIOS should set F2x[1, 0]94[BankSwizzleMode]=1b, F2x110[DctSelIntLvAddr]=10b, and F2x110[DctSelIntLvEn]=1b.

### 2.8.5 Routing DRAM Requests

Typically, system BIOS acquires DIMM configuration information, such as the amount of memory on each DIMM, from the Serial Presence Detect (SPD) ROM on each DIMM and uses this information to program the DRAM controller registers.

DRAM requests are mapped to the DCT of the appropriate node based on the routing configuration specified in section 2.6.4.1.1 [DRAM and MMIO Memory Space] on page 51. They are mapped to chip selects through [The DRAM CS Base Address Registers] F2x[1, 0][5C:40], and [The DRAM CS Mask Registers] F2x[1, 0][6C:60].

The following algorithm is designed to be used to determine the processor, the DRAM controller, and the chip select for a system address that maps to DRAM. SystemAddr is a 64 bit input variable representing the physical address. CSFound, NodeID, ChannelSelect, and CS are output variables. If CSFound is equal to 1, then NodeID, ChannelSelect, and CS outputs are equal to the node, DRAM controller (zero or one), and the chip select that corresponds to the input address.

If the On-line Spare feature is enabled BIOS assigns one of the chip-selects for a controller, CH0SPARE\_RANK or CH1SPARE\_RANK, to be the spare rank in the event of a DIMM failure precondition. If the DIMM failure precondition occurs and the data of the failing rank is copied over, the spare rank decodes to the same system address range as the failing rank (BadDramCs).

```
(int,int,int,int) TranslateSysAddrToCS((uint64)SystemAddr){
int SwapDone, BadDramCs;
```

```
int CSFound, NodeID, CS, F1Offset, F2Offset, F2MaskOffset, Ilog, device;
int HiRangeSelected, DramRange;
uint32 IntlvEn, IntlvSel;
uint32 DramBaseLow, DramLimitLow, DramEn;
uint32 HoleOffset, HoleEn;
uint32 CSBase, CSLimit, CSMask, CSEn;
uint32 InputAddr, Temp;
uint32 OnlineSpareCTL;
uint32 DctSelBaseAddr, DctSelIntLvAddr, DctGangEn, DctSelIntLvEn;
uint32 DctSelHiRngEn, DctSelHi;
uint64 DramBaseLong, DramLimitLong;
uint64 DctSelBaseOffsetLong, ChannelOffsetLong, ChannelAddrLong;
// device is a user supplied value for the PCI device ID of the processor
// from which CSRs are initially read from (current processor is fastest).
// CHOSPARE RANK and CH1SPARE RANK are user supplied values, determined
// by BIOS during DIMM sizing.
CSFound = 0;
for(DramRange = 0; DramRange < 8; DramRange++)</pre>
   F1Offset = 0x40 + (DramRange << 3);
   DramBaseLow = Get_PCI(bus0, device, func1, F1Offset);
    DramEn = DramBaseLow & 0x00000003;
   IntlvEn = (DramBaseLow & 0x00000700) >> 8;
   DramBaseLow = DramBaseLow & 0xFFFF0000;
   DramBaseLong = ((Get PCI(bus0, device, func1, F10ffset + 0x100))<<32 +</pre>
   DramBaseLow) << 8;</pre>
   DramLimitLow = Get_PCI(bus0, device, func1, F1Offset + 4);
   NodeID = DramLimitLow & 0x00000007;
   IntlvSel = (DramLimitLow & 0x00000700) >> 8;
   DramLimitLow = DramLimitLow | 0x0000FFFF;
   DramLimitLong = ((Get PCI(bus0, device, func1, F10ffset + 0x104)) << 32 +</pre>
   DramLimitLow) << 8 | 0xFF;</pre>
   HoleEn = Get_PCI(bus0, dev24 + NodeID, func1, 0xF0);
   HoleOffset = (HoleEn & 0x0000FF80);
   HoleEn = (HoleEn &0x00000003);
   if(DramEn && DramBaseLong<=SystemAddr && SystemAddr <= DramLimitLong)
      if(IntlvEn == 0 | IntlvSel == ((SystemAddr >> 12) & IntlvEn))
         if(IntlvEn == 1) Ilog = 1;
         else if(IntlvEn == 3) Ilog = 2;
         else if(IntlvEn == 7) Ilog = 3;
         else Ilog = 0;
         Temp = Get_PCI(bus0, device, func2, 0x110);
         DctSelHiRngEn = Temp & 1;
         DctSelHi = Temp>>1 & 1;
         DctSelIntLvEn = Temp & 4;
         DctGangEn = Temp \& 0x10;
         DctSelIntLvAddr = (Temp>>6) & 3;
         DctSelBaseAddr = Temp & 0xFFFFF800;
         DctSelBaseOffsetLong = Get_PCI(bus0, device, func2, 0x114)<<16;</pre>
         //Determine if High range is selected
         if(DctSelHiRngEn && DctGangEn==0 && (SystemAddr>>27) >=
            (DctSelBaseAddr>>11)) HiRangeSelected = 1;
         else HiRangeSelected=0;
         //Determine Channel
```

```
if(DctGangEn) ChannelSelect = 0;
else if (HiRangeSelected) ChannelSelect = DctSelHi;
else if (DctSelIntLvEn && DctSelIntLvAddr == 0)
   ChannelSelect = SystemAddr>>6 & 1;
else if (DctSelIntLvEn && DctSelIntLvAddr>>1 & 1)
   Temp ^= SystemAddr>>16&0x1F;
   if(DctSelIntLvAddr & 1) ChannelSelect = (SystemAddr>>9 & 1) Temp;
   else ChannelSelect = (SystemAddr>>6 & 1) Temp;
else if (DctSelIntLvEn && IntlvEn&4)ChannelSelect = SystemAddr>>15&1;
else if (DctSelIntLvEn && IntlvEn&2)ChannelSelect = SystemAddr>>14&1;
else if (DctSelIntLvEn && IntlvEn&1) ChannelSelect = SystemAddr>>13&1;
else if (DctSelIntLvEn) ChannelSelect = SystemAddr>>12&1;
else if (DctSelHiRngEn && DctGangEn==0) ChannelSelect = ~DctSelHi&1;
else ChannelSelect = 0;
//Determine Base address Offset to use
if(HiRangeSelected)
   if(!(DctSelBaseAddr & 0xFFFF0000) && (HoleEn & 1) &&
      (SystemAddr >= 0x1 00000000))
      ChannelOffsetLong = HoleOffset<<16;</pre>
   else
       ChannelOffsetLong= DctSelBaseOffsetLong;
else
   if((HoleEn & 1) && (SystemAddr >= 0x1 00000000))
      ChannelOffsetLong = HoleOffset<<16;</pre>
      ChannelOffsetLong = DramBaseLong & 0xFFFF F8000000;
//Remove hoisting offset and normalize to DRAM bus addresses
ChannelAddrLong = SystemAddr & 0x0000FFFF FFFFFC0 -
ChannelOffsetLong & 0x0000FFFF_FF800000;
//Remove Node ID (in case of processor interleaving)
Temp = ChannelAddrLong & 0xFC0;
ChannelAddrLong = (ChannelAddrLong >>Ilog & 0xFFFF_FFFF000) | Temp;
//Remove Channel interleave and hash
if (DctSelIntLvEn && DctSelHiRngEn==0 && DctGangEn==0)
   if(DctSelIntLvAddr != 1)
      ChannelAddrLong = (ChannelAddrLong>>1) & 0xffffffff ffffffc0;
   else
      Temp = ChannelAddrLong & 0xFC0;
      ChannelAddrLong = ((ChannelAddrLong & 0xFFFFFFFF FFFFC000) >> 1) | Temp;
InputAddr = ChannelAddrLong>>8;
for(CS = 0; CS < 8; CS++)
   F2Offset = 0x40 + (CS << 2);
   if ((CS % 2) == 0)
      F2MaskOffset = 0x60 + (CS << 1);
   else
      F2MaskOffset = 0x60 + ((CS-1) << 1);
   if(ChannelSelect)
      F2Offset+=0x100;
```

```
F2MaskOffset+=0x100;
            CSBase = Get PCI(bus0, dev24 + NodeID, func2, F2Offset);
            CSEn = CSBase \& 0x00000001;
            CSBase = CSBase & 0x1FF83FE0;
            CSMask = Get_PCI(bus0, dev24 + NodeID, func2, F2MaskOffset);
            CSMask = (CSMask | 0x0007C01F) & 0x1FFFFFFF;
            if(CSEn && ((InputAddr & ~CSMask) == (CSBase & ~CSMask)))
               CSFound = 1;
               OnlineSpareCTL = Get_PCI(bus0, dev24 + NodeID, func3, 0xB0);
               if(ChannelSelect)
                  SwapDone = (OnlineSpareCTL >> 3) & 0x00000001;
                  BadDramCs = (OnlineSpareCTL >> 8) & 0x00000007;
                  if(SwapDone && CS == BadDramCs) CS=CH1SPARE RANK;
               }
               else
                  SwapDone = (OnlineSpareCTL >> 1) & 0x00000001;
                  BadDramCs = (OnlineSpareCTL >> 4) & 0x00000007;
                  if(SwapDone && CS == BadDramCs) CS=CHOSPARE RANK;
               break;
            }
         }
if (CSFound) break;
} // for each DramRange
return(CSFound, NodeID, ChannelSelect, CS);
```

### 2.8.6 DRAM Data Burst Mapping

DRAM requests are mapped to data bursts on the DDR bus in the following order:

- In unganged mode, a 64-byte request is mapped to each of the eight sequential data beats as QW0, QW1...QW7.
- In ganged mode, a 64-byte request is mapped to each of the four sequential data beats across both channels as QW0 (channel A), QW1 (channel B), QW2 (channel A)...QW7 (channel B).

### 2.8.7 DCT/DRAM Initialization

DRAM initialization involves several steps in order to configure the DRAM controllers and the DRAM, and to tune the DRAM channel for optimal performance. The following describes an ordered sequence of steps needed to accomplish setting up the memory channels from reset.

After cold reset, BIOS performs the following in order:

- 1. Phy and controller mode configuration. See section 2.8.7.1.
- 2. Phy compensation initialization. See section 2.8.7.2.
- 3. DRAM controller and device initialization. See the note at the end of this section.
  - a. Program SPD timings. See section 2.8.7.3.
  - b. Program Non-SPD timings. See section 2.8.7.4 and all sub-sections.
  - c. DRAM device initialization. See section 2.8.7.5.
- 4. Phy Fence programmingSee section 2.8.7.6.

- 5. DRAM Write Leveling ((if using DDR3 memory). See section 2.8.7.8.1.
- 6. Perform second pass of steps 4 through 7 at the target frequency, if applicable. See the note at the end of this section.
- 7. DRAM Data Training. See section 2.8.7.8 and all sub-sections:
  - a. Receiver Enable Training. See sections 2.8.7.8.2.1 and 2.8.7.8.2.2.
  - b. DQS Position Training. See section 2.8.7.8.2.3.
  - c. MaxRdLat Training. See section 2.8.7.8.4.1.
- 8. Program Non-SPD timings to optimal values. See section 2.8.7.4 and all sub-sections.
- 9. The memory subsystem is ready for use.

Note: If DDR3 memory is used and the target frequency is greater than 400 MHz, then BIOS must perform two initialization passes for certain steps during the DCT/DRAM initialization; the first pass BIOS configures MEMCLK frequency to 400 Mhz, while the second pass BIOS configures MEMCLK frequency to the target frequency.

# 2.8.7.1 Phy and Controller Mode Configuration

To enable subsequent phy and controller register accesses to be routed correctly, Family 10h BIOS must do the following very early in POST:

- Program F2x[1, 0]94[LegacyBiosMode] = 0.
- Program F2x[1, 0]94[Ddr3Mode], based on the platform and DIMM type.

# 2.8.7.2 Phy compensation initialization

Each normalized driver strength code in F2x[1, 0]9C\_x00[DataDrvStren, AddrCmdDrvStren] has a corresponding D3CMP predriver calibration code that must be programmed into F2x9C\_x0A. BIOS is required to program F2x9C\_x0A after any processor or memory reset before any DDR commands are sent to the DRAM. BIOS initializes the DDR phy compensation logic registers F2x9C\_x09 and F2x9C\_x0A by performing the following steps:

- 1. BIOS disables the phy compensation register by programming F2x[1, 0]9C\_x08[DisAutoComp]=1.
- 2. BIOS waits 5 us for the disabling of the compensation engine to complete.
- 3. For each normalized driver strength code read from F2x[1, 0]9C\_x00[AddrCmdDrvStren], program the corresponding 3 bit predriver code in F2x9C\_x0A[D3Cmp1NCal, D3Cmp1PCal].
- 4. For each normalized driver strength code read from F2x[1, 0]9C\_x00[DataDrvStren], program the corresponding 3 bit predriver code in F2x9C\_x0A[D3Cmp0NCal, D3Cmp0PCal, D3Cmp2NCal, D3Cmp2PCal].

BIOS re-enables the phy compensation engine when DRAM initialization is complete. See section 2.8.7.5.

## 2.8.7.3 SPD ROM-Based Configuration

The SPD ROM is a non-volatile memory device on the DIMM encoded by the DIMM manufacturer. The description of the SPD is usually provided on a data sheet for the DIMM itself along with data describing the memory devices used. The data describes configuration and speed characteristics of the DIMM and the SDRAM components mounted on the DIMM. The associated data sheet also contains the DIMM byte values that are encoded in the SPD on the DIMM.

BIOS reads the values encoded in the SPD ROM through the I/O hub, which obtains the information through a secondary device connected to the I/O hub through the SMBus. This secondary device communicates with the

DIMM by means of the I<sup>2</sup>C bus. BIOS must determine the type of DRAM used on the DIMM in order to interpret the SPD byte values correctly as they differ greatly between DRR2 and DDR3. This information is available in byte 2 of the SPD in all DIMM devices.

The SPD ROM provides values for several DRAM timing parameters that are required by the DCT. In general, BIOS should use the optimal value specified by the SPD ROM. These parameters are:

- Tcl: (CAS latency)
- Trc: Active-to-Active/Auto Refresh command period
- Trfc: Auto-Refresh-to-Active/Auto Refresh command period
- Trcd: Active-to-Read-or-Write delay
- Trrd: Active-Bank-A to-Active-Bank-B delay
- Tras: Active-to-Precharge delay
- Trp: Precharge time
- Tref: Refresh interval
- Trtp: Internal Read to Precharge command delay
- Twtr: Internal Write to Read command delay
- Twr: Write recovery time

Optimal cycle time is specified for each DIMM and is used to limit or determine bus frequency. See section 2.8.7.7 [DRAM Channel Frequency Change] on page 84 for more information on configuring the bus frequency.

## 2.8.7.4 Non-SPD ROM-Based Configuration

There are several DRAM timing parameters and DCT configurations that need to be programmed for optimal memory performance. These values are not derived from the SPD ROM. Several of these timing parameters are functions of other configuration values. These interdependencies must be considered when programming values into several DCT register timing fields. The factors to consider when specifying a value for a specific non-SPD timing parameter are:

- DDR2 vs. DDR3 DRAM types.
- Mixed or non-mixed DIMMs (x4 with x8).
- Training delay values. See section 2.8.7.8 [DRAM Training] on page 85.
- Read and write latency differences.
- The phy's idle clock requirements on the data bus.
- DDR3 ODT timing requirements.

The following sub-sections describe how BIOS programs each non-SPD related timing field to a recommended minimum timing value with respect to the above factors.

### 2.8.7.4.1 Trdrd (Read to Read Timing)

This timing parameter, F2x[1, 0]8C[Trdrd], accounts for turn-around and termination timing when a read is followed by a read to a different chip select. Prior to DRAM training, BIOS should program F2x[1, 0]8C[Trdrd]=11b for DDR2, or F2x[1, 0]8C[Trdrd]=0011b for DDR3; otherwise, BIOS should program this value optimally after DDR training is complete as follows:

• For DDR2 and DDR3 systems with non-mixed (x4 or x8) DIMM types and where the DRAM Read DQS Timing Control delays are the same for all DIMMs and where the total DqsRcvEn delay difference between any two DIMMs is less than half of a MEMCLK, BIOS should program Trdrd to 0000b, else BIOS should

program Trdrd to 0001b.

• For DDR2 and DDR3 systems with mixed (x4 or x8) DIMM types, BIOS should program Trdrd based on the following table:

Table 16: DDR2 and DDR3 Trdrd settings

| CGDD <sup>1</sup> | Trdrd value | Virtual CAS (read)<br>to CAS (read) sepa-<br>ration in MEMCLKs | Idle cycle(s) on<br>the data bus in<br>MEMCLKs |
|-------------------|-------------|----------------------------------------------------------------|------------------------------------------------|
| 0                 | 0001b       | 3                                                              | 2                                              |
| 1                 | 0010b       | 4                                                              | 2.5                                            |
| 2                 | 0010b       | 4                                                              | 2                                              |

On any given byte lane, the largest F2x[1, 0]9C\_x[2B:10][DqsRcvEnGross-Delay] delay of any DIMM minus the F2x[1, 0]9C\_x[2B:10][DqsRcvEnGrossDelay] delay of any other DIMM is equal to the Critical Gross Delay Difference (CGDD) for Trdrd.

## 2.8.7.4.2 Twrwr (Write to Write Timing)

This timing parameter, F2x[1, 0]8C[Twrwr], accounts for turn-around timing when a write is followed by a write to a different DIMM. Prior to DRAM training, BIOS should program F2x[1, 0]8C[Twrwr]=11b for DDR2, or F2x[1, 0]8C[Twrwr]=0011b for DDR3; otherwise, BIOS should program this value optimally after DDR training is complete as follows:

- For DDR2 and DDR3 systems with non-mixed (x4 or x8) DIMM types and only one write F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03] delay setting, BIOS should program Twrwr to 0000b.
- For DDR2 systems with mixed (x4 or x8) DIMM types and only one F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03] delay setting, BIOS should program Twrwr to 0000b.
- For DDR2 and DDR3 with more than one F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03] delay settings, BIOS should program Twrwr based on the following table:

Table 17: DDR2 and DDR3 Twrwr settings

| CGDD <sup>1</sup> | Twrwr value | Virtual CAS (read)<br>to CAS (read) sepa-<br>ration in MEMCLKs | Idle cycle(s) on<br>the data bus in<br>MEMCLKs |
|-------------------|-------------|----------------------------------------------------------------|------------------------------------------------|
| 0                 | 0010b       | 3                                                              | 2                                              |
| 1                 | 0011b       | 4                                                              | 2.5                                            |
| 2                 | 0011b       | 4                                                              | 2                                              |

<sup>1.</sup> On any given byte lane, the largest F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03][WrDatGrossDlyByte] delay of any DIMM minus the F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03][WrDatGrossDlyByte] delay of any other DIMM is equal to the Critical Gross Delay Difference (CGDD) for Twrwr.

#### 2.8.7.4.3 Twrrd (Write to Read DIMM Termination Turn-around)

This timing parameter, F2x[1, 0]8C[Twrrd], accounts for termination timing when a write is followed by a read to a different DIMM. Prior to DRAM training, BIOS should program F2x[1, 0]8C[Twrrd]=11b for DDR2, or F2x[1, 0]8C[Twrrd]=1010b for DDR3; otherwise, BIOS should program this value optimally after DDR training is complete as follows:

• For DDR2 systems with mixed or non-mixed (x4 or x8) DIMM types, BIOS should program Twrrd based on the following table:

**Table 18: DDR2 Twrrd settings** 

| CGDD <sup>1</sup> | Twrrd value | Virtual CAS (read)<br>to CAS (read) sepa-<br>ration in MEMCLKs | Idle cycle(s) on<br>the data bus in<br>MEMCLKs |
|-------------------|-------------|----------------------------------------------------------------|------------------------------------------------|
| -2                | 00b         | 2                                                              | 3                                              |
| -1                | 00b         | 2                                                              | 2.5                                            |
| 0                 | 00b         | 2                                                              | 2                                              |
| 1                 | 01b         | 2                                                              | 2                                              |
| 2                 | 10b         | 3                                                              | 2.5                                            |
| 3                 | 10b         | 3                                                              | 2                                              |

<sup>1.</sup> On any given byte lane, the largest F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03][WrDatGrossDlyByte] delay of any DIMM minus the F2x[1, 0]9C\_x[2B:10][DqsRcvEnGrossDelay] delay of any other DIMM is equal to the Critical Gross Delay Difference (CGDD) for Twrrd.

• For DDR3, systems with mixed or non-mixed (x4 or x8) DIMM types, BIOS must also consider the difference between the read and write latencies. BIOS should program Twrrd based on the following table:

**Table 19: DDR3 Twrrd settings** 

| $LD^2$ | CGDD <sup>1</sup> | Twrrd value | Virtual CAS (read) to<br>CAS (read) separation<br>in MEMCLKs | Idle cycle(s) on the data bus in MEM-CLKs |
|--------|-------------------|-------------|--------------------------------------------------------------|-------------------------------------------|
| -1     | -7                | 0001b       | 2                                                            | 3.5                                       |
|        | -6                | 0001b       | 2                                                            | 3                                         |
|        | -5                | 0010b       | 3                                                            | 3.5                                       |
|        | -4                | 0010b       | 3                                                            | 3                                         |
|        | -3                | 0011b       | 4                                                            | 3.5                                       |
|        | -2                | 0011b       | 4                                                            | 3                                         |
|        | -1                | 0100b       | 5                                                            | 3.5                                       |
|        | 0                 | 0100b       | 5                                                            | 3                                         |
|        | 1                 | 0101b       | 6                                                            | 3.5                                       |
|        | 2                 | 0101b       | 6                                                            | 3                                         |

#### Notes:

- 1. On any given byte lane, the largest F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03][WrDat-GrossDlyByte] delay of any DIMM minus the F2x[1, 0]9C\_x[2B:10][DqsRcvEnGrossDelay] delay of any other DIMM is equal to the Critical Gross Delay Difference (CGDD) for Twrrd.
- 2. The LD value, or latency difference, is equal to F2x[1, 0]88[Tcl] minus F2x[1, 0]84[Tcwl] and can be a negative or positive value.

**Table 19: DDR3 Twrrd settings** 

| $LD^2$ | CGDD <sup>1</sup> | Twrrd value | Virtual CAS (read) to<br>CAS (read) separation<br>in MEMCLKs |     |
|--------|-------------------|-------------|--------------------------------------------------------------|-----|
| 0      | -7                | 0001b       | 2                                                            | 4.5 |
|        | -6                | 0001b       | 2                                                            | 4   |
|        | -5                | 0001b       | 2                                                            | 3.5 |
|        | -4                | 0001b       | 2                                                            | 3   |
|        | -3                | 0011b       | 3                                                            | 3.5 |
|        | -2                | 0011b       | 3                                                            | 3   |
|        | -1                | 0100b       | 4                                                            | 3.5 |
|        | 0                 | 0100b       | 4                                                            | 3   |
|        | 1                 | 0101b       | 5                                                            | 3.5 |
|        | 2                 | 0101b       | 5                                                            | 3   |
| 1      | -7                | 0001b       | 2                                                            | 5.5 |
|        | -6                | 0001b       | 2                                                            | 5   |
|        | -5                | 0001b       | 2                                                            | 4.5 |
|        | -4                | 0001b       | 2                                                            | 4   |
|        | -3                | 0001b       | 2                                                            | 3.5 |
|        | -2                | 0001b       | 2                                                            | 3   |
|        | -1                | 0100b       | 3                                                            | 3.5 |
|        | 0                 | 0100b       | 3                                                            | 3   |
|        | 1                 | 0101b       | 4                                                            | 3.5 |
|        | 2                 | 0101b       | 4                                                            | 3   |

#### Notes:

- 1. On any given byte lane, the largest F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03][WrDat-GrossDlyByte] delay of any DIMM minus the F2x[1, 0]9C\_x[2B:10][DqsRcvEnGrossDelay] delay of any other DIMM is equal to the Critical Gross Delay Difference (CGDD) for Twrrd.
- 2. The LD value, or latency difference, is equal to F2x[1, 0]88[Tcl] minus F2x[1, 0]84[Tcwl] and can be a negative or positive value.

## 2.8.7.4.4 TrwtTO (Read-to-Write Turnaround for Data, DQS Contention)

This timing parameter, F2x[1, 0]8C[TrwtTO], ensures read-to-write data-bus turnaround. Prior to DRAM training, BIOS should program F2x[1, 0]8C[TrwtTO]=0111b for DDR2, or F2x[1, 0]8C[TrwtTO]=1111b for DDR3; otherwise, BIOS should program this value optimally after DDR training is complete as follows:

• For DDR2 systems with mixed or non-mixed (x4 or x8) DIMM types: BIOS should program TrwtTO based on the following table:

| Table 20 | : DDR2 | <b>TrwtTO</b> | settings |
|----------|--------|---------------|----------|
|----------|--------|---------------|----------|

| CGDD <sup>1</sup> | TrwtTO value | Virtual CAS (read)<br>to CAS (read) sepa-<br>ration in MEMCLKs | Idle cycle(s) on<br>the data bus in<br>MEMCLKs |
|-------------------|--------------|----------------------------------------------------------------|------------------------------------------------|
| -3                | 0001b        | 3                                                              | 3                                              |
| -2                | 0001b        | 3                                                              | 2                                              |
| -1                | 0010b        | 4                                                              | 2.5                                            |
| 0                 | 0010b        | 4                                                              | 2                                              |
| 1                 | 0011b        | 5                                                              | 2.5                                            |
| 2                 | 0011b        | 5                                                              | 2                                              |
| 3                 | 0100b        | 6                                                              | 2.5                                            |
| 4                 | 0100b        | 6                                                              | 2                                              |

On any given byte lane, the largest F2x[1, 0]9C\_x[2B:10][DqsRcvEnGross-Delay] delay of any DIMM minus the F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03][WrDatGrossDlyByte] delay of any other DIMM is equal to the Critical Gross Delay Difference (CGDD) for TrwtTO.

• For DDR3, systems with mixed or non-mixed (x4 or x8) DIMM types, BIOS must also consider the difference between the read and write latencies or LD<sup>2</sup> BIOS should program TrwtTO based on the following table:

Table 21: DDR3 TrwtTO settings

| CGDD <sup>1</sup> | TrwtTO value | Virtual CAS (read)<br>to CAS (read) separa-<br>tion in MEMCLKs | Idle cycle(s) on<br>the data bus in<br>MEMCLKs |
|-------------------|--------------|----------------------------------------------------------------|------------------------------------------------|
| -2                | 0001b + LD   | 3 + LD                                                         | 3                                              |
| -1                | 0001b + LD   | 3 + LD                                                         | 2.5                                            |
| 0                 | 0001b + LD   | 3 + LD                                                         | 2                                              |
| 1                 | 0010b + LD   | 4 + LD                                                         | 2.5                                            |
| 2                 | 0010b + LD   | 4 + LD                                                         | 2                                              |
| 3                 | 0011b + LD   | 5 + LD                                                         | 2.5                                            |
| 4                 | 0011b + LD   | 5 + LD                                                         | 2                                              |

<sup>1.</sup> On any given byte lane, the largest F2x[1, 0]9C\_x[2B:10][DqsRcvEnGross-Delay] delay of any DIMM minus the F2x[1, 0]9C\_x[102:101, 02:01]:F2x[1, 0]9C\_x[103, 03][WrDatGrossDlyByte] delay of any other DIMM is equal to the Critical Gross Delay Difference (CGDD) for TrwtTO.

#### 2.8.7.4.5 TrwtWB (Read-to-Write Turnaround for Opportunistic Write Bursting)

This timing parameter, F2x[1, 0]8C[TrwtWB], ensures read-to-write data-bus turnaround. This value should be one more than the programmed F2x[1, 0]8C[TrwtTO] value. See section [The TrwtTO (Read-to-Write Turnaround for Data, DQS Contention)] 2.8.7.4.4.

<sup>2.</sup> The LD value, or latency difference, is equal to the read latency (Tcl) minus the write latency (Tcwl) and can be a negative or positive value.

# 2.8.7.4.6 FourActWindow (Four Bank Activate Window or tFAW)

No more than 4 banks may be activated in a rolling tFAW window. For DDR2 devices, BIOS must convert the tFAW parameter into MEMCLK cycles by dividing the highest tFAW parameter (in ns) found in all the SPD ROMs for DIMMs connected to the channel by the period of MEMCLK (in ns) and rounding up to the next integer. For example, if this field is set to 10 clocks and an activate command is issued in clock N, then no more than three further activate commands may be issued in clocks N+1 through N+9. Table 22 shows the DDR2 F2x[1, 0]94[tFAW] clock values used for various frequencies and page sizes.

**Table 22: DDR2 Four Bank Activate Window Values** 

| Page Size | 533 MHz    | 400 MHz    | 333 MHz    | 266 MHz    | 200 MHz    |
|-----------|------------|------------|------------|------------|------------|
| 1K        | 19 MEMCLKs | 14 MEMCLKs | 13 MEMCLKs | 10 MEMCLKs | 8 MEMCLKs  |
| 2K        | 24 MEMCLKs | 18 MEMCLKs | 17 MEMCLKs | 14 MEMCLKs | 10 MEMCLKs |

For DDR3, BIOS should use the tFAW values specified in the SPD ROM for the specific DIMM device.

#### 2.8.7.4.7 DRAM ODT Control

This section describes the ODT configurations and settings for the processor and attached DIMMs. The tables specify ODT values for different speeds and configurations, on a per channel basis. The processor ODT values are controlled by  $F2x[1, 0]9C_x00[ProcOdt]$  for both DDR2 and DDR3. The DIMM termination values are programmed as specified below before DRAM device initialization. If the DIMM termination values are changed after device initialization then BIOS must issue MRS commands to the devices to change the values. See F2x[1, 0]7C for more information.

Table 23 documents the ODT termination values for different DDR2 configurations. The DDR2 DIMM nominal termination resistance is controlled by F2x[1, 0]90[DramTerm].

Table 24 documents the ODT nominal (non-write) and dynamic termination resistance values for different DDR3 DIMM configurations. The DDR3 DIMM nominal termination resistance is controlled by F2x[1, 0]84[DramTerm]. The DDR3 DIMM dynamic termination resistance is controlled by F2x[1, 0]84[DramTerm-Dyn].

Table 25 documents the ODT nominal (non-write) and dynamic termination resistance values for different DDR3 4 rank DIMM configurations. The BIOS enables nominal termination on even numbered ranks and disables nominal termination of odd numbered ranks of a 4 rank DIMM. In addition, BIOS configures different ODT values for single rank or dual rank DIMMs on a channel including quad rank DIMMs, as specified in this table.

**Table 23: Processor and DDR2 DIMM ODT Settings** 

| Rate                | Number of DIMMs | Processor ODT | DIMM ODT |
|---------------------|-----------------|---------------|----------|
| DDR2-400, DDR2-533, | 1               | 75 ohms       | 75 ohms  |
| DDR2-667            |                 |               |          |
| DDR2-400, DDR2-533  | 2 or more       | 150 ohms      | 75 ohms  |
| DDR2-667            | 2 or 3          | 150 ohms      | 75 ohms  |
| DDR2-667            | 4               | 150 ohms      | 50 ohms  |

**Table 23: Processor and DDR2 DIMM ODT Settings** 

| Rate      | Number of DIMMs | Processor ODT | DIMM ODT |
|-----------|-----------------|---------------|----------|
| DDR2-800  | 1               | 75 ohms       | 75 ohms  |
| DDR2-800  | 2 or more       | 150 ohms      | 50 ohms  |
| DDR2-1066 | 1               | 75 ohms       | 75 ohms  |

Table 24: Processor and DDR3 DIMM ODT Settings

| Number of DIMMs | Processor ODT     | DIMM ODT<br>(Rtt_Nom) | DIMM Dynamic ODT (Rtt_Wr) |
|-----------------|-------------------|-----------------------|---------------------------|
| 1               | 60 ohms           | 60 ohms               | Disabled                  |
| 2 or more       | 2 or more 60 ohms |                       | 120 ohms                  |

Table 25: Processor and QR-DDR3 DIMM ODT Settings

| Number of DIMMs <sup>1</sup> | Processor ODT | DIMM ODT <sup>2</sup><br>(Rtt_Nom) | DIMM Dynamic ODT (Rtt_Wr) |
|------------------------------|---------------|------------------------------------|---------------------------|
| 1 or 2 QR                    | 60 ohms       | 60 ohms                            | 120 ohms                  |
| 1 SR or DR                   | 60 ohms       | 30 ohms                            | 120 ohms                  |

- 1. QR = Quad Rank. SR, DR = Single rank, dual rank.
- 2. BIOS enables Rtt\_Nom only on ranks S0 and S2 of a 4 rank DIMM.

The following describes the general ODT behavior for various DDR2 system configurations. In all cases, the processor ODT is off for writes and is on for reads:

- For 1 DIMM on a channel:
  - For writes, the first rank of the DIMM provides ODT.
  - For reads, the DIMM ODT is off for all ranks.
- For 2 DIMMs on a channel:
  - For writes and reads:
    - ODT is on for the first rank of the non-targeted DIMM.
    - ODTs are off for all other ranks on the channel.
- For more than 2 DIMMs on a channel:
  - For writes and reads:
    - ODT is active for the first rank of all the non-target DIMMs. The target DIMM being written has ODT turned off for all ranks.

The following describes the general ODT behavior for various DDR3 system configurations. In all cases, the processor ODT is off for writes and is on for reads:

- For one dual rank DIMM on a channel:
  - For writes, the ODT of the target rank is off and the non-target rank is on. If the DIMM is a single rank DIMM, then ODT is on for that rank.
  - For reads, the DIMM ODT is off for all ranks.
- For two dual rank DIMMs on a channel:
  - For writes, the ODT is on for the target rank of the target DIMM and also on for the first rank of the non-target DIMM.
  - For reads, ODT is on for the first rank of the non-target DIMM.
- For one 4 rank DIMM on a channel:
  - For writes to any even target rank (i.e. ranks 0 or 2), the ODT is on for all even ranks. For writes to rank

- 1, the ODT is on for rank 1 and for rank 2. For writes to rank 3, the ODT is on for rank 3 and rank 0.
- For reads, the DIMM ODT is off for all ranks.
- For one single rank DIMM and one 4 rank DIMM on a channel:
  - For writes, if the target is the single rank DIMM, then ODT is on for the target rank and the ODT is on for all even ranks of the 4 rank DIMM. ODT is off for all other ranks.
  - For writes, if the target rank is on the 4 rank DIMM, then ODT is on for the single rank DIMM and ODT is on for the target rank of the 4 rank DIMM. ODT is off for all other ranks.
  - For reads, if the target is the single rank DIMM, then ODT is on for all even ranks of the 4 rank DIMM only. ODT is off for all other ranks.
  - For reads, if the target rank is on the 4 rank DIMM, then ODT is on for the single rank DIMM only.
- For one dual rank DIMM and one 4 rank DIMM on a channel:
  - For writes, if the write is to one of the ranks on the target dual rank DIMM, then ODT is on for the target rank and ODT is also on for all even ranks of the 4 rank DIMM. ODT is off for all other ranks.
  - For writes, if the write is to a rank on the 4 rank DIMM, then ODT is on for the first rank of the dual rank DIMM and ODT is also on for the target rank of the 4 rank DIMM. ODT is off for all other ranks.
  - For reads, if the read is from one of the ranks of the dual rank DIMM, then ODT is on for all even ranks of the non-target 4 rank DIMM.
  - For reads, if the read is from a rank on the 4 rank DIMM, then ODT is on for the first rank of the dual rank DIMM only.
- For two 4 rank DIMMs on a channel:
  - For writes, if the write is to one of the ranks of a 4 rank DIMM, then ODT is on for that target rank and ODT is also on for all even ranks of the non-target 4 rank DIMM. ODT is off for all other ranks.
  - For reads, if the read is from one of the ranks of a 4 rank DIMM, then ODT is on for all even ranks of the non-target 4 rank DIMM.
- For more than two registered DIMMs on a channel:
  - For writes, ODT is on for the first rank of all the DIMMs.
  - For reads, ODT is on for the first rank of all the non-target DIMMs. ODT is off for the target DIMM.

# 2.8.7.4.8 DRAM Address Timing and Output Driver Compensation Control

This section describes the settings required for programming the timing on the address pins, the CS/ODT pins, and the CKE pins. Table 26, Table 27, Table 28, and Table 29 document the address timing and output driver settings on a per channel basis for different DDR DIMM types. The DIMMs on each channel are numbered from 0 to n where DIMM0 is the DIMM closest to the processor on that channel and DIMMn is the DIMM farthest from the processor on that channel. DIMMs must be populated from farthest slot to closest slot to the processor on a per channel basis .Populations that are not shown in these tables are not supported. These tables document the optimal settings for motherboards which meet the relevant motherboard design guidelines. See section 2.8 [DRAM Controllers (DCTs)] on page 60 for an overview of the DIMM and memory bus speed support.

Table 26: DDR2 Unbuffered DIMM Address Timings and Drive Strengths for the AM2r2 Package

| DDR Type-Rate | DIMM0 <sup>1</sup> | DIMM1 <sup>1</sup> | Timing Mode | F2x[1, 0]9C_x04 | F2x[1, 0]9C_x00 <sup>2</sup> |
|---------------|--------------------|--------------------|-------------|-----------------|------------------------------|
| DDR2-400      | -                  | any                | 1T          | 002F_2F00h      | X011_1222h                   |
| DDR2-400      | any                | any                | 2T          | 002F_2F00h      | X011_1322h                   |

1. SR = Single Rank DIMM

DR = Dual Rank DIMM

any = SR, DR

2. See Table 23 on page 72 for DDR2 ProcODT settings.

Table 26: DDR2 Unbuffered DIMM Address Timings and Drive Strengths for the AM2r2 Package

| DDR Type-Rate | DIMM0 <sup>1</sup> | DIMM1 <sup>1</sup> | Timing Mode | F2x[1, 0]9C_x04 | F2x[1, 0]9C_x00 <sup>2</sup> |  |
|---------------|--------------------|--------------------|-------------|-----------------|------------------------------|--|
| DDR2-533      | -                  | SRx16              | - 1T        | 002B_2F00h      | X011_1222h                   |  |
| DDR2-353      | -                  | DRx8               | 11          | 002B_2F00II     | A011_1222II                  |  |
| DDR2-533      | -                  | SRx8               | 1T          | 002F_2F00h      | X011_1222h                   |  |
|               | SRx16              | SRx16              |             |                 |                              |  |
| DDR2-533      | SRx16              | SRx8               | 2T          | 002F_2F00h      | X011_1322h                   |  |
|               | SRx8               | SRx16              |             |                 |                              |  |
| DDR2-533      | SRx8               | SRx8               | 2T          | 0000_2F00h      | X011_1322h                   |  |
| DDR2-533      | DRx8               | DRx8               | 2T          | 0034_2F00h      | X011_1322h                   |  |
| DDR2-533      | DRx8               | SRx16              | 2Т          | 0038_2F00h      | V011 1222h                   |  |
| DDR2-333      | SRx16              | DRx8               | 21          | 0038_2F00II     | X011_1322h                   |  |
| DDR2-533      | DRx8               | SRx8               | 2Т          | 0037_2F00h      | X011_1322h                   |  |
| DDR2-353      | SRx8               | DRx8               | 21          | 003/_2F00II     | A011_132211                  |  |
| DDR2-667      | -                  | any                | 1T          | 0020_2220h      | X011_1222h                   |  |
|               | SRx16              | SRx16              |             |                 |                              |  |
| DDR2-667      | SRx16              | SRx8               | 2T          | 0020_2220h      | X011_1322h                   |  |
|               | SRx8               | SRx16              |             |                 |                              |  |
| DDR2-667      | SRx8               | SRx8               | 2T          | 0030_2220h      | X011_1322h                   |  |
| DDR2-667      | DRx8               | DRx8               | 2T          | 002B_2220h      | X011_1322h                   |  |
| DDR2-667      | DRx8               | SRx16              | 2T          | 002C_2220h      | X011_1322h                   |  |
| DDR2-007      | SRx16              | DRx8               | 21          | 002C_2220II     | A011_1322II                  |  |
| DDR2-667      | DRx8               | SRx8               | 2Т          | 0024 22205      | V011 1222h                   |  |
| DDR2-007      | SRx8               | DRx8               | 21          | 002A_2220h      | X011_1322h                   |  |
| DDR2-800      | -                  | any                | 2T          | 0020_2520h      | X011_3222h                   |  |
| DDR2-800      | any                | any                | 2T          | 0020_2520h      | X011_3322h                   |  |
|               |                    | DRx8               |             |                 | X011_3222h                   |  |
| DDR2-1066     | -                  | SRx8               | 2T          | 0020_2520h      |                              |  |
|               |                    | SRx16              |             |                 |                              |  |

<sup>1.</sup> SR = Single Rank DIMM

DR = Dual Rank DIMM

any = SR, DR

2. See Table 23 on page 72 for DDR2 ProcODT settings.

Table 27: DDR2 Registered DIMM Address Timings and Drive Strengths for Fr2(1207) Package (4 DIMMs per channel)

| DDR Type-<br>Rate | DIMM0 <sup>1</sup> | DIMM1 <sup>1</sup> | DIMM2 <sup>1</sup> | DIMM3 <sup>1</sup> | Timing<br>Mode | F2x[1, 0]9C_x04 | F2x[1, 0]9C_x00 <sup>2</sup> |
|-------------------|--------------------|--------------------|--------------------|--------------------|----------------|-----------------|------------------------------|
| DDR2-400          | -                  | -                  | -                  | any                | 1T             | 0000_0000h      | X011_1222h                   |
| DDR2-400          | -                  | -                  | any                | any                | 1T             | 0037_0000h      | X011_1222h                   |
| DDR2-400          | -                  | any                | any                | any                | 1T             | 002F_0000h      | X011_1222h                   |
| DDR2-400          | any                | any                | any                | any                | 1T             | 002F_0000h      | X011_1222h                   |
| DDR2-533          | -                  | -                  | -                  | any                | 1T             | 0000_0000h      | X011_1222h                   |
| DDR2-533          | -                  | -                  | any                | any                | 1T             | 0037_0000h      | X011_1222h                   |
| DDR2-533          | -                  | any                | any                | any                | 1T             | 002F_0000h      | X011_1222h                   |
| DDR2-533          | any                | any                | any                | any                | 1T             | 002F_0000h      | X011_1222h                   |
| DDR2-667          | -                  | -                  | -                  | SR or              | 1T             | 0000_0000h      | X011_1222h                   |
|                   |                    |                    |                    | DRx8               |                |                 |                              |
| DDR2-667          | -                  | -                  | -                  | DRx4               | 1T             | 0000_2F00h      | X011_1222h                   |
| DDR2-667          | -                  | -                  | SR or              | SR or              | 1T             | 0037_0000h      | X011_1222h                   |
|                   |                    |                    | DRx8               | DRx8               |                |                 |                              |
| DDR2-667          | -                  | -                  | any                | DRx4               | 1T             | 0037_2F00h      | X011_1222h                   |
| DDR2-667          | -                  | -                  | DRx4               | any                | 1T             | 0037_2F00h      | X011_1222h                   |
| DDR2-800          | -                  | -                  | -                  | SR or              | 1T             | 0000_0000h      | X011_1222h                   |
|                   |                    |                    |                    | DRx8               |                |                 |                              |
| DDR2-800          | -                  | -                  | -                  | DRx4               | 1T             | 0000_2F00h      | X011_1222h                   |
| DDR2-800          | -                  | -                  | SR or              | SR or              | 1T             | 0037_0000h      | X011_1222h                   |
|                   |                    |                    | DRx8               | DRx8               |                |                 |                              |
| DDR2-800          | -                  | -                  | DRx4               | any                | 1T             | 0037_2F00h      | X011_1222h                   |
| DDR2-800          | 1                  | 1                  | any                | DRx4               | 1T             | 0037_2F00h      | X011_1222h                   |
|                   |                    |                    |                    |                    | -              |                 |                              |

<sup>1.</sup> Any = SR or DR.

Table 28: DDR2 Registered DIMM Address Timings and Drive Strengths for the Fr2(1207) Package (2 DIMMs per channel)

| DDR Type-Rate | DIMM0 <sup>1</sup> | DIMM1 <sup>1</sup> | Timing Mode | F2x[1, 0]9C_x04 | F2x[1, 0]9C_x00 <sup>2</sup> |
|---------------|--------------------|--------------------|-------------|-----------------|------------------------------|
| DDR2-400      | -                  | any                | 1T          | 0000_0000h      | X011_1222h                   |
| DDR2-400      | SR or DR           | SR or DR           | 1T          | 0037_0000h      | X011_1222h                   |
| DDR2-400      | QR                 | QR                 | 1T          | 002F_0000h      | X011_1222h                   |
| DDR2-533      | -                  | any                | 1T          | 0000_0000h      | X011_1222h                   |

<sup>1.</sup> SR = Single Rank DIMM

DR = Dual Rank DIMM

QR = Quad Rank DIMM

any = SR, DR, or QR

2. See Table 23 on page 72 for DDR2 ProcODT settings.

<sup>2.</sup> See Table 23 on page 72 for DDR2 ProcODT settings.

Table 28: DDR2 Registered DIMM Address Timings and Drive Strengths for the Fr2(1207) Package (2 DIMMs per channel)

| DDR Type-Rate | DIMM0 <sup>1</sup> | DIMM1 <sup>1</sup> | Timing Mode | F2x[1, 0]9C_x04 | F2x[1, 0]9C_x00 <sup>2</sup> |
|---------------|--------------------|--------------------|-------------|-----------------|------------------------------|
| DDR2-533      | SR or DR           | SR or DR           | 1T          | 0037_0000h      | X011_1222h                   |
| DDR2-533      | QR                 | QR                 | 1T          | 002F_0000h      | X011_1222h                   |
| DDR2-667      | -                  | SR or DRx8         | 1T          | 0000_0000h      | X011_1222h                   |
| DDR2-667      | -                  | DRx4 or QR         | 1T          | 0000_2F00h      | X011_1222h                   |
| DDR2-667      | SR or DRx8         | SR or DRx8         | 1T          | 0037_0000h      | X011_1222h                   |
| DDR2-667      | any                | DRx4               | 1T          | 0037_2F00h      | X011_1222h                   |
| DDR2-667      | DRx4               | any                | 1T          | 0037_2F00h      | X011_1222h                   |
| DDR2-667      | QR                 | QR                 | 1T          | 002F_2F00h      | X033_1222h                   |
| DDR2-800      | -                  | SR or DRx8         | 1T          | 0000_0000h      | X011_1222h                   |
| DDR2-800      | -                  | DRx4               | 1T          | 0000_2F00h      | X011_1222h                   |
| DDR2-800      | SR or DRx8         | SR or DRx8         | 1T          | 0037_0000h      | X011_1222h                   |
| DDR2-800      | SR or DR           | DRx4               | 1T          | 0037_2F00h      | X011_1222h                   |
| DDR2-800      | DRx4               | SR or DR           | 1T          | 0037_2F00h      | X011_1222h                   |

<sup>1.</sup> SR = Single Rank DIMM

Table 29: DDR3 Unbuffered DIMM Address Timings and Drive Strengths

| DDR Type-Rate | DIMM0  | DIMM1  | Timing<br>Mode | F2x[1, 0]9C_x04 | F2x[1, 0]9C_x00 |
|---------------|--------|--------|----------------|-----------------|-----------------|
| DDR3-800      | -      | SR-x16 | 1T             | 0037_3737h      | 2022_3222h      |
| DDR3-800      | -      | SR-x8  | 1T             | 0037_3737h      | 2022_3222h      |
| DDR3-800      | -      | DR-x8  | 1T             | 0037_3737h      | 2022_3222h      |
| DDR3-800      | SR-x16 | SR-x16 | 1T             | 0037_3737h      | 2022_3322h      |
| DDR3-800      | SR-x8  | SR-x8  | 1T             | 0037_3737h      | 2022_3322h      |
| DDR3-800      | DR-x8  | DR-x8  | 1T             | 0037_3737h      | 2022_3322h      |
| DDR3-800      | SR-x16 | SR-x8  | 1T             | 0037_3737h      | 2022_3322h      |
| DDR3-800      | SR-x8  | SR-x16 | 1T             | 0037_3737h      | 2022_3322h      |
| DDR3-800      | SR-x16 | DR-x8  | 1T             | 0037_3737h      | 2022_3322h      |
| DDR3-800      | DR-x8  | SR-x16 | 1T             | 0037_3737h      | 2022_3322h      |
| DDR3-800      | SR-x8  | DR-x8  | 1T             | 0037_3737h      | 2022_3322h      |
| DDR3-800      | DR-x8  | SR-x8  | 1T             | 0037_3737h      | 2022_3322h      |
| DDR3-1066     | -      | SR-x16 | 1T             | 0037_3737h      | 2022_3222h      |
| DDR3-1066     | -      | SR-x8  | 1T             | 0037_3737h      | 2022_3222h      |
| DDR3-1066     | -      | DR-x8  | 1T             | 0037_3737h      | 2022_3222h      |

DR = Dual Rank DIMM

QR = Quad Rank DIMM

any = SR, DR, or QR

<sup>2.</sup> See Table 23 on page 72 for DDR2 ProcODT settings.

| DDR3-1066 | SR-x16 | SR-x16 | 1T | 0035_3737h  | 2022_3322h  |
|-----------|--------|--------|----|-------------|-------------|
| DDR3-1066 | SR-x8  | SR-x8  | 1T | 0035_3737h  | 2022_3322h  |
| DDR3-1066 | DR-x8  | DR-x8  | 1T | 0035_3737h  | 2022_3322h  |
| DDR3-1066 | SR-x16 | SR-x8  | 1T | 0035_3737h  | 2022_3322h  |
| DDR3-1066 | SR-x8  | SR-x16 | 1T | 0035_3737h  | 2022_3322h  |
| DDR3-1066 | SR-x16 | DR-x8  | 1T | 0035_3737h  | 2022_3322h  |
| DDR3-1066 | DR-x8  | SR-x16 | 1T | 0035_3737h  | 2022_3322h  |
| DDR3-1066 | SR-x8  | DR-x8  | 1T | 0035_3737h  | 2022_3322h  |
| DDR3-1066 | DR-x8  | SR-x8  | 1T | 0035_3737h  | 2022_3322h  |
| DDR3-1333 | -      | SR-x16 | 1T | 0037_3737h  | 2022_3222h  |
| DDR3-1333 | -      | SR-x8  | 1T | 0037_3737h  | 2022_3222h  |
| DDR3-1333 | -      | DR-x8  | 1T | 0037_3737h  | 2022_3222h  |
| DDR3-1333 | SR-x16 | SR-x16 | 2T | 0000_3737h  | 2022_3322h  |
| DDR3-1333 | SR-x8  | SR-x8  | 2T | 0000_3737h  | 2022_3322h  |
| DDR3-1333 | DR-x8  | DR-x8  | 2T | 0000_3737h  | 2022_3322h  |
| DDR3-1333 | SR-x16 | SR-x8  | 2T | 0000_3737h  | 2022_3322h  |
| DDR3-1333 | SR-x8  | SR-x16 | 2T | 0000_3737h  | 2022_3322h  |
| DDR3-1333 | SR-x16 | DR-x8  | 2T | 0000_3737h  | 2022_3322h  |
| DDR3-1333 | DR-x8  | SR-x16 | 2T | 0000_3737h  | 2022_3322h  |
| DDR3-1333 | SR-x8  | DR-x8  | 2T | 0000_3737h  | 2022_3322h  |
| DDR3-1333 | DR-x8  | SR-x8  | 2T | 0000_3737h  | 2022_3322h  |
| DDR3 1333 | DIX-X0 | SIX-X0 | 21 | 0000_373711 | 2022_332211 |

Table 29: DDR3 Unbuffered DIMM Address Timings and Drive Strengths

### 2.8.7.5 DRAM Device Initialization

After the DCT registers are programmed (see sections 2.8.7.3 and 2.8.7.4), BIOS initializes the DRAM using either a hardware or BIOS controlled sequence. See sections 2.8.7.5.1 and 2.8.7.5.2 for more information on BIOS controlled initialization. To initiate the hardware sequence, BIOS does the following:

1. Program F2x[1, 0]90[InitDram] = 1.

DRAM initialization completes after the hardware-controlled initialization process completes or when the BIOS-controlled initialization process completes (F2x[1, 0]7C[EnDramInit] is written from 1 to 0).

When both DCTs are enabled in unganged mode, BIOS must initialize each DCT in order. This is accomplished as follows:

- 1. Ensure  $F2x[1, 0]9C \times 08[DisAutoComp] = 1$ .
- 2. BIOS waits 5 us for the disabling of the compensation engine to complete.
- 3. Configure all DCT registers.
- 4. Program F2x90[InitDram]=1 (or F2x7C[EnDramInit]=1 when using software DRAM initialization as described in 2.8.7.5.1 [Software DDR2 Device Initialization] on page 80 or 2.8.7.5.2 [Software DDR3 Device Initialization] on page 81) for channel 0.
- 5. BIOS polls F2x[1, 0]98[DctAccessDone].
- 6. When F2x[1, 0]98[DctAccessDone]=0, BIOS programs F2x190[InitDram]=1 (or F2x17C[EnDramInit]=1 when using software DRAM initialization) for channel 1.
- 7. Program  $F2x[1, 0]9C_x08[DisAutoComp] = 0$ .

8. BIOS must wait 750 us for the phy compensation engine to reinitialize.

A similar requirement exists when changing the DRAM channel frequency. See section 2.8.7.7 [DRAM Channel Frequency Change] on page 84 for more information.

For DDR2, part of the initialization sequence includes writing mode register set (MRS) values to the DDR2 DRAM. The values written to MRS and EMRS in DRAM devices are determined as follows when using the hardware-controlled sequence:

- MRS[2:0] burst length (BL): based on F2x[1, 0]90[Width128 and BurstLength32].
- MRS[3] burst type (BT): interleave.
- MRS[6:4] CAS latency: based on F2x[1, 0]88[Tcl].
- MRS[7] test mode (TM): normal mode.
- MRS[8] DLL reset (DLL): controlled as required by the initialization sequence.
- MRS[11:9] write recovery for auto pre-charge (WR): based on F2x[1, 0]88[Twr].
- MRS[12] active power down exit time (PD): fast exit (although the mode is not supported).
- EMRS(1)[0]: DLL enable (DLL): enabled.
- EMRS(1)[1]: output driver impedance control (DIC): based on F2x[1, 0]90[DramDrvWeak].
- EMRS(1)[6,2]: Rtt: based on F2x[1, 0]90[DramTerm].
- EMRS(1)[5:3]: additive latency: fixed at 0.
- EMRS(1)[9:7]: OCD calibration program: controlled as required by the initialization sequence (but not calibrated).
- EMRS(1)[10]: DQS bar: based on F2x[1, 0]90[DisDqsBar].
- EMRS(1)[11]: RDQS: based on F2x[1, 0]94[RDqsEn].
- EMRS(1)[12]: Qoff: output buffer enabled.
- EMRS(2)[7]: SRF: high temperature self refresh rate enable, based on F2x[1, 0]90[SelfRefRateEn].

For DDR3 unbuffered DIMMS, a similar initialization sequence is invoked; DDR3 registered DIMMs do not support hardware-controlled initialization. The values written to the DRAM device's MRs when using the hardware-controlled sequence are determined as follows:

- MR0[1:0] burst length and control method (BL): based on F2x[1, 0]84[BurstCtrl].
- MR0[3] burst type (BT): interleaved.
- MR0[6:4,2] read CAS latency (CL): based on F2x[1, 0]88[Tcl].
- MR0[7] test mode (TM): normal mode.
- MR0[8] DLL reset (DLL Reset): controlled as required by the initialization sequence.
- MR0[11:9] write recovery for auto-precharge (WR): based on F2x[1, 0]84[Twr].
- MR0[12] precharge power-down mode select (PPD): based on F2x[1, 0]84[PchgPDModeSel].
- MR1[0] DLL disable (DLL Dis): DLL enabled.
- MR1[1] output driver impedance control (DIC): normal.
- MR1[6,2] nominal termination resistance of ODT (RTT): based on F2x[1, 0]90[DramTerm].
- MR1[4:3] additive latency (AL): AL is disabled.
- MR1[7] write leveling enable (Level): controlled as required by the initialization sequence.
- MR1[11]: TDQS: based on F2x[1, 0]94[RDqsEn].
- MR1[12] output disable (QOFF): based on F2x[1, 0]84[Qoff].
- MR2[2:0] partial array self refresh (PASR): full array.
- MR2[5:3] CAS write latency (CWL): based on F2x[1, 0]84[Tcwl].
- MR2[6] auto self refresh method (ASR): based on F2x[1, 0]84[ASR].
- MR2[7] self refresh temperature range (SRT): based on F2x[1, 0]84[ASR and SRT].
- MR3[1:0] multi purpose register address location (MPR Location): based on F2x[1, 0]84[MprLoc].
- MR3[2] multi purpose register (MPR): based on F2x[1, 0]84[MprEn].

The processor does not support the use of speculative system-memory reads and writes to determine the size of system memory. It is expected that BIOS determines the size of system memory by reading DIMM SPD information or an equivalent means.

### 2.8.7.5.1 Software DDR2 Device Initialization

The following BIOS controlled software initialization procedure applies to each DRAM controller and properly initializes all the DDR2 DIMMs on the channel. This procedure should be run only when booting from an unpowered state (ACPI S4, S5 or G3; not S3, suspend to RAM):

- 1. Configure the DCT registers, including MemClkFreq and MemClkFreqVal.
- 2. Program F2x[1, 0]7C[EnDramInit] = 1.
- 3. Wait 200 us.
- 4. Program F2x[1, 0]7C[DeassertMemRstX] = 1.
- 5. Wait 10 ns.
- 6. Program F2x[1, 0]7C[AssertCke] = 1.
- 7. Wait 400 ns.
- 8. Send Precharge All command.
- 9. Send EMRS(2).
- 10. Send EMRS(3).
- 11. Send EMRS(1) with MrsAddress[6,2] = 00b at this time.
- 12. Send MRS with MrsAddress[8] = 1.
- 13. Wait 200 MEMCLKs.
- 14. Send Precharge All command.
- 15. Send two Auto Refresh commands.
- 16. Send MRS with MrsAddress[8] = 0.
- 17. Send EMRS(1) with MrsAddress[9:7] = 111b and set MrsAddress[6,2]=00b at this time.
- 18. Send EMRS(1) with MrsAddress[9:7] = 000b.
- 19. Program F2x[1, 0]7C[EnDramInit] = 0.

Send Precharge All command is accomplished as follows:

- 1. Program F2x[1, 0]7C[SendPchgAll] = 1.
- 2. Wait Trp.

Send Auto Refresh command is accomplished as follows:

- 1. Program F2x[1, 0]7C[SendAutoRefresh] = 1.
- 2. Wait Trfc.

Send MRS command is accomplished by programming the [The DRAM Initialization Register] F2x[1, 0]7C register as follows:

- 1. Program MrsBank = 000b.
- 2. If EnDramInit=0 program MrsChipSel=chipselect; otherwise all chip selects are automatically selected.
- 3. Program MrsAddress[2:0] = burst length (BL): based on F2x[1, 0]90[Width128 and BurstLength32].
  - 010b = 4-beat burst length.
  - 011b = 8-beat burst length.
- 4. Program MrsAddress[3] = 1.
- 5. Program MrsAddress[6:4] = CAS latency based on the F2x[1, 0]88[Tcl] field.
- 6. Program MrsAddress[8] = DLL reset (DLL), controlled as required by the initialization sequence.
- 7. Program MrsAddress[11:9] = write recovery for auto pre-charge (WR): based on F2x[1, 0]88[Twr].
- 8. Set all other bits in MrsAddress to zero.

- 9. Set SendMrsCmd = 1.
- 10. Wait for SendMrsCmd = 0.

Send EMRS(1) command is accomplished by programming F2x[1, 0]7C as follows:

- 1. Program MrsBank = 001b.
- 2. If EnDramInit=0 program MrsChipSel=*target chip select*; otherwise all chip selects are automatically selected.
- 3. Program MrsAddress[0] = 1.
- 4. Program MrsAddress[1] = output driver impedance control (DIC): based on F2x[1, 0]90[DramDrvWeak].
- 5. Program MrsAddress[6,2] = Rtt: based on F2x[1,0]90[DramTerm].
- 6. Program MrsAddress[9:7] = OCD calibration program: controlled as required by the initialization sequence (but not calibrated).
- 7. Program MrsAddress[10] = DQS bar: based on F2x[1, 0]90[DisDqsBar].
- 8. Program MrsAddress[11] = RDQS: based on F2x[1, 0]94[RDqsEn].
- 9. Set all other bits in MrsAddress to zero.
- 10. Set SendMrsCmd = 1.
- 11. Wait for SendMrsCmd = 0.

Send EMRS(2) command is accomplished by programming F2x[1, 0]7C as follows:

- 1. Program MrsBank = 010b.
- 2. If EnDramInit=0 program MrsChipSel=*target chip select*; otherwise all chip selects are automatically selected.
- 3. Program MrsAddress[7] = SRF: high temperature self refresh rate enable, based on F2x[1, 0]90[SelfRe-fRateEn].
- 4. Set all other bits in MrsAddress to zero.
- 5. Set SendMrsCmd = 1.
- 6. Wait for SendMrsCmd = 0.

Send EMRS(3) command is accomplished by programming F2x[1, 0]7C as follows:

- 1. Program MrsBank = 011b.
- 2. If EnDramInit=0 program MrsChipSel=*target chip select*; otherwise all chip selects are automatically selected.
- 3. Program MrsAddress[15:0] = 0.
- 4. Set SendMrsCmd = 1.
- 5. Wait for SendMrsCmd = 0.

# 2.8.7.5.2 Software DDR3 Device Initialization

The following BIOS controlled software initialization procedure applies to each DRAM controller to properly initialize all the DDR3 DIMMs on the channel. This procedure should be run only when booting from an unpowered state (ACPI S4, S5 or G3; not S3, suspend to RAM). This procedure is required to support registered DDR3 DIMMs. This procedure may also be used to support unbuffered DDR3 DIMMs:

- 1. Configure the DCT registers, including MemClkFreq and MemClkFreqVal.
- 2. Program F2x[1, 0]7C[EnDramInit] = 1.
- 3. Wait 200 us.
- 4. Program F2x[1, 0]7C[DeassertMemRstX] = 1.
- 5. Wait 500 us.
- 6. Program F2x[1, 0]7C[AssertCke] = 1.
- 7. Wait 360 ns.

The following steps are performed with registered DIMMs only and must be done for each chip select pair:

- 8. Send RCW(0), RCW(1), and RCW(2). See 2.8.7.5.2.1 for details.
- 9. Wait 6 us.
- 10. Send RCW(3), RCW(4), and RCW(5).
- 11. Send RCW(6) and RCW(7) for custom settings at this time, as directed by the DIMM manufacturer's data sheet.

The following steps are performed once for each channel with unbuffered DIMMs and once for each chip select with registered DIMMs:

- 12. Send EMRS(2). See Note below.
- 13. Send EMRS(3). Ordinarily at this time, MrsAddress[2:0] = 000b.
- 14. Send EMRS(1).
- 15. Send MRS with MrsAddress[8]= 1.

*Note*: Unbuffered DIMMs optionally have address bits rearranged from the edge connector to the second rank of a dual rank DIMM. This feature is called address mirroring. The BIOS must program F2x[1, 0][5C:40][OnDimmMirror] = 1 prior to sending the MR commands used for device initialization if SPD byte 63 indicates that address mapping is mirrored.

The following steps are performed for all DIMM types:

- 16. Send two ZQCL commands.
- 17. Program F2x[1, 0]7C[EnDramInit] = 0.

Send ZQCL command is accomplished by programming F2x[1, 0]7C as follows:

- 1. Program MrsAddress[10] = 1.
- 2. Set SendZQCmd = 1.
- 3. Wait for SendZOCmd = 0.
- 4. Wait 512 MEMCLKs.

Send MRS command for DDR3 initialization is accomplished by programming F2x[1, 0]7C as follows:

- 1. Program MrsBank = 000b.
- 2. If EnDramInit=0 program MrsChipSel=*target chip select*; otherwise all chip selects are automatically selected.
- 3. Program MrsAddress[1:0] = burst length and control method (BL): based on F2x[1, 0]84[BurstCtrl].
- 4. Program MrsAddress[3] = 1.
- 5. Program MrsAddress[6:4,2] = read CAS latency (CL): based on F2x[1,0]88[Tc1].

```
0000b = 4 MEMCLKs.
```

0010b = 5 MEMCLKs.

0100b = 6 MEMCLKs.

0110b = 7 MEMCLKs.

1000b = 8 MEMCLKs.

1010b = 9 MEMCLKs.

1100b = 10 MEMCLKs.

1110b = 11 MEMCLKs.

0001b = 12 MEMCLKs.

- 6. Program MrsAddress[11:9] = write recovery for auto-precharge (WR): based on F2x[1, 0]84[Twr].
- 7. Program MrsAddress[12] = precharge powerdown mode select (PPD): based on F2x[1, 0]84[PchgPDModeSel].
- 8. Set all other bits in MrsAddress to zero.
- 9. Set SendMrsCmd = 1.
- 10. Wait for SendMrsCmd = 0.

Send EMRS(1) command for DDR3 initialization is accomplished by programming F2x[1, 0]7C as follows:

- 1. Program MrsBank = 001b.
- 2. If EnDramInit=0 program MrsChipSel=*target chip select*; otherwise all chip selects are automatically selected.
- 3. Program MrsAddress[5,1] = output driver impedance control (DIC): based on F2x[1, 0]84[DrvImpCtrl].
- 4. Program MrsAddress[9,6,2] = nominal termination resistance of ODT (RTT): based on F2x[1, 0]84[DramTerm].
- 5. Program MrsAddress[11] = TDQS: based on F2x[1, 0]94[RDqsEn].
- 6. Program MrsAddress[12] = output disable (QOFF): based on F2x[1, 0]84[Qoff].
- 7. Set all other bits in MrsAddress to zero.
- 8. Set SendMrsCmd = 1.
- 9. Wait for SendMrsCmd = 0.

Send EMRS(2) command for DDR3 initialization is accomplished by programming the F2x[1, 0]7C as follows:

- 1. Program MrsBank = 010b.
- 2. If EnDramInit=0 program MrsChipSel=*target chip select*; otherwise all chip selects are automatically selected.
- 3. Program MrsAddress[5:3] = CAS write latency (CWL): based on F2x[1, 0]84[Tcwl].
- 4. Program MrsAddress[6] = auto self refresh method (ASR): based on <math>F2x[1, 0]84[ASR].
- 5. Program MrsAddress[7] = self refresh temperature range (SRT): based on F2x[1, 0]84[ASR and SRT].
- 6. Program MrsAddress[10:9] = dynamic termination during writes (RTT\_WR): based on F2x[1, 0]84[DramTermDyn].
- 7. Set all other bits in MrsAddress to zero.
- 8. Set SendMrsCmd = 1.
- 9. Wait for SendMrsCmd = 0.

Send EMRS(3) command for DDR3 initialization is accomplished by programming F2x[1, 0]7C as follows:

- 1. Program MrsBank = 011b.
- 2. If EnDramInit=0 program MrsChipSel=*target chip select*; otherwise all chip selects are automatically selected.
- 3. Program MrsAddress[1:0] = multi purpose register address location (MPR Location): based on F2x[1, 0]84[MprLoc].
- 4. Program MrsAddress[2] = multi purpose register (MPR): based on F2x[1, 0]84[MprEn].
- 5. Set all other bits in MrsAddress to zero.
- 6. Set SendMrsCmd = 1.
- 7. Wait for SendMrsCmd = 0.

### 2.8.7.5.2.1 Software Control Word Initialization

DDR3 data register and clock driver devices on RDIMMs contain up to 16 control words, referred to as RC0 to RC15. Each control word is four bits. These devices are programmed at the bus by (a) presenting the 4-bit address of the control word on [BA2, A2, A1, A0], (b) presenting the 4-bit write data on [BA1, BA0, A4, A3], and (c) asserting both chip selects of a chip select pair.

Send RCW(n) command for DDR3 initialization is accomplished by programming F2x[1, 0]7C and F2x[1, 0]A8[CtrlWordCS] as follows:

- 1. Program MrsBank and MrsAddress.
  - n = [BA2, A2, A1, A0].
  - data = [BA1, BA0, A4, A3].
  - Set all other bits in MrsAddress to zero.

- 2. Program F2x[1, 0]A8[CtrlWordCS]=bit mask for *target chip selects*.
- 3. Set SendControlWord = 1.
- 4. Wait for SendControlWord = 0.

Based on the DIMM raw card version, BIOS programs RC0 to RC5 for the DIMM according to the information in the following table:

Table 30. DDR3 RDIMM Register Control Word Values

| Control          |             | Raw Card Version <sup>1</sup> |             |             |             |             |  |
|------------------|-------------|-------------------------------|-------------|-------------|-------------|-------------|--|
| Word             | A<br>(1Rx8) | B<br>(2Rx8)                   | C<br>(1Rx4) | D<br>(2Rx4) | E<br>(2Rx4) | F<br>(4Rx4) |  |
| RC0              | 0h          | 0h                            | 0h          | 0h          | 0h          | 0h          |  |
| RC1              | Ch          | 0h                            | Ch          | 0h          | 0h          | 0h          |  |
| RC2 <sup>2</sup> | 0X00b       | 0X00b                         | 0X00b       | 0X00b       | 0X00b       | 0X00b       |  |
| RC3              | 0h          | 5h                            | 5h          | Ah          | Ah          | Ah          |  |
| RC4              | 0h          | 0h                            | 5h          | 5h          | 5h          | 5h          |  |
| RC5              | 0h          | 0h                            | 5h          | 5h          | 5h          | 5h          |  |
| RC8              | 0h          | 0h                            | 0h          | 0h          | 0h          | 0h          |  |
| RC9              | 0Ch         | 0Ch                           | 0Ch         | 0Ch         | 0Ch         | 0Ch         |  |

### Notes:

- JEDEC raw card version is determined by reading SPD byte 62.
   R=rank.
- 2. X=0b for 1 or 2 logical RDIMMs per channel. (buffer term is 100 ohms) X=1b for 3 or 4 logical RDIMMs per channel.(buffer term is 150 ohms)

# 2.8.7.6 Phy Fence programming

The DDR phy fence logic used to adjust the phase relationship between the data fifo and the data going to the pad. After any frequency change (see section 2.8.7.7) and before any memory training, BIOS must perform phy fence training for each channel using the following steps:

- 1. BIOS first programs a seed value to the phase recovery engine registers.
- 2. Set  $F2x[1, 0]9C_x08[PhyFenceTrEn]=1$ .
- 3. Wait 200 MEMCLKs.
- 4. Clear  $F2x[1, 0]9C_x08[PhyFenceTrEn]=0$ .
- 5. BIOS reads the phase recovery engine registers F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52.
- 6. Calculate the average value and subtract 8.
- 7. Write the value to F2x[1, 0]9C\_x0C[PhyFence].
- 8. BIOS rewrites F2x[1, 0]9C\_x04, DRAM Address/Command Timing Control Register delays for both channels.

## 2.8.7.7 DRAM Channel Frequency Change

When both DCTs are enabled in unganged mode, BIOS must initialize the frequency of each DCT in order.

This is required for the initial SPD based configuration (when booting from cold or warm reset) and when changing the bus frequency as required for DDR3 DRAM training (see 2.8.7.8.1 [DDR3 Training] on page 85. This is accomplished as follows:

- 1. Program  $F2x[1, 0]9C_x08[DisAutoComp] = 1$ .
- 2. BIOS waits 5 us for the disabling of the compensation engine to complete.
- 3. Program F2x[1, 0]94[MemClkFreq] to the proper operating frequency for the DCTs.
- 4. Program F2x94[MemClkFreqVal]=1 for channel 0.
- 5. BIOS polls F2x[1, 0]98[DctAccessDone].
- 6. When F2x[1, 0]98[DctAccessDone]=0, BIOS programs F2x194[MemClkFreqVal]=1 for channel 1.
- 7. Program  $F2x[1, 0]9C_x08[DisAutoComp] = 0$ .
- 8. BIOS must wait 750 us for the phy compensation engine to reinitialize.

BIOS must not change the DRAM frequency after DRAM device initialization for DDR2 DIMMs and after DRAM training is complete for DDR3 DIMMs.

# 2.8.7.8 DRAM Training

This section describes detailed methods used to train the processor DDR interface to DRAM for optimal functionality and performance. DRAM training is performed by BIOS after initializing the DRAM controller (see 2.8.7.5 [DRAM Device Initialization] on page 78). It may be entirely BIOS controlled or BIOS may use hardware to assist with the training process in the case of DDR3.

If the DCTs are to be operated in ganged mode (see section 2.8 [DRAM Controllers (DCTs)] on page 60) then the training algorithms are done in ganged mode. Likewise, if the DCTs are unganged then the training is done unganged. However, when in ganged mode, training should use the worst case F2x[1, 0]78[MaxRdLatency] that exists between either DRAM channel.

BIOS must program MSRC001\_1023[WbEnhWsbDis]=1 before training and program MSRC001\_1023[WbEnhWsbDis]=0 when DRAM training is complete.

DRAM training of the ECC byte lanes is accomplished after the data lanes are trained. This is described in section 2.8.7.8.3 [ECC Byte Lane Training] on page 96.

### **2.8.7.8.1 DDR3** Training

DDR3 training is a superset of DDR2 training. DDR3 requires the same training process for DQS receiver enable and DQ-DQS position that is accomplished for DDR2. See section 2.8.7.8.2 [DDR2 DRAM Training] on page 90. While DDR2 uses a star topology for command and address, DDR3 employs a flyby topology where each tap point on the command and address bus is high impedance. Write levelization (DDR3-defined tDQSS margining) solves the MEMCLK to DQS skew problem caused by the flyby topology by using the phy's ability to delay the launch of each DQS going to the DIMM such that at each DRAM chip, DQS is seen to coalesce with incoming MEMCLK. Levelization is done per channel and per DIMM. Levelization can be performed on each channel in parallel regardless of whether the channels are ganged or not. A two pass levelization is necessary if the target MEMCLK frequency is different than 400MHz.

Some restrictions for write levelization training follow:

- Write levelization must be done before DQS receiver enable and DQ-DQS position training.
- No memory reads or writes to DRAM should occur before write levelization training; otherwise, write levelization training may fail.

There are two methods to accomplish write levelization training: phy assisted or BIOS based training.

## 2.8.7.8.1.1 Phy Assisted Write Levelization

Phy assisted write levelization involves using the DDR phy to detect where the edge of DQS is with respect to MEMCLK on the DIMM for write accesses. The following describes the steps used in phy assisted write levelization training:

### Pass 1:

- Program F2x[1, 0]9C\_x08[WrtLlTrEn]=0.
- Configure the DRAM interface for a 400MHz MEMCLK (DDR3-800) frequency.
- Disable auto refresh by configuring F2x[1, 0]8C[DisAutoRefresh] = 1.
- Disable ZQ calibration short command by configuring F2x[1, 0]94[ZqcsInterval] = 00b.

## For each DIMM or chip select pair of a quad rank DIMM:

- 1. Specify the target DIMM that is to be trained by programming F2x[1, 0]9C\_x08[TrDimmSel].
- 2. Prepare the DIMMs for write levelization using DDR3-defined MR commands.
  - A quad rank DIMM is treated as two DIMMs. In the following steps, the target rank and next subsequent rank of a quad rank DIMM are referred to as the target DIMM. The remaining two ranks are treated as a non-target DIMM.
  - Configure the DCT to send initialization MR commands to the target DIMM by programming the F2x[1, 0]7C register using the following steps.
    - Program F2x[1, 0]7C[MrsChipSel[2:0]] for the current rank to be trained.
    - Program F2x[1, 0]7C[MrsBank[2:0]] for the appropriate internal DRAM register that defines the required DDR3-defined function for write levelization.
    - Program F2x[1, 0]7C[MrsAddress[15:0]] to the required DDR3-defined function for write levelization.
    - Program F2x[1, 0]7C[SendMrsCmd]=1 to initiate the command to the specified DIMM.
    - Wait for F2x[1, 0]7C[SendMrsCmd] to be cleared by hardware.
  - Using the above DIMM initialization steps, configure the target DIMMs normally as follows:
    - All ranks of the target DIMM are set to write levelization mode.
    - Enable the output driver of the first rank of the target DIMM.
    - Disable the output drivers of all other ranks for the target DIMM.
    - Write leveling mode enable and output driver enable/disable can use a single MRS command; one to each rank separately.
    - For two DIMMs in the system, program the Rtt\_Nom value for the target DIMM to the weakest termination (RZQ/2) using a send MR command. Otherwise, configure the target DIMM normally. See section 2.8.7.4.7 for more information on normal ODT settings.
  - Configure the non-target DIMM normally (See section 2.8.7.4.7).
- 3. After the DIMMs are configured, BIOS waits 40 MEMCLKs to satisfy DDR3-defined internal DRAM timing.
- 4. Configure the processor's DDR phy for write levelization training:
  - Program F2x[1, 0]9C\_x08[WrLvOdt[3:0]] to the proper ODT settings for the current memory subsystem configuration.
  - Program F2x[1, 0]9C\_x08[WrLvOdtEn]=1.
  - Wait 10 MEMCLKs to allow for ODT signal settling.
  - Program an initialization value to registers F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52 to set the gross and fine delay for all the byte lane fields. If the target frequency is different than 400MHz, BIOS must execute two training passes for each DIMM.
    - For Pass 1 at a 400MHz MEMCLK frequency, use an initial total delay value specified in 2.8.7.8.1.2.2 [Write Leveling Seed Value] on page 90.

- For Pass 2, at the target MEMCLK frequency, use the results of the Pass 1 as the initial delay values for the seed. Note: if BIOS intends to execute phy assisted DQS receiver enable training (2.8.7.8.2.1 [Phy Assisted DQS Receiver Enable Training] on page 90) then Pass 2 of this section must not be executed until after Pass 1 of 2.8.7.8.2.1 [Phy Assisted DQS Receiver Enable Training] on page 90 is complete.
- Program F2x[1, 0]9C\_x08[WrtLvTrMode]=0 for phy assisted training.
- Program  $F2x[1, 0]9C \times 08[TrNibbleSel]=0^1$ .
- 5. Begin write levelization training:
  - Program F2x[1, 0]9C\_x08[WrtLlTrEn]=1.
  - Wait 200 MEMCLKs. If executing Pass 2, wait 32 MEMCLKs.
  - Program F2x[1, 0]9C\_x08[WrtLlTrEn]=0.
  - Read from registers F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52 to get the gross and fine delay settings for the target DIMM and save these values.
- 6. Configure DRAM Phy Control Register so that the phy stops driving write levelization ODT.
  - Wait 10 MEMCLKs to allow for ODT signal settling.
- 7. Program the target DIMM back to normal operation by configuring the following: (see step #2 above)
  - Configure all ranks of the target DIMM for normal operation.
  - Enable the output drivers of all ranks of the target DIMM.
  - For a two DIMM system, program the Rtt value for the target DIMM to the normal operating termination: F2x[1, 0]84[Dram Term]= 011b (RZQ/6 = 40 ohms).

If the target MEMCLK frequency is different than 400MHz, execute Pass 2, steps #8 through #11 below; else execute step #12:

### Pass 2:

- 8. Prepare the memory subsystem for the target MEMCLK frequency. Note: BIOS must program both DCTs to the same frequency.
  - Program F2x[1, 0]90[EnterSelfRefresh]=1.
  - Wait until the hardware resets F2x[1, 0]90[EnterSelfRefresh]=0.
  - Program  $F2x[1, 0]9C_x08[DisAutoComp] = 1$ .
  - Program F2x[1, 0]94[MemClkFreqVal] = 0.
  - Program F2x[1, 0]94[MemClkFreq] to specify the target MEMCLK frequency.
  - Program F2x[1, 0]94[MemClkFreqVal] = 1.
  - Wait until F2x[1, 0]94[FreqChgInProg]=0.
  - Program  $F2x[1, 0]9C_x08[DisAutoComp] = 0$ .
  - Program F2x[1, 0]90[ExitSelfRef]=1 for both DCTs.
  - Wait until the hardware resets F2x[1, 0]90[ExitSelfRef]=0.
  - Perform Phy Fence retrainingSee section 2.8.7.6.
- 9. Configure the DCT to send initialization MR commands: BIOS must reprogram Twr, Tcwl, and Tcl based on the new MEMCLK frequency. Program F2x[1, 0]7C similar to step #2 in Pass 1 above for the new DIMM values.
- 10. Multiply the previously saved delay values in Pass 1, step #5 by (target frequency)/400 to find the gross and fine delay initialization values at the target frequency. Use these values as the initial seed values when executing Pass 2, step #4.
- 11. For each DIMM, execute steps #1 through #7 in Pass 1 above.
- 12. For each DIMM, program the gross and fine delays for each field of registers F2x[1, 0]9C\_x[45:30] with the corresponding final saved delay settings.
- 13. Program F2x[1, 0]8C[DisAutoRefresh] = 0.
- 14. Program F2x[1, 0]94[ZqcsInterval] to the proper interval for the current memory configuration.

Note 1: If BIOS needs to train based on both the lower and upper nibbles it can program the F2x[1,

0]9C\_x08[TrNibbleSel] register to specify which nibbles (0=lower, 1=upper) the training uses and then repeat the Pass 1 steps above. BIOS then averages the training values for the nibbles of each byte and uses the average for the delay settings.

# 2.8.7.8.1.2 BIOS Based Write Levelization Training

BIOS controlled write levelization involves using the BIOS to detect where the edge of DQS is with respect to the memory clock on the DIMM for write accesses to each lane. In the steps below, a lane is used to describe either a 4-bit wide data group or an 8-bit wide data group, each with its own write DQS timing control. Normally, an 8-bit lane size is used.

The following describes the steps used for BIOS controlled write levelization training:

### Pass 1:

- Program F2x[1, 0]9C\_x08[WrtLlTrEn]=0.
- Configure the DRAM interface for a 400MHz MEMCLK (DDR3-800).
- Disable auto refresh by configuring F2x[1, 0]8C[DisAutoRefresh] = 1.
- Disable ZQ calibration short command by configuring F2x[1, 0]94[ZqcsInterval] = 00b.

# For each chip select pair:

- 1. Specify the target DIMM that is to be trained by programming F2x[1, 0]9C\_x08[TrDimmSel].
- 2. Prepare the DIMMs for write levelization using DDR3-defined MR commands. Execute Pass 1, steps #2 and #3 in section 2.8.7.8.1.1 [Phy Assisted Write Levelization] on page 86.
- 3. Configure the phy for write levelization training:
  - Program F2x[1, 0]9C\_x08[WrLvOdt[3:0]] to the proper ODT settings for the current memory subsystem configuration.
  - Program F2x[1, 0]9C\_x08[WrLvOdtEn]=1.
  - Wait 10 MEMCLKs to allow for ODT signal settling.
  - Program an initialization value to registers F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52 to set the gross and fine delay for all the byte lane fields. If the target frequency is different than 400MHz, BIOS must execute two training passes for each DIMM.
    - For Pass 1 at a 400MHz MEMCLK frequency, use an initial total delay value specified in 2.8.7.8.1.2.2 [Write Leveling Seed Value] on page 90.
    - For Pass 2, at the target MEMCLK frequency, use the results of the Pass 1 as the initial delay values for the seed.
  - Program F2x[1, 0]9C\_x08[WrtLvTrMode]=1 for BIOS controlled training.
  - Program  $F2x[1, 0]9C \times 08[TrNibbleSel]=0^1$ .
- 4. Perform write leveling of the devices on the DIMM as described in section 2.8.7.8.1.2.1.
- 5. Program F2x[1, 0]9C x08[WrLvOdtEn]=0 so that the phy stops driving write levelization ODT.
  - Wait 10 MEMCLKs to allow for ODT signal settling.
- 6. Program the target DIMM back to normal operation by configuring the following (See section 2.8.7.8.1.1 [Phy Assisted Write Levelization] on page 86 Pass 1, step #2):
  - Configure all ranks of the target DIMM for normal operation.
  - Enable the output drivers of all ranks of the target DIMM.
  - For a two DIMM system, program the Rtt value for the target DIMM to the normal operating termination: F2x[1, 0]84[Dram Term]= 011b (RZQ/6 = 40 ohms).

If the target MEMCLK frequency is different than 400MHz, execute Pass 2, steps #7 through #10 below; else execute step #11:

# Pass 2:

- 7. Prepare the memory subsystem for the target MEMCLK frequency. Note: BIOS must change the frequency on both channels together. Both channels must be at the same frequency.
  - Program F2x[1, 0]90[EnterSelfRefresh]=1.
  - Wait until the hardware resets F2x[1, 0]90[EnterSelfRefresh]=0.
  - Program F2x[1, 0]9C\_x08[DisAutoComp] =1.
  - Program F2x[1, 0]94[MemClkFreqVal] = 0.
  - Program F2x[1, 0]94[MemClkFreq] to specify the target MEMCLK frequency.
  - Program F2x[1, 0]94[MemClkFreqVal] = 1.
  - Wait until F2x[1, 0]94[FreqChgInProg]=0.
  - Program F2x[1, 0]9C\_x08[DisAutoComp] =0.
  - Program F2x[1, 0]90[ExitSelfRef]=1 for both DCTs.
  - Wait until the hardware resets F2x[1, 0]90[ExitSelfRef]=0.
  - Perform Phy Fence retraining See section 2.8.7.6.
- 8. Configure the DCT to send initialization MR commands: BIOS must reprogram Twr, Tcwl, and Tcl based on the new MEMCLK frequency. Program F2x[1, 0]7C similar to step #2, Pass 1 in section 2.8.7.8.1.1 [Phy Assisted Write Levelization] on page 86 for the new DIMM values.
- 9. Multiply the previously saved delay values by (target frequency)/400 MHz to find the coarse delay and fine delay seed at the target frequency which is used in the second pass.
- 10. For each DIMM, execute steps #1 through #6 in Pass 1 above.
- 11. each DIMM, program the gross and fine delay fields for each byte lane of registers F2x[1, 0]9C\_x[45:30] with the corresponding saved final delay settings.
- 12. Program F2x[1, 0]8C[DisAutoRefresh] = 0.
- 13. Program F2x[1, 0]94[ZqcsInterval] to the proper interval for the current memory configuration.

Note: If BIOS needs to train based on both the lower and upper nibbles it can program the F2x[1, 0]9C\_x08[TrNibbleSel] register to specify which nibbles (0=lower, 1=upper) the training uses and then repeat the Pass 1 steps above. BIOS then averages the training values for the nibbles of each byte and uses the average for the delay settings.

### 2.8.7.8.1.2.1 Write Leveling

BIOS performs write leveling of the devices on a DIMM using the following steps, for different total delay values:

- 1. Program F2x[1, 0]9C\_x08[WrtLlTrEn]=1.
- 2. Wait 32 MEMCLKs.
- 3. Program  $F2x[1, 0]9C \times 08[WrtLlTrEn]=0$ .
- 4. BIOS reads from F2x[1, 0]9C\_x53[WrtLvErr[8:0]] to get the current state of each byte lane field.
- 5. Compare the state of each bit of F2x[1, 0]9C\_x53[WrtLvErr[8:0]]; if the bit=0, increment the total delay field for the corresponding byte lane of registers F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52; if the bit=1, decrement the total delay field for the corresponding byte lane in registers F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52. If the error bit is steady state 0, increment the gross delay value until a transition is seen. At this point, begin decrementing the fine delay until another transition is seen, then, begin incrementing the fine delay until another transition is seen.
- 6. BIOS loops back to step #1 with the adjusted gross and fine delay settings until it sees a 0 to 1 or 1 to 0 transition.
- 7. Save the total delay values for registers  $F2x[1, 0]9C_x[51:50]$  and  $F2x[1, 0]9C_x52$ .

### 2.8.7.8.1.2.2 Write Leveling Seed Value

BIOS uses a seed value for the first pass (400MHz) of write leveling using the following guidelines:

- For Unbuffered DIMMs, the seed for the total delay is 1Fh. This represents a 1UI (UI=.5MEMCLK) delay.
- For Registered DIMMs, if bit 0 of RCW2 (programmed with A3) is clear, then the seed for the total delay is 41h.
- For Registered DIMMs, if bit 0 of RCW2 is set, then the seed for the total delay is 51h.

*Note*: The seed value represents the actual clock delay and is platform dependent. The platform vendor may need to characterize and adjust this value for proper write levelization training. The seed delay value must fall within +/- 1.20 ns, including PVT and jitter, of the measured clock delay.

## 2.8.7.8.2 DDR2 DRAM Training

DDR2 DRAM training is used to determine when to enable the processor's DQS receivers for reads and to position the DQS in the center of the data eye for both reads and writes. DDR2 training is performed at the desired memory clock rate.

Part of the DDR2 training process requires BIOS to calculate a latency component called F2x[1, 0]78[MaxRd-Latency]. This is described in section 2.8.7.8.4 [Calculating MaxRdLatency] on page 98.

# 2.8.7.8.2.1 Phy Assisted DQS Receiver Enable Training

The following section describes the phy assisted DQS receiver enable training algorithm. Phy assisted DQS receiver enable training involves using the DDR phy to determine the values required to program the DRAM DQS Receiver Enable Timing Control registers (see F2x[1, 0]9C\_x[2B:10]). This procedure optimizes the timing used to turn on the receiver enables when doing reads from the DRAM. Receiver enable training is performed after write levelization (see section 2.8.7.8.1 [DDR3 Training] on page 85).

Phy assisted training is accomplished on a per channel, per DIMM basis. It is not necessary to train each rank of a specific DIMM as the skew between ranks on the same DIMM is negligible. For DDR2, a single training pass is required for each DIMM. For DDR3, a two pass DQS receiver enable training is necessary if the target MEMCLK frequency is different than 400MHz.

The following describes the steps used for the phy assisted receiver enable training:

## Pass 1:

- For DDR3, configure the DRAM interface for a 400MHz MEMCLK (DDR3-800). For DDR2, configure the DRAM interface for the target frequency.
- Disable auto refresh by configuring F2x[1, 0]8C[DisAutoRefresh] = 1.
- Disable ZQ calibration short command by configuring F2x[1, 0]94[ZqcsInterval] = 00b.

#### For each DIMM:

- 1. Prepare the DIMMs for training:
  - Specify the DIMM to be trained by configuring [The DRAM Phy Control Register] F2x[1, 0]9C\_x08[TrDimmSel].
  - For DDR3, configure the first chip select of the target DIMM for 8-beat burst length mode using DDR3-defined MR commands.
    - Configure the DCT to send initialization MR commands to the target DIMM by programming the

F2x[1, 0]7C register using the following steps.

- Program F2x[1, 0]7C[MrsChipSel[2:0]] for the current rank to be trained.
- Program F2x[1, 0]7C[MrsBank[2:0]] for the appropriate internal DRAM register that defines the required DDR3-defined function for training.
- Program F2x[1, 0]7C[MrsAddress[15:0]] to the required DDR3-defined function for training.
- Program F2x[1, 0]7C[SendMrsCmd]=1 to initiate the command to the specified DIMM.
- Wait for F2x[1, 0]7C[SendMrsCmd] to be cleared by hardware.
- Wait 20 MEMCLKs to allow for command completion.
- For DDR2, no additional DIMM configuration is needed for training.
- 2. Prepare the phy for DQS receiver enable training.
  - Program the DRAM Phase Recovery Control Registers (see F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52) with a gross and fine delay seed value. The following steps are taken to determine the seed values needed to program the DRAM Phase Recovery Control Registers for each byte lane:
    - For Pass 1:
      - BIOS starts with the delay value obtained from the first pass of write levelization training that was done in section 2.8.7.8.1 [DDR3 Training] on page 85 and add a delay value of 26h. This corresponds to a 1.2UI (UI=.5MEMCLK) delay and is called SeedTotal.
      - Next, determine the gross component of SeedTotal. SeedGrossPass1=SeedTotal DIV 32.
      - Then, determine the fine delay component of SeedTotal. SeedFinePass1=SeedTotal MOD 32.
      - Use SeedGrossPass1 to determine SeedPreGrossPass1: SeedPreGrossPass1=1 if SeedGrossPass1 is odd; SeedPreGrossPass1=2 if SeedGrossPass1 is even. This allows the phase recovery engine a positive and negative adjustment range.
      - The last term that BIOS needs to calculate for the seed is called SeedPass1Remainder. SeedPass1Remainder=SeedGrossPass1-SeedPreGrossPass1. BIOS saves this value which is used to determine the final delay value. This is necessary because the phy does not have the full range of delay adjustment.
      - BIOS programs registers F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52) with SeedPreGrossPass1 and SeedFinePass1 from the preceding steps.
    - For Pass2, for each byte lane, BIOS uses executes the following steps and uses the results obtained from Pass 1 to determine the seed value. These steps are needed only if the target MEMCLK frequency is not 400MHz.
      - Determine the total seed based on the delay value used in Pass1: SeedTotalPass2=(Pass1DqsRcvEnDly\*target frequency)/400.
      - Next, determine the gross component of SeedTotalPass2: SeedGrossPass2=SeedTotalPass2 DIV 32.
      - Then, BIOS determines the fine delay component of SeedTotalPass2: SeedFinePass2=SeedTotalPass2 MOD 32.
      - Use SeedGrossPass2 to determine SeedPreGrossPass2: SeedPreGrossPass2=1 if SeedGrossPass2 is odd; SeedPreGrossPass2=2 if SeedGrossPass2 is even. This allows the phase recovery engine a positive and negative adjustment range.
      - BIOS calculates SeedPass2Remainder. SeedPass2Remainder=SeedGrossPass2-SeedPreGrossPass2. BIOS saves this value which is used to determine the final delay value. This is necessary because the phy does not have the full range of delay adjustment.
      - BIOS programs registers F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52) with SeedPreGrossPass2 and SeedFinePass2 from the preceding steps.
  - For DDR2, BIOS only executes 1 pass for each DIMM. BIOS uses a seed value of 26h. This corresponds to a 1.2UI (UI=.5MEMCLK) delay.
- 3. BIOS initiates the phy assisted receiver enable training by programming F2x[1, 0]9C\_x08[Dqs-RcvTrEn]=1.
- 4. BIOS begins sending out of back-to-back reads to create a continuous stream of DQS edges on the DDR interface.

- Program F2x11C[MctPrefReqLimit] = 01Fh.
- BIOS sends 32 read requests to the target rank. The reads must be to consecutive cache lines (i.e. 64 bytes apart) and must not cross a naturally aligned 4 Kbyte boundary. To generate the needed continuous read or write data streams for phy assisted receiver enable training, see section 2.8.7.8.5 [Continuous Pattern Generation] on page 99.

Note: the phy implements a counter so that phase recovery engine is halted during down time between streams of DQS edges.

- 5. Repeat step #4 two more times.
- 6. Wait 200 MEMCLKs.
- 7. Program [The DRAM Phy Control Register] F2x[1, 0]9C\_x08[DqsRcvTrEn]=0 to stop the DQS receive enable training.
- 8. Read from DRAM Phase Recovery Control Registers F2x[1, 0]9C\_x[51:50] and F2x[1, 0]9C\_x52 to get the gross and fine delay values.
- 9. Calculate the corresponding final delay values: For Pass 1, F2x[1, 0]9C\_x[2B:10][DqsRcvEnGrossDelay] = SeedPass1Remainder+F2x[1, 0]9C\_x[52:50]PhRecGrossDlyByte; F2x[1, 0]9C\_x[2B:10][DqsRcvEn-FineDelay]=F2x[1, 0]9C\_x[52:50]PhRecFineDlyByte. For Pass 2, F2x[1, 0]9C\_x[2B:10][DqsRcvEn-GrossDelay] = SeedPass2Remainder+F2x[1, 0]9C\_x[52:50]PhRecGrossDlyByte; F2x[1, 0]9C\_x[2B:10][DqsRcvEnFineDelay]=F2x[1, 0]9C\_x[52:50]PhRecFineDlyByte.
- 10. Save the delay values. Note: if BIOS is required to do nibble based write levelization and DQS receive enable training (for example, on X4 DIMM systems), repeat steps #2 through #9 above for the other nibbles by configuring [The DRAM Phy Control Register] F2x[1, 0]9C\_x08[TrNibbleSel].

Perform steps #11 through #17 below if the system is using DDR3 type DIMMs at a frequency other than 400MHz else execute steps #14 through #17 only.

### Pass 2:

- 11. Prepare the memory subsystem for the target MEMCLK frequency. Note: Both channels must be at the same frequency.
  - Program F2x[1, 0]90[EnterSelfRefresh]=1.
  - Wait until the hardware resets F2x[1, 0]90[EnterSelfRefresh]=0.
  - Program F2x[1, 0]94[MemClkFreqVal] = 0.
  - Program F2x[1, 0]94[MemClkFreq] to specify the target MEMCLK frequency.
  - Program F2x[1, 0]94[MemClkFreqVal] = 1.
  - Wait until F2x[1, 0]94[FreqChgInProg]=0.
  - Program F2x[1, 0]90[ExitSelfRef]=1 for both DCTs.
  - Wait until the hardware resets F2x[1, 0]90[ExitSelfRef]=0.
- 12. Configure the DCT to send initialization MR commands: BIOS must reprogram Twr, Tcwl, and Tcl based on the new MEMCLK frequency. Program F2x[1, 0]7C similar to step #2, Pass 1 in section 2.8.7.8.1.1 [Phy Assisted Write Levelization] on page 86 for the new DIMM values.
- 13. For each DIMM, execute steps #2 through #9 in Pass 1 above.
- 14. For DDR3, configure the target DIMM back to normal operation using MRS commands.
  - Wait 20 MEMCLKs to allow for command completion.
- 15. Program [The DRAM DQS Receiver Enable Timing Control Registers] F2x[1, 0]9C\_x[2B:10] with the corresponding final delay values: F2x[1, 0]9C\_x[2B:10][DqsRcvEnGrossDelay] = SeedPass2Remainder+F2x[1, 0]9C\_x[52:50]PhRecGrossDlyByte; F2x[1, 0]9C\_x[2B:10][DqsRcvEnFineDelay]=F2x[1, 0]9C\_x[52:50]PhRecFineDlyByte.
- 16. Program F2x[1, 0]8C[DisAutoRefresh] = 0.
- 17. Program F2x[1, 0]94[ZqcsInterval] to the proper interval for the current memory configuration.

# 2.8.7.8.2.2 BIOS Based DQS Receiver Enable Training

This section describes the BIOS algorithm used to determine the values required to program the DRAM DQS Receiver Enable Timing Control registers (see F2x[1, 0]9C\_x[2B:10]) for read DQS receiver enable position training. DQS receiver enable training determines when to enable the DQS receivers for reads on each DIMM and is accomplished in two training phases. The first phase is used to detect when the DIMM starts driving the DDR-defined read preamble phase of a read transaction. The second phase is used to determine the effective width of the read preamble and is optional for DDR2. The second training phase for DQS receiver enable is used to optimally place the receiver enable setting in the center of the read preamble. It can be used to obtain better performance margin in some circumstances. DQS receiver enable training is done per channel, per DIMM, per byte. The second phase must be done after DQS position training is complete. See 2.8.7.8.2.3 [DQS Position Training] on page 95 for details on how to train the DRAM for proper DQS position.

The first phase of DQS receiver training is performed using the following steps:

### For each channel:

- 1. Program  $F2x[1, 0]9C_x[102:101, 02:01]:F2x[1, 0]9C_x[103, 03]$  to 00h for all bytes.
- 2. Program  $F2x[1, 0]9C_x[106:105, 06:05]$  and  $F2x[1, 0]9C_x[107, 07]$  to 2Fh for all bytes.
- 3. Program F2x[1, 0]78[DqsRcvEnTrain]=1.
- 4. Select two test addresses for each rank present. The addresses must be cache line (64 byte) aligned and separated by 2Meg starting with the first rank.
- 5. Write one cache line where each byte is 55h to the first test address for each rank.
- 6. Write one cache line where each byte is AAh to the second test address for each rank.
- 7. For each rank:
- 8. For all lanes, program the gross and fine timing fields in F2x[1, 0]9C\_x[2B:10] with a starting total delay value: For DDR2, the starting total delay value is zero. For DDR3, the starting value corresponds to the write DQS delays found during write leveling. For the start value and each subsequent total delay value in F2x[1, 0]9C\_x[2B:10] do the following:
  - a. Program F2x[1, 0]78[MaxRdLatency] with the current greatest value of F2x[1, 0]9C\_x[2B:10]. See section 2.8.7.8.4 [Calculating MaxRdLatency] on page 98.
  - b. Read the first test address for the current rank and compare each byte of the first data beat with each byte of the value written in step 5 above.
  - c. Reset the read pointer in the DRAM controller receive FIFO by writing the current corresponding DQS receiver enable delay settings to each byte in each corresponding F2x[1, 0]9C\_x[2B:10] register.
  - d. Read the second test address for the rank and compare each byte of the first data beat with each byte of the value written in step 6 above.
  - e. Save each DQS receiver enable settings that passes for both read patterns. Continue to step 8 below
  - f. Increment the current total delay DQS receiver enable setting by one for each failing byte lane in F2x[1, 0]9C\_x[2B:10] and repeat steps a through e. The total delay is the sum of the gross and fine delay fields.
- 9. For each DIMM (chip select pair):
  - Program each F2x[1, 0]9C\_x[2B:10] register with the first F2x[1, 0]9C\_x[2B:10] register settings that passed for all ranks in the steps above plus 0.5 MEMCLK.
  - Save the first DQS receiver enable delay settings that pass for all ranks. This is used in phase two below.
- 10. Program F2x[1, 0]78[MaxRdLatency] with the current greatest value of F2x[1, 0]9C\_x[2B:10]. See section 2.8.7.8.4 [Calculating MaxRdLatency] on page 98.
- 11. Program F2x[1, 0]78[DqsRcvEnTrain]=0.

Before completing the DQS receiver enable training, BIOS must complete the DQS position training described

in the next section 2.8.7.8.2.3 [DQS Position Training] on page 95. The second training phase for DQS receiver enable is completed using the following procedure:

- 1. Select two test addresses for each chip select present in the system. The addresses must be cache line (64 byte) aligned and separated by 2Meg starting with the first rank.
- 2. Program F2x[1, 0]78[DqsRcvEnTrain]=1.
- 3. Program the total delay setting for each byte of each F2x[1, 0]9C\_x[2B:10] register for the DIMM with the corresponding [The DRAM DQS Receiver Enable Timing Control Registers] F2x[1, 0]9C\_x[2B:10] delay setting that passed for all ranks in phase one above.
- 4. Write a cache line to the first test address for each rank with the following data pattern:

```
1234_5678_8765_4321h
2345_6789_9876_5432h
5938_5824_3049_6724h
2449_0795_9993_8733h
4038_5642_3846_5245h
2943_2163_0506_7894h
1234_9045_9872_3467h
1238_7634_3458_7623h
```

5. Write a cache line to the second test address for each rank with the following data pattern:

```
1234_5678_8765_4321h
2345_6789_9876_5432h
5938_5824_3049_6724h
2449_0795_9993_8733h
4038_5642_3846_5245h
2943_2163_0506_7894h
1234_9045_9872_3467h
1238_7634_3458_7623h
```

### 6. For each channel:

- For each rank:
  - a. Write the current DQS receiver enable total delay settings for each byte lane in each F2x[1, 0]9C\_x[2B:10] register for the current rank.
  - b. Program F2x[1, 0]78[MaxRdLatency] with the current greatest value of F2x[1, 0]9C\_x[2B:10]. See section 2.8.7.8.4 [Calculating MaxRdLatency] on page 98.
  - c. Read the first test address for the rank and compare the data read with the written value from step 3 above
  - d. Reset the read pointer in the DRAM controller FIFO by writing the current corresponding DQS receiver enable delay settings for each byte lane in each corresponding F2x[1, 0]9C\_x[2B:10] register.
  - e. Read the second test address for the current rank and compare the data read with the expected value from step 4 above.
  - f. Save the total delay F2x[1, 0]9C\_x[2B:10] setting that passes for both read patterns to identify a range of passing values for each byte lane.
  - g. Increment the current total delay F2x[1, 0]9C\_x[2B:10] setting by one for each byte lane in F2x[1, 0]9C\_x[2B:10] and repeat steps a through f incrementing through all passing values for each byte lane until a fail setting is reached.
- 7. For each DIMM (chip select pair):
  - For each total delay setting in each  $F2x[1, 0]9C_x[2B:10]$  register saved in phase 2, calculate the median value for the passing range obtained in phase 2, step #6 above. This centers the DQS receiver enable within the preamble and is the final total delay setting to be used for each byte lane in each  $F2x[1, 0]9C_x[2B:10]$

register.

- 8. Program F2x[1, 0]78[MaxRdLatency] with the current greatest value of F2x[1, 0]9C\_x[2B:10] in phase 2, step 7 above. See section 2.8.7.8.4 [Calculating MaxRdLatency] on page 98.
- 9. Program F2x[1, 0]78[DqsRcvEnTrain]=0.

## 2.8.7.8.2.3 DQS Position Training

DQS position training is used to place the DQS strobe in the center of the DQ data eye. Determining the correct DRAM DQS delay settings for both reads and writes must be performed using a two dimensional search of the read and write delay settings. This section describes the algorithm used to determine the values required to program the DRAM Write Data Timing registers (see F2x[1, 0]9C\_x[102:101, 02:01] and F2x[1, 0]9C\_x[103, 03]) and the DRAM Read DQS Timing Control registers (see F2x[1, 0]9C\_x[106:105, 06:05] and F2x[1, 0]9C\_x[107, 07]) registers for DQS position training. Read DQS and DRAM Write Data timing adjustments for each DIMM are controlled by registers specified in table Table 31 . To generate the needed continuous read or write data streams for DQS position training, see section 2.8.7.8.5 [Continuous Pattern Generation] on page 99.

Table 31: DIMM to timing register mapping<sup>2</sup> for revision B

| DDR Type-Rate          | DIMM controlled by:<br>F2x[1, 0]9C_x[02:01];<br>F2x[1, 0]9C_x[03];<br>F2x[1, 0]9C_x[06:05];<br>F2x[1, 0]9C_x[07] | DIMM controlled by:<br>F2x[1, 0]9C_x[102:101];<br>F2x[1, 0]9C_x[103];<br>F2x[1, 0]9C_x[106:105];<br>F2x[1, 0]9C_x[107] |
|------------------------|------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| DDR2-400               | All DIMMs                                                                                                        | None                                                                                                                   |
| DDR2-533               | All DIMMs                                                                                                        | None                                                                                                                   |
| DDR2-667               | All DIMMs                                                                                                        | None                                                                                                                   |
| DDR2-800               | DIMM 0                                                                                                           | DIMM 1                                                                                                                 |
| DDR3-800               | DIMM 0                                                                                                           | DIMM 1                                                                                                                 |
| DDR2-1066 <sup>2</sup> | DIMM 0                                                                                                           | DIMM 1                                                                                                                 |
| DDR3-1333              | DIMM 0                                                                                                           | DIMM 1                                                                                                                 |
| DDR3-1600              | DIMM 0                                                                                                           | DIMM 1                                                                                                                 |

- 1. To ensure unique values are written to each timing control register, BIOS must program these registers in consecutive DIMM order; i.e., program DIMM 0 register values first followed by the DIMM 1 values, etc.
- 2. The processor supports only one unbuffered DDR2-1066 DIMM per channel.
- 1. Select three test addresses for each rank present in the system. The addresses must be cache line (64 byte) aligned. Fill all three addresses with cachelines of identical data for each byte location.
- 2. For each channel:
  - For each byte lane:
    - · For each rank:

# **DRAM Write Data Timing Loop:**

- For each DRAM Write Data Timing setting of the current byte:
  - Write the current write DQS delay value to the DRAM Write Data Timing register for the current byte lane.
  - Write the DRAM training pattern to the first test address for the rank.

### **DRAM Read DOS Timing Control Loop:**

• For each read delay setting for the DRAM Read DQS Timing Control register:

- a. Write the current DRAM Read DQS Timing Control delay setting for the current byte lane.
- b. Read the DRAM training pattern from the first test address three times.
- c. If the training pattern is read correctly, record the read position for the current byte lane as a pass; otherwise record the result as a fail.
- d. Increment the DQS Read Timing Control Register setting for the current byte lane by two and continue in this **DRAM Read DQS Timing Control Loop**.
- Process the array of results from step c above and determine the longest string of consecutive Read DQS values with passing results.
- If the read DQ to DQS delay setting for the current byte lane contains three or more consecutive delay values with passing results, then exit the **DRAM Write Data Timing Loop** after programming the Read DQS Timing Control register with the average value of the smallest and largest values in the string of consecutive passing results.
- Increment the Write DQS Timing Control Register byte for the current byte lane and continue the **DRAM Write Data Timing Loop**.
- Write the Read DQS Timing Control register setting for the current byte with a value that represents the center position of the passing region.
- Write 0 to the DRAM Write Data Timing register for the current byte lane.
- For each DRAM Write Data Timing register setting:
  - a. Write the current DRAM DQS timing control register delay setting for the current byte lane
  - b. Write 0's to the three test addresses for the current rank.
  - c. Write the DRAM training pattern to the three test addresses for the current rank.
  - d. Read the DRAM training pattern from the three test addresses.
  - e. If the training pattern is read correctly from each test address mark the DRAM Write Data Timing setting for the current byte lane as a pass.
  - f. Increment the DRAM DQS write timing register byte for the current byte lane and go to step a.
- Compare the passing regions for the current byte lane for each rank to determine a mutually centered region that passes for all ranks.
- Write the Read DQS Timing Control register for the current byte lane with the centered delay setting of the mutually passing region for reads.
- Write the DRAM Write Data Timing register for the current byte with the centered delay position of the mutual passing region for writes.

## 2.8.7.8.3 ECC Byte Lane Training

Because the ECC lanes of the DRAM interface are not visible to software additional steps are necessary in order to program the proper delay settings for the ECC lanes. This affects the BIOS controlled training algorithms described above in sections 2.8.7.8.1.2 [BIOS Based Write Levelization Training] on page 88, 2.8.7.8.2.2 [BIOS Based DQS Receiver Enable Training] on page 93, and 2.8.7.8.2.3 [DQS Position Training] on page 95. Also, the different DDR3 DRAM layout topologies makes calculating the delay values of the ECC lanes problematical. However, in most cases, a simple averaging can be performed that yields reasonable delay values for the ECC lanes.

For DDR2 DIMMs, all ECC byte lane delay values can be determined by averaging the physically adjacent data lanes on the DRAM interface. For example, if the ECC byte lane signals on the board are physically between data byte lanes 4 and 5, the programmed value for the delay registers would be the average of the values used for data byte lanes 4 and 5. This technique would be used to calculate the delay settings for all DDR2 BIOS based training as mentioned in the previous paragraph. This method is also used to determine the ECC delay settings for unbuffered DDR3 DIMMs.

For DDR3 registered DIMMs, ECC delay training is accomplished by adding or subtracting a fixed delay value based on adjacent DRAM locations relative to the ECC DRAM on the DIMM. Currently, there are five families of DDR3 registered DIMMs with ECC: 1 rank x8, 2 rank x8, 1 rank x4, 2 rank x4 stacked card, and 2 rank x4 planar card. All data lanes on x4 DIMMs are trained using the lower nibbles by default so the data lanes chosen for the examples below are byte aligned. See 2.8.7.8.1 [DDR3 Training] on page 85. The delay settings for the first four family types can be calculated using the method as described in the following example.

For each rank of a 1 or 2 rank x8 DDR3 registered DIMM, BIOS calculates the needed delay value by subtracting the delay value used for data lane X associated with DRAM device D2 from the value used for data lane Y associated with DRAM device D3. See Figure 6 below. The difference is added to the delay setting used for data lane Y and the result is used for the delay setting of the ECC lane. BIOS repeats this process for the other ranks as needed. A similar method is used for 2 stacked rank x4 registered DDR3 devices.



To Processor DRAM Interface

Figure 6: DDR3 Registered DIMM (non-planar)

For DDR3 planar registered DIMMs, ECC delay settings are determined by adding the difference in the delay settings between two adjacent DRAMs on a DIMM to the value used for the DRAM device next to the ECC DRAM device on the DIMM. This value is used as the delay setting for the ECC lane. For the x4 planar DIMM example shown in Figure 7, the delay values needed to calculate the ECC delay setting are based on byte aligned data lanes. In this case, BIOS calculates the needed delay value by subtracting the delay value used for data lane X associated with DRAM device D2 from the value used for data lane Y associated with DRAM device D9. See Figure 7 below. The difference is added to the delay setting used for data lane Y and the result is used for the delay setting of the ECC lane. BIOS repeats this process for the other ranks as needed.



To Processor DRAM Interface

Figure 7: DDR3 Registered DIMM (planar)

## 2.8.7.8.4 Calculating MaxRdLatency

The MaxRdLatency value determines when the node's memory controller can receive incoming data from the DCTs. Calculating MaxRdLatency consists of summing all the synchronous and asynchronous delays in the path from the processor to the DRAM and back at a given MEMCLK frequency. BIOS incrementally calculates the MaxRdLatency and then finally programs the value into F2x[1, 0]78[MaxRdLatency].

The following steps describe the algorithm used to compute F2x[1, 0]78[MaxRdLatency] used for DRAM training. K is used as a temporary placeholder for the incrementally summed value.

- 1. Multiply the CAS Latency (in MEMCLKs) by 2 to get the number of 1/2 MEMCLKs units for Tcl and store into K.
  - K = 2 \* CL; See F2x[1, 0]88[Tcl].
- 2. If registered DIMMs are used then add 2 to the incremental sub-total K.
  - If F2x[1, 0]90[UnbuffDimm]=0 then K = K + 2
- 3. If the all coarse prelaunch setup delays are 1/2 MEMCLK then add 1, else add 2 to the sub-total K.
  - If  $(F2x[1, 0]9C_x04[AddrCmdSetup]$  and  $F2x[1, 0]9C_x04[CsOdtSetup]$  and  $F2x[1, 0]9C_x04[CkeSetup] = 0$ ) then K = K + 1
  - If  $(F2x[1, 0]9C_x04[AddrCmdSetup]$  or  $F2x[1, 0]9C_x04[CsOdtSetup]$  or  $F2x[1, 0]9C_x04[CkeSetup]$  = 1) then K = K + 2
- 4. If the F2x[1, 0]78[RdPtrInit] field is 4, 5, or 6, then add 4, 3, or 2, respectively, to the sub-total K.
  - K = K + (8 F2x[1, 0]78[RdPtrInit])
- 5. Add the maximum (worst case) delay value of F2x[1, 0]9C\_x[2B:10][DqsRcvEnGrossDelay] that exists across all DIMMs and byte lanes.
  - $K = K + (Maximum F2x[1, 0]9C_x[2B:10][DqsRcvEnGrossDelay])$
- 6. Add 5.5 to the sub-total K. 5.5 represents part of the processor specific constant delay value in the DRAM clock domain.
  - K = K + 5.5
- 7. Convert the sub-total value K (in 1/2 MEMCLKs) to Northbridge clocks (NCLKs) normalized to 200 MHz clk (multiplying before dividing avoids rounding errors):
  - K = K \* 200 \* (F3xD4[NbFid] + 4); see F3xD4[NbFid] for more information on the state of NbFid.
  - K = K / (current memory clock frequency); see F2x[1, 0]88[MemClkFreq]
  - K = K / 2; removes the 1/2 MEMCLK component
- 8. Add 5 NCLKs to the sub-total. 5 represents part of the processor specific constant delay value in the Northbridge clock domain.
  - K = K + 5
- 9. Program the final MaxRdLatency with the total delay value (in NCLKs):
  - F2x[1, 0]78[MaxRdLatency] = RoundUp(K)

Note: if F2x110[DctGangEn] = 1, BIOS sets both DCT's F2x[1, 0]78[MaxRdLatency] to the maximum of either channel's computed MaxRdLatency value.

# 2.8.7.8.4.1 MaxRdLatency Training

The following describes an algorithm that can be used to optimize F2x[1, 0]78[MaxRdLatency] value used after DRAM training:

The following three cache line pattern is used to train the MaxRdLatency value:

```
0C3C_FF52_6E0E_3FACh
49C5_B613_4A68_8181h
```

```
5C16 50E3 7C78 0BA6h
0C67 53E6 0C4F 9D76h
BABF B6CA 2055 35A5h
0C5F 1C87 610E 6E5Fh
14C9 C383 4884 93CEh
9CE8 F615 F5B9 A5CDh
C38F 1B4C AAD7_14B5h
669F 7562 72ED 647Ch
4A89 8B30 5233 F802h
3326 B465 10A4 0617h
C807 E3D3 5538 6E04h
14B4 E63A AB49 E193h
EA51 7C45 67DF 2495h
F814 0C51 7624 CE51h
B61D D0C9 4824 BD23h
E8F3 807D 072B CFBEh
25E3 0C47 919E A373h
4DA8 0A5A FEB1 2958h
792B 0076 E9A0 DDF8h
F025 B496 E81C 73DCh
8085 94FE 1DB7 E627h
655C 7783 8266 8268h
```

- For each channel:
  - BIOS calculates a starting MaxRdLatency delay value by executing steps 1 through 5, and 7 in section 2.8.7.8.4 above.
  - BIOS selects an address associated with the DIMM that has the worst case [The DRAM DQS Receiver Enable Timing Control Registers] F2x[1, 0]9C\_x[2B:10] register setting that was found on the channel during DQS receiver enable training.
  - Using the patterns given above, write 3 cache lines to the target address on the current DIMM.
    - 1. Incrementing through all possible MaxRdLatency delay values beginning at the calculated MaxRd-Latency start value:
    - 2. Set current MaxRdLatency delay value.
    - 3. Read three cache lines from the selected addresses on the current DIMM.
    - 4. Compare all three cache lines of data to the values written.
      - If the compare matches, go to step 5. below.
      - If the compare does not match, increment the MaxRdLatency value and go to step 2. above.
    - 5. Save the MaxRdLatency value for the current DIMM for the current channel.
    - 6. Repeat all the above steps for the other channel.
- Program the largest MaxRdLatency value in nclks plus 1/2 MEMCLK (to convert the MEMCLK value to nclks see section 2.8.7.8.4 step 7 above) for each channel. If the channels are ganged, use the larger value.

### 2.8.7.8.5 Continuous Pattern Generation

DRAM training relies on the ability to generate a string of continuous reads or writes between the processor and DRAM, such that worst case electrical interactions can be created. This section describes how these continuous strings of accesses may be generated.

For reads, prefetch DRAM training mode is enabled through [The Memory Controller Configuration High

Register] F2x11C[PrefDramTrainMode]. In prefetch DRAM training mode, the DRAM prefetcher (see the same register) continues to issue to prefetches (once it detects a stride) until the DRAM prefetch limit, F2x11C[MctPrefReqLimit], is reached. This results in a series of back-to-back reads to the DCT; the corresponding data is stored in the prefetch data buffer. This data can then be accessed by subsequent reads to the strided addresses (and then checked for correctness by software). The expected sequence of events is as follows:

- 1. BIOS ensures that the only accesses outstanding to the MCT are training reads.
- 2. If F2x[1, 0]90[BurstLength32]=1, then BIOS ensures that the DCTs and DRAMs are configured for 64 byte bursts (8-beat burst length). See 2.8.3 [Burst Length] on page 62. This requires that BIOS issue MRS commands to the devices to change to an 8-beat burst length and then to restore the desired burst length after training is complete.
- 3. BIOS programs F2x[1, 0]90[ForceAutoPchg] = 0 and F2x[1, 0]8C[DisAutoRefresh] = 1.
- 4. If necessary, BIOS programs F2x[1, 0]78[EarlyArbEn] = 1 at this time. See register description.
- 5. BIOS sets F2x11C[MctPrefReqLimit] to the number of training reads (Ntrain) it wishes to generate in the training sequence.
- 6. BIOS sets F2x11C[PrefDramTrainMode] bit.
- 7. The act of setting F2x11C[PrefDramTrainMode] causes the MCT to flush out the prefetch stride predictor table (removing any existing prefetch stride patterns).
- 8. BIOS issues an SFENCE (or other serializing instruction) to ensure that the prior write completes.
- 9. BIOS generates two training reads. These must be to consecutive cache lines (i.e. 64 bytes apart) and must not cross a naturally aligned 4 Kbyte boundary.
- 10. These reads set up a stride pattern which is detected by the prefetcher. The prefetcher then continues to issue prefetches until F2x11C[MctPrefReqLimit] is reached, at which point the MCT clears F2x11C[PrefDramTrainMode].
- 11. BIOS issues the remaining (Ntrain 2) reads after checking that F2x11C[PrefDramTrainMode] is cleared. These reads must be to consecutive cache lines (i.e., 64 bytes apart) and must not cross a naturally aligned 4KB boundary. These reads hit the prefetches and read the data from the prefetch buffer.
- 12. When BIOS is ready to issue the next set of training reads, go to step #6.
- 13. When training is complete, BIOS disables the DRAM prefetcher training mode by programming F2x11C[PrefDramTrainMode]=0;
- 14. BIOS restores the target values for F2x[1, 0]90[ForceAutoPchg], F2x[1, 0]8C[DisAutoRefresh] and F2x[1, 0]90[BurstLength32].

For writes, prefetch DRAM training is accomplished using the write bursting function, described in F2x11C, as follows:

- 1. Disable the leaking of writes to the DCT that are below the burst watermark by setting F2x11C[DctWr-Limit] = 00b.
- 2. Set F2x11C[MctWrLimit] to desired number of cachelines in the burst.
- 3. Flush out prior writes by setting F2x11C[FlushWr].
- 4. Wait for F2x11C[FlushWr] to clear, indicating prior writes have been flushed.
- 5. Issue the stream of writes. When F2x11C[MctWrLimit] is reached (or when F2x11C[FlushWr] is set again), all the writes are written to DRAM.

# 2.8.8 Memory Interleaving Modes

Interleaving is defined as the spreading contiguous physical address space over multiple DIMM banks, as opposed to each DIMM owning a single contiguous address space. This is accomplished by using lower-order address bits to select between DIMMs. The processor supports three different types of interleaving modes:

• CS: interleaving between the DIMM banks of a channel based the CS. This is controlled through [The

- DRAM CS Base Address Registers F2x[1, 0][5C:40].
- Channel: interleaving between the two 64-bit channels of a processor. This is controlled through [The DRAM Controller Select Low Register] F2x110[DctSelIntLvEn].
- Node: interleaving between DIMMs of different processor nodes. This is controlled through [The DRAM Base/Limit Registers] F1x[1, 0][7C:40] and [The DRAM Limit System Address Register] F1x124. See section 2.8.8.2 [Node Interleaving] on page 103.

Any combination of these interleaving modes may be enabled concurrently.

## 2.8.8.1 Chip Select Interleaving

The chip select memory interleaving mode requires all DIMM chip-select ranges be the same size and type, and the number of chip selects a power of two. A BIOS algorithm for programming [The DRAM CS Base Address Registers] F2x[1, 0][5C:40] and [The DRAM CS Mask Registers] F2x[1, 0][6C:60] in memory interleaving mode is as follows:

- 1. Program all DRAM CS Base Address and DRAM CS Mask registers using contiguous normalized address mapping.
- 2. For each enabled chip select, swap the corresponding F2x[1, 0][5C:40][BaseAddr[36:27]] bits with F2x[1, 0][5C:40][BaseAddr[21:13]] bits, as defined Table 32 and Table 33 for DDR2 and Table 34 and Table 35 for DDR3.
- 3. For each enabled chip select, swap the corresponding F2x[1, 0][6C:60][AddrMask[36:27]] bits with F2x[1, 0][6C:60][AddrMask[21:13]] bits, as defined in Table 32 and Table 33 for DDR2 and Table 34 and Table 35 for DDR3.

Table 32. DDR2 swapped normalized address lines for interleaving for a 64-bit interface

| Chip Select<br>Mode | Chip Select<br>Size | Swapped Base Address and Address Mask bits |                       |                       |
|---------------------|---------------------|--------------------------------------------|-----------------------|-----------------------|
|                     |                     | 8 way CS interleaving                      | 4 way CS interleaving | 2 way CS interleaving |
| 0000b               | 128-MB              | [29:27] and [16:14]                        | [28:27] and [15:14]   | [27] and [14]         |
| 0001b               | 256-MB              | [30:28] and [17:15]                        | [29:28] and [16:15]   | [28] and [15]         |
| 0010b               | 512-MB              | [31:29] and [17:15]                        | [30:29] and [16:15]   | [29] and [15]         |
| 0011b               | 512-MB              | [31:29] and [18:16]                        | [30:29] and [17:16]   | [29] and [16]         |
| 0100b               | 512-MB              | [31:29] and [18:16]                        | [30:29] and [17:16]   | [29] and [16]         |
| 0101b               | 1-GB                | [32:30] and [18:16]                        | [31:30] and [17:16]   | [30] and [16]         |
| 0110b               | 1-GB                | [32:30] and [18:16]                        | [31:30] and [17:16]   | [30] and [16]         |
| 0111b               | 2-GB                | [33:31] and [18:16]                        | [32:31] and [17:16]   | [31] and [16]         |
| 1000b               | 2-GB                | [33:31] and [19:17]                        | [32:31] and [18:17]   | [31] and [17]         |
| 1001b               | 4-GB                | [34:32] and [19:17]                        | [33:32] and [18:17]   | [32] and [17]         |
| 1010b               | 4-GB                | [34:32] and [18:16]                        | [33:32] and [17:16]   | [32] and [16]         |
| 1011b               | 8-GB                | [35:33] and [19:17]                        | [34:33] and [18:17]   | [33] and [17]         |

Table 33. DDR2 swapped normalized address lines for CS interleaving for a 128-bit interface

| Chip Select<br>Mode | Chip Select<br>Size | Swapped Base Address and Address Mask bits |                       |                          |
|---------------------|---------------------|--------------------------------------------|-----------------------|--------------------------|
|                     |                     | 8 way CS<br>interleaving                   | 4 way CS interleaving | 2 way CS<br>interleaving |
| 0000b               | 256-MB              | [30:28] and [17:15]                        | [29:28] and [16:15]   | [28] and [15]            |
| 0001b               | 512-MB              | [31:29] and [18:16]                        | [30:29] and [17:16]   | [29] and [16]            |
| 0010b               | 1-GB                | [32:30] and [18:16]                        | [31:30] and [17:16]   | [30] and [16]            |
| 0011b               | 1-GB                | [32:30] and [19:17]                        | [31:30] and [18:17]   | [30] and [17]            |
| 0100b               | 1-GB                | [32:30] and [19:17]                        | [31:30] and [18:17]   | [30] and [17]            |
| 0101b               | 2-GB                | [33:31] and [19:17]                        | [32:31] and [18:17]   | [31] and [17]            |
| 0110b               | 2-GB                | [33:31] and [19:17]                        | [32:31] and [18:17]   | [31] and [17]            |
| 0111b               | 4-GB                | [34:32] and [19:17]                        | [33:32] and [18:17]   | [32] and [17]            |
| 1000b               | 4-GB                | [34:32] and [20:18]                        | [33:32] and [19:18]   | [32] and [18]            |
| 1001b               | 8-GB                | [35:33] and [20:18]                        | [34:33] and [19:18]   | [33] and [18]            |
| 1010b               | 8-GB                | [35:33] and [19:17]                        | [34:33] and [18:17]   | [33] and [17]            |
| 1011b               | 16-GB               | [36:34] and [20:18]                        | [35:34] and [19:18]   | [34] and [18]            |

Table 34. DDR3 swapped normalized address lines for interleaving for a 64-bit interface

| Chip Select<br>Mode | Chip Select<br>Size | Swapped Base Address and Address Mask bits |                       |                          |
|---------------------|---------------------|--------------------------------------------|-----------------------|--------------------------|
|                     |                     | 8 way CS interleaving                      | 4 way CS interleaving | 2 way CS<br>interleaving |
| 0001b               | 256-MB              | [30:28] and [18:16]                        | [29:28] and [17:16]   | [28] and [16]            |
| 0010b               | 512-MB              | [31:29] and [18:16]                        | [30:29] and [17:16]   | [29] and [16]            |
| 0101b               | 1-GB                | [32:30] and [18:16]                        | [31:30] and [17:16]   | [30] and [16]            |
| 0110b               | 1-GB                | [32:30] and [19:17]                        | [31:30] and [18:17]   | [30] and [17]            |
| 0111b               | 2-GB                | [33:31] and [18:16]                        | [32:31] and [17:16]   | [31] and [16]            |
| 1000b               | 2-GB                | [33:31] and [19:17]                        | [32:31] and [18:17]   | [31] and [17]            |
| 1001b               | 4-GB                | [34:32] and [19:17]                        | [33:32] and [18:17]   | [32] and [17]            |
| 1010b               | 4-GB                | [34:32] and [18:16]                        | [33:32] and [17:16]   | [32] and [16]            |
| 1011b               | 8-GB                | [35:33] and [19:17]                        | [34:33] and [18:17]   | [33] and [17]            |

Table 35. DDR3 swapped normalized address lines for CS interleaving for a 128-bit interface

| Chip Select<br>Mode | Chip Select<br>Size | Swapped Base Address and Address Mask bits |                       |                       |
|---------------------|---------------------|--------------------------------------------|-----------------------|-----------------------|
|                     |                     | 8 way CS interleaving                      | 4 way CS interleaving | 2 way CS interleaving |
| 0001b               | 512-MB              | [31:29] and [19:17]                        | [30:29] and [18:17]   | [29] and [17]         |
| 0010b               | 1-GB                | [32:30] and [19:17]                        | [31:30] and [18:17]   | [30] and [17]         |
| 0101b               | 2-GB                | [33:31] and [19:17]                        | [32:31] and [18:17]   | [31] and [17]         |

| Chip Select<br>Mode | Chip Select<br>Size | Swapped Base Address and Address Mask bits |                       |                          |
|---------------------|---------------------|--------------------------------------------|-----------------------|--------------------------|
|                     |                     | 8 way CS interleaving                      | 4 way CS interleaving | 2 way CS<br>interleaving |
| 0110b               | 2-GB                | [33:31] and [20:18]                        | [32:31] and [19:18]   | [31] and [18]            |
| 0111b               | 4-GB                | [34:32] and [19:17]                        | [33:32] and [18:17]   | [32] and [17]            |
| 1000b               | 4-GB                | [34:32] and [20:18]                        | [33:32] and [19:18]   | [32] and [18]            |
| 1001b               | 8-GB                | [35:33] and [20:18]                        | [34:33] and [19:18]   | [33] and [18]            |
| 1010b               | 8-GB                | [35:33] and [19:17]                        | [34:33] and [18:17]   | [33] and [17]            |
| 1011b               | 16-GB               | [36:34] and [20:18]                        | [35:34] and [19:18]   | [34] and [18]            |

Table 35. DDR3 swapped normalized address lines for CS interleaving for a 128-bit interface

The following is an example of interleaving a 64-bit interface to DDR2 DRAM. The DRAM memory consists of two 2-sided DDR2 DIMMs with 256 Mbytes on each side.

1. The register settings for contiguous memory mapping are:

```
F2x[1, 0]80 = 0000\_0011h \text{ // CS0/1} = 256 \text{ MB; CS2/3} = 256 \text{ MB} F2x[1, 0]40 = 0000\_0001h \text{ // 0 MB base} F2x[1, 0]44 = 0010\_0001h \text{ // 256 MB base} = 0 \text{ MB} + 256 \text{ MB} F2x[1, 0]48 = 0020\_0001h \text{ // 512 MB base} = 256 \text{ MB} + 256 \text{ MB} F2x[1, 0]4C = 0030\_0001h \text{ // 768 MB base} = 512 \text{ MB} + 256 \text{ MB} F2x[1, 0]60 = 0008\_3FF0h \text{ // CS0/CS1} = 256 \text{ MB} F2x[1, 0]64 = 0008\_3FF0h \text{ // CS2/CS3} = 256 \text{ MB}
```

2. The base address bits to be swapped are defined in Table 32, 256MB chip select size, 4 way CS interleaving column (4 chip selects are used). Base address bits [29:28] bits are defined with F2x[1, 0][5C:40][BaseAddr[21:20]. Base address bits [16:15] are defined with F2x[1, 0][5C:40][BaseAddr[8:7]].

```
F2x[1, 0]40 = 0000_0001h

F2x[1, 0]44 = 0000_0081h

F2x[1, 0]48 = 0000_0101h

F2x[1, 0]4C = 0000_0181h
```

3. The address mask bits to be swapped are the same as the base address bits defined in the previous step. Address mask bits [29:28] are defined with F2x[1, 0][6C:60][AddrMask[21:20]. Address mask bits [16:15] are defined with F2x[1, 0][6C:60][AddrMask[8:7].

```
F2x[1, 0]60 = 0038\_3E70h

F2x[1, 0]64 = 0038\_3E70h
```

# 2.8.8.2 Node Interleaving

If node interleaving is enabled, then (1) all nodes in the system must contain the same amount of DRAM, (2) all the DRAM of all nodes in the system must be interleaved, and (3) the base and limit registers for all nodes must be programmed to 0 and top of memory, respectively. If node interleaving and channel interleaving are enabled, all DRAM channels in the system must have the same amount of DRAM.

Node interleaving for up to 8 nodes is controlled by F1x[1, 0][7C:40][IntlvEn and IntlvSel],

F1x120[DramIntlvSel] and F1x124[DramIntlvEn]. IntlvEn and DramIntlvEn are programmed to specify the interleaved address bits (programmed the same in each node). IntlvSel specifies the value that those address bits need to be to target a node (must be programmed to a different value for each node). DramIntlvSel specifies the value of those address bits for the local node. It is expected that one [The DRAM Base/Limit Registers] F1x[1, 0][7C:40] pair is enabled per node; one of these pairs selects the local node by having an IntlvSel value that matches F1x120[DramIntlvSel]; IntlvEn is the same in all [The DRAM Base/Limit Registers] F1x[1, 0][7C:40] pairs and the same as F1x124[DramIntlvEn] of all nodes. For example, a 4-node system would normally be programmed as follows for interleaving:

### Node 0

 $- IntlvEn = 00_0011b$ 

- IntlvSel = 000b

- Addr[13:12] = 00b

### Node 2

 $- IntlvEn = 00_0011b$ 

- IntlySel = 010b

- Addr[13:12] = 10b

### Node 1

 $- IntlvEn = 00_0011b$ 

- IntlySel = 001b

- Addr[13:12] = 01b

### Node 3

 $- IntlvEn = 00_0011b$ 

- IntlvSel = 011b

- Addr[13:12] = 11b

# 2.8.9 Memory Hoisting

Memory hoisting is defined as reclaiming the DRAM space that would naturally reside in the MMIO hole just below the 4G address level. This memory is repositioned above the 4G level when the registers that control memory hoisting, [The DRAM Hole Address Register] F1xF0, [The DRAM Controller Select Low Register] F2x110, [The DRAM Controller Select High Register] F2x114, are set up properly.

The memory hoisting offset fields, F1xF0[DramHoleOffset] and F2x114[DctSelBaseOffset], are programmed based on the following parameters:

- F1xF0[DramHoleBase], which is the base address of the IO hole below the 4G level. In MP systems, this should be programmed to the same value in all processors.
- F2x110[DctSelBaseAddr], which specifies the base address of the upper memory space owned by one of the DCTs.
- F2x110[DctSelIntLvEn], which specifies if interleaving between the two DCTs is enabled (channel interleave mode).
- F1x120[DramBaseAddr], and F1x124[DramLimitAddr], which specify the address range of the node.
- If both DCTs are enabled (F2x[1, 0][5C:40][CSEnable]). Note: if the two DCTs are ganged in 128-bit mode, then only 1 DCT is defined to be enabled in the case conditions below.

DramHoleSize is defined in order to simplify the following equations in this section and is calculated as follows: DramHoleSize[31:24] = (100h-DramHoleBase[31:24]).

### 2.8.9.1 DramHoleOffset Programming

F1xF0[DramHoleOffset] is programmed to one of the following equations based on the scenario:

- Case 1: if only one DCT is enabled OR both DCTs are enabled in channel interleaved mode and have equal amount of memory OR DctSelBaseAddr > DramHoleBase, then:
  - DramHoleOffset[31:23] = {DramHoleSize[31:24], 0b} + {DramBaseAddr[31:27], 0000b};
- Case 2: if both DCTs are enabled in channel non-interleaved mode and DctSelBaseAddr < DramHoleBase, then:
  - $DramHoleOffset[31:23] = \{DramHoleSize[31:24], 0b\} + \{DctSelBaseAddr[31:27], 0000b\};$
- Case 3: if both DRAM controllers are enabled in channel interleaved mode and DctSelBaseAddress < Dram-HoleBase, then:



Figure 8: Example cases for programming DramHoleOffset.

# 2.8.9.2 DctSelBaseOffset Programming

F2x114[DctSelBaseOffset] is programmed to one of the following equations based on the scenario:

- Case 1: if the two DCTs are enabled in channel non-interleaved mode, then: DctSelBaseOffset[47:26] = {DctSelBaseAddr[47:27], 0b};
- Case 2: if (1) the two DCTs are enabled in channel interleaved mode and DctSelBaseAddr < DramHoleBase OR if (2) there is no memory hole in the address map, then:

```
DctSelBaseOffset[47:26] = \{DramBaseAddr[47:27], 0b\}
```

```
+ {0b, (DctSelBaseAddr[47:27] – DramBaseAddr[47:27]) };
```

• Case 3: if the two DCTs are enabled in channel interleaved mode, DctSelBaseAddr > DramHoleBase, and the interleaved range includes the MMIO hole, then:

```
DctSelBaseOffset[47:26] = \{DramBaseAddr[47:27], 0b\}
```

- + {0000h, DramHoleSize[31:26]}
- + {0b, (DctSelBaseAddr[47:27]
  - {0000h, (DramBaseAddr[31:27] + DramHoleSize[31:27]) } };



Figure 9: Example cases for programming DctSelBaseOffset.

## 2.8.10 On-Line Spare

On-line spare is a RAS mechanism that allows the system to reserve one rank of one logical DIMM to be used as a spare rank. System software reserves a spare rank by setting F2x[1, 0][5C:40][Spare] in one of the CS Base address registers. The spare rank must be greater than or equal to the size of all other ranks in the system.

The system can switch to the spare rank when system software determines that one of the ranks in the system is no longer functioning properly and needs to be replaced. System software initiates the swap to the spare rank by writing the chip select number of the bad rank to F3xB0[BadDramCS] and setting F3xB0[SwapEn].

On-line spare is not supported in UMA systems.

## 2.8.10.1 On-Line Spare and CS Interleaving

The on-line spare feature can only be used with 2 way and 4 way CS interleaving under the following conditions.

- All ranks of each DIMM present must be of the same size and configuration.
- Only the following populations are supported:
  - 2 DIMMs per channel (2 way CS interleaving)
    - One single rank DIMM and one dual rank DIMM. Any rank can be used as the spare rank.
    - Both DIMMs are dual rank. Any rank can be used as the spare rank. One rank must be marked as bad since only two ranks can be active.
  - 3 DIMMs per channel (4 way CS interleaving)
    - Two dual rank DIMMs and one single rank DIMM. Any rank can be used as the spare rank.
    - All DIMMs are dual rank. Any rank can be used as the spare rank. One rank must be marked as bad since only four ranks can be active.
  - 4 DIMMs per channel (4 way CS interleaving)
    - One dual rank DIMMs and three single rank DIMMs. Any rank can be used as the spare rank.
    - Two dual rank DIMMs and two single rank DIMMs. Any rank can be used as the spare rank. One rank must be marked as bad since only four ranks can be active.

## 2.9 CPU Core

The majority of the behavioral definition of the CPU core is specified in the *AMD64 Architecture Programmer's Manual*. See section 1.2 [Reference Documents] on page 12.

# 2.9.1 Virtual Address Space

The processor supports 48 address bits of virtual memory space (256 terabyte) as indicated by CPUID Fn8000 0008 EAX.

# 2.9.2 CPU Cores and Downcoring

Each node supports 1, 2, 3, or 4 CPU cores as follows:

- The number of cores supported by the node is specified by F3xE8[CmpCap].
- CPU cores may be *downcored* (removed) by F3x190[DisCore[3:0]] through a warm reset. This may be useful in that CPU cores that are determined to be bad may be removed from operation. Based on F3xE8[Cmp-Cap], DisCore[0] applies to a single-core node; DisCore[1:0] apply to a dual-core node; DisCore[2:0] apply to a 3-core node; DisCore[3:0] apply to a 4-core node.
- F3x190[DisCore] affects CPUID Fn8000\_0008\_ECX[NC].
- Software is required to use F3x190[DisCore[3:0]] as follows:
  - 1, 2, 3 or 4 cores must be enabled on each node(0-core configurations are not allowed).
  - Setting bits corresponding to CPU cores that are not present results in undefined behavior.
  - Once a core has been removed, it cannot be added back without a cold reset.
  - If the number of cores in the system is changed, then F0x60[CpuCnt] in all nodes must be updated to reflect the new value after the warm reset.
- The CPU core number, *CpuCoreNum*, is provided to SW running on each core through CPUID Fn0000\_0001\_EBX[LocalApicId] and APIC20[ApicId], formatted based on the state of MSRC001\_001F[InitApicIdCpuIdLo]; CpuCoreNum also affects F0x68[Cpu1En] and F0x168[Cpu3En and Cpu2En]. CpuCoreNum, varies as the lowest integers from 0 to 3, based on the number of enabled cores; e.g., a 4-core node with 1 core disabled results in cores reporting CpuCoreNum values of 0, 1, and 2 regardless of which core is disabled. Here are all the possible downcore combinations:

A 4-core node with 0 cores disabled.
A 4-core node with 1 core disabled.
A 4-core node with 1 core disabled.
A 4-core node with 2 cores disabled.
A 4-core node with 3 cores disabled.
A 2-core node with 0 cores disabled.
A 1-core node with 0 cores disabled.
A 2-core node with 1 core disabled.
A 2-core node with 1 core disabled.

• The boot core is always the core reporting CpuCoreNum = 0.

Some legacy operating systems do not support three core processors. The BIOS should support a user configurable option to disable one core in a three core processor for legacy operating system support.

# 2.9.3 Access Type Determination

The access type determination and destination affects routing specified in section 2.6.4 [Northbridge Routing] on page 51.

# 2.9.3.1 Memory Access to the Physical Address Space

All memory accesses to the physical address space from a CPU core are sent to its associated Northbridge (NB). All memory accesses from an IO link are routed through the NB. An IO link access to physical address space indicates to the NB the cache attribute (Coherent or Non-coherent, based on bit[0] of the Sized Read and

Write commands).

A CPU core access to physical address space has two important attributes that the CPU must determine before issuing the access to the NB: the cache attribute (e.g., WB, WC, UC; as described in the MTRRs) and the access destination (DRAM or MMIO).

# **2.9.3.1.1 Determining The Cache Attribute**

- 1. The CPU translates the logical address to a physical address. In that process it determines the initial cache attribute based on the settings of the Page Table Entry PAT bits, [The MTRR Default Memory Type Register (MTRRdefType)] MSR0000\_02FF, [The Variable-Size MTRRs (MTRRphysBasen and MTRRphysMaskn)] MSR0000\_02[0F:00], and [The Fixed-Size MTRRs (MTRRfixn)] MSR0000\_02[6F:68, 59, 58, 50].
- The ASeg and TSeg SMM mechanisms are then checked in parallel to determine if the initial cache attribute should be overridden (see [The SMM TSeg Base Address Register (SMMAddr)]
   MSRC001\_0112 and [The SMM TSeg Mask Register (SMMMask)] MSRC001\_0113). If the address falls within an enabled ASeg/TSeg region, then the final cache attribute is determined as specified in MSRC001\_0113.

This mechanism is managed by the BIOS and does not require any setup or changes by system software.

# 2.9.3.1.2 Determining The Access Destination for CPU Accesses

The access destination, DRAM or MMIO, is based on the highest priority of the following ranges that the access falls in:

- 1. (Lowest priority) Compare against the top-of memory (TOM) registers (see MSRC001\_001A, and MSRC001\_001D).
- 2. [The Fixed-Size MTRRs (MTRRfixn)] MSR0000 02[6F:68, 59, 58, 50].
- 3. The IORRs (see MSRC001 00[18, 16] and MSRC001 00[19, 17]).
- 4. TSEG & ASEG (see MSRC001\_0112 and MSRC001\_0113).
- 5. (Highest priority) NB AGP aperture range registers.

To determine the access destination, the following steps are taken:

- The CPU compares the address against [The Top Of Memory Register (TOP\_MEM)] MSRC001\_001A, and [The Top Of Memory 2 Register (TOM2)] MSRC001\_001D, to determine if the default access destination is DRAM or MMIO space.
- 2. For addresses below 1M byte, the address is then compared against the appropriate Fixed MTRRs to override the default access destination. Each fixed MTRR includes two bits, RdDram and WrDram, that determine the destination based on the access type. See MSR0000\_02[6F:68, 59, 58, 50].
- 3. The CPU then compares the address against the IORRs (MSRC001\_00[18, 16] and MSRC001\_00[19, 17]); if it matches, the default access destination is overridden as specified by the IORRs. BIOS can use the IORRs to create an IO hole within a range of addresses that would normally be mapped to DRAM. It can also use the IORRs to re-assert a DRAM destination for a range of addresses that fall within a bigger IO hole that overlays DRAM. Some key points to consider:
  - a) Operating system software never needs to program IORRs to re-map addresses that naturally target DRAM; any such programming is done by the BIOS.
  - b) The IORRs should not cover the range used for the AGP aperture if the GART logic in the NB is enabled.
  - c) The IORRs should be programmed to cover the AGP aperture if the aperture/GART translation is

handled by an IO device (e.g., the chipset).

4. The ASeg and TSeg SMM mechanisms are then checked in parallel to determine if the destination should be overridden (see MSRC001\_0112 and MSRC001\_0113). If the address falls within an enabled ASeg/TSeg region, then the destination is determined as specified in MSRC001\_0113.

This mechanism is managed by the BIOS and does not require any setup or changes by system software.

#### **2.9.4** Timers

Each CPU core includes the following timers. These timers do not vary in frequency regardless of the current P-state or C-state.

Note: Timers associated with different CPU cores in the same processor increment at the same rate. Timers associated with different CPU cores in different processors increment at slightly different rates if (1) they are located on different nodes and (2) CLKIN for these nodes is derived from different, non-synchronized oscillator sources.

- [The Time Stamp Counter Register (TSC)] MSR0000\_0010; the TSC increments at the rate specified by MSRC001\_0015[TscFreqSel].
- The APIC timer (APIC380 and APIC390), which increments at the rate of CLKIN; the APIC timer may increment in units of between 1 and 8.

#### 2.9.5 APIC

# 2.9.5.1 ApicId Enumeration Requirements

System hardware and BIOS must ensure that the number of cores per processor (NC) exposed to the operating system by all tables, registers, and instructions across all cores and processors in the system is identical. See2.16.1 [Multi-Core Support] on page 133 to derive NC.

Operating systems are expected to use CPUID Fn8000\_0008\_ECX[ApicIdCoreIdSize[3:0]], the number of least significant bits in the Initial APIC ID that indicate CPU core ID within a processor, in constructing percore CPUID masks. (ApicIdCoreIdSize[3:0] determines the maximum number of cores (MNC) that the processor could theoretically support, not the actual number of cores that are actually implemented or enabled on the processor, as indicated by CPUID Fn8000\_0008\_ECX[NC].) BIOS must use the ApicId MNC rule when assigning [The APIC ID Register] APIC20[ApicId] values as described below.

ApicId MNC rule: The ApicId of core j on processor i must be enumerated/assigned as:

```
ApicId[proc=i, core=j] = (OFFSET_IDX + i) * MNC + j
```

Where "OFFSET\_IDX" is an integer offset (0 to N) used to shift up the CPU ApicId values to allow room for IOAPIC devices.

It is recommended that BIOS use the following APIC ID assignments for the broadest operating system support. Given  $N = (Number\_Of\_Processors * MNC)$  and  $M = Number\_Of\_IOAPICs$ :

- If (N+M) <16, assign the local (core) ApicId's first from 0 to N-1, and the IOAPIC IDs from N to N+(M-1).
- If (N+M) > =16, assign the IOAPIC IDs first from 0 to M-1, and the local (core) ApicId's from K to K+(N-1), where K is an integer multiple of MNC greater than M-1.

For example, consider a 3 processor system where each processor has 3 cores and there are 8 IOAPIC devices. Each CPU core can support an 8-bit ApicId. But if each IOAPIC device supports only a 4-bit IOAPIC ID, then the problem can be solved by shifting the CPU ApicId space to start at some integer multiple of MNC, such as offset 8 (MNC = 4; OFFSET IDX=2):

#### 2.10 Thermal Functions

Thermal functions HTC, STC and THERMTRIP are intended to maintain processors temperature in a valid range by:

- Providing an input to the external circuitry that controls cooling.
- Lowering power consumption by switching to lower-performance P-state or.
- Sending processor to the THERMTRIP state to prevent it from damage.

The processor thermal-related circuitry includes (1) the temperature calculation circuit (TCC) for determining the temperature of the processor and (2) logic that uses the temperature from the TCC. The processor includes a thermal diode as well.

### 2.10.1 The Tctl Temperature Scale

Tctl is the processor temperature control value, used by the platform to control cooling systems. Tctl is accessible through SB-TSI and F3xA4[CurTmp]. Tctl is a non-physical temperature on an arbitrary scale measured in degrees. It does *not* represent an actual physical temperature like die or case temperature. Instead, it specifies the processor temperature relative to the point at which the system must supply the maximum cooling for the processor's specified maximum case temperature and maximum thermal power dissipation. It is defined as follows for all parts:

- For Tctl = 0 to Tctl\_max 0.125: the temperature of the part is [Tctl\_max Tctl] degrees under the temperature for which maximum cooling is required.
- For Tctl = Tctl\_max to 255.875: the temperature of the part is [Tctl Tctl\_max] degrees over the worst-case expected temperature under normal conditions. The processor may take corrective actions that affects performance or operation as a result, such as invoking HTC or THERMTRIP\_L.

### 2.10.2 Thermal Diode

The thermal diode is a diode connected to the THERMDA and THERMDC pins used for thermal measurements. External devices use measurements from the thermal diode measurements to calculate temperature during operation and test. These measurements are required to be adjusted as specified by F3xE4[DiodeOffset]. This diode offset supports temperature sensors using two sourcing currents only. Other sourcing current implementations are not compatible with the diode offset and are not supported. A correction to the offset may be required for temperature sensors using other current sourcing methods. Contact the temperature sensor vendor to determine whether an offset correction is needed.

### 2.10.3 Temperature-Driven Logic

The temperature calculated by the TCC is used by HTC, STC, THERMTRIP, the PROCHOT signal.

### 2.10.3.1 PROCHOT L and Hardware Thermal Control (HTC)

The processor *HTC-active state* is characterized by (1) the assertion of PROCHOT\_L, (2) reduced power consumption, and (3) reduced performance. While in the HTC-active state, the processor reduces power consumption by limiting all CPU cores to a P-state (specified by F3x64[HtcPstateLimit]). See section 2.4.2 [P-states] on page 31. While in the HTC-active state, software should not change F3x64 (except for HtcActSts and HtcEn). Any change to the previous list of fields when in the HTC-active state can result in undefined behavior. HTC status and control is provided through F3x64.

The PROCHOT\_L pin acts as both an input and as an open-drain output. As an output, PROCHOT\_L is driven low to indicate that the HTC-active state has been entered due to an internal condition, as described by the following text. The minimum assertion and deassertion time for PROCHOT L is 15 ns.

The processor enters the HTC-active state if all of the following conditions are true:

- F3xE8[HtcCapable]=1
- F3x64[HtcEn]=1
- PWROK=1
- THERMTRIP L=1
- The processor is not in the C3 ACPI state.

and any of the following conditions are true:

- Tctl is greater than or equal to the HTC temperature limit (F3x64[HtcTmpLmt]).
- PROCHOT\_L=0

The processor exits the HTC-active state when all of the following are true:

- Tctl is less than the HTC temperature limit (F3x64[HtcTmpLmt]).
- Tctl has become less than the HTC temperature limit (F3x64[HtcTmpLmt]) minus the HTC hysteresis limit (F3x64[HtcHystLmt]) since being greater than or equal to the HTC temperature limit (F3x64[HtcTmpLmt]).
- PROCHOT\_L=1.

The default value of the HTC temperature threshold (Tctl\_max) is specified in the Power and Thermal Datasheet.

### 2.10.3.2 Software Thermal Control (STC)

STC is controlled by [The Software Thermal Control (STC) Register] F3x68. This register provides a software-controlled mechanism to alter power consumption based on temperature. When the processor control temperature (Tctl; see section 2.10.1 [The Tctl Temperature Scale] on page 110) exceeds the temperature threshold specified by F3x68[StcTmpLmt], then the processor enters the *STC thermal zone*. When it subsequently drops below F3x68[StcTmpLmt] minus F3x68[StcHystLmt], the processor exits the STC thermal zone. F3x68 controls whether interrupts or special bus cycles (which may be converted into interrupts by the chipset) are generated when the processor transitions into and out of the STC thermal zone. The interrupt handler may take an action to alter power consumption or alter the level of external cooling.

One way that software may reduce power is to program the processor to enter the *STC-active state*. This is like the HTC-active state, however PROCHOT\_L is not asserted. The processor enters the STC-active state if F3x68[StcPstateEn]=1. While in the STC-active state, the processor limits the performance to the P-state specified by [The Software Thermal Control (STC) Register] F3x68[StcPstateLimit]; See section 2.4.2 [P-states] on page 31.

#### **2.10.3.3 THERMTRIP**

If the processor supports the THERMTRIP state (as specified by [The Thermtrip Status Register] F3xE4[ThermtpEn] or CPUID Fn8000\_0007[TTP], which are the same) and the temperature approaches the point at which the processor may be damaged, the processor enters the THERMTRIP state. The THERMTRIP function is enabled after cold reset (after PWROK asserts and RESET\_L deasserts). It remains enabled in all other processor states, except during warm reset (while RESET\_L is asserted). The THERMTRIP state is characterized as follows:

- The THERMTRIP\_L signal is asserted.
- Nearly all clocks are gated off to reduce dynamic power.
- A low-value VID is generated.
- In addition, the external chipset is expected to place the system into the S5 ACPI state (power off) if THERMTRIP\_L is detected to be asserted.

A cold reset is required to exit the THERMTRIP state.

# 2.11 Configuration Space

PCI-defined configuration space was originally defined to allow up to 256 bytes of register space for each function of each device; these first 256 bytes are called base configuration space (BCS). It was expanded to support up to 4096 bytes per function; bytes 256 through 4095 are called extended configuration space (ECS). The processor includes configuration space registers located in both BCS and ECS. Processor configuration space is accessed through bus 0, devices 24 to 31, where device 24 corresponds to node 0 and device 31 corresponds to node 7. See 2.11.3 [Processor Configuration Space] on page 113 for more information on processor configuration space.

Configuration space is accessed by the processor through two methods:

- IO-space configuration: IO instructions to addresses CF8h and CFCh.
  - Enabled through [The IO-Space Configuration Address Register] IOCF8[ConfigEn], which allows access to BCS.
  - Access to ECS enabled through [The Northbridge Configuration Register (NB\_CFG)] MSRC001 001F[EnableCf8ExtCfg].
  - Only PCI-defined segment 0 is accessible.
  - Use of IO-space configuration can be programmed to generate GP faults through [The Hardware Configuration Register (HWCR)] MSRC001\_0015[IoCfgGpFault].
  - SMI trapping for these accesses is specified by [The IO Trap Control Register (SMI\_ON\_IO\_TRAP\_CTL\_STS)] MSRC001\_0054 and [The IO Trap Registers (SMI\_ON\_IO\_TRAP\_[3:0])] MSRC001\_00[53:50].
- MMIO configuration: configuration space is a region of memory space.
  - The base address and size of this range is specified by [The MMIO Configuration Base Address Register] MSRC001\_0058. The size is controlled by the number of configuration-space bus numbers supported by the system. Accesses to this range are converted to configuration space accesses as follows:
    - Address[31:0] = {0h, bus[7:0], device[4:0], function[2:0], offset[11:0]}.
  - SMI trapping for these accesses is specified by [The MMIO Configuration Trap Control Register] MSRC001\_0059 and [The MMIO Configuration Trap Address Registers] MSRC001\_00[5D:5A].

The BIOS may use either configuration space access mechanism during boot. Before booting the OS, BIOS must disable IO access to ECS, enable MMIO configuration and build an ACPI defined MCFG table. BIOS ACPI code must use MMIO to access configuration space.

See 2.6.4.1.3 [Configuration Space] on page 52 for details on configuration space routing.

### 2.11.1 MMIO Configuration Coding Requirements

MMIO configuration space is normally specified to be the uncacheable (UC) memory type. Instructions used to read MMIO configuration space are required to take the following form:

```
mov eax/ax/al, <any_address_mode>;
```

Instructions used to write MMIO configuration space are required to take the following form:

```
mov <any address mode>, eax/ax/al;
```

No other source/target registers may be use other than eax/ax/al.

In addition, all such accesses are required not to cross any naturally aligned DW boundary. Access to MMIO configuration space registers that do not meet these requirements result in undefined behavior.

# 2.11.2 MMIO Configuration Ordering

Since MMIO configuration cycles are not serializing in the way that IO configuration cycles are, their ordering rules relative to posted may result in unexpected behavior.

Therefore, processor MMIO configuration space is designed to match the following ordering relationship that exists naturally with IO-space configuration: if a CPU generates a configuration cycle followed by a posted-write cycle, then the posted write is held in the processor until the configuration cycle completes. As a result, any unexpected behavior that might have resulted if the posted-write cycle were to pass MMIO configuration cycle is avoided.

#### 2.11.3 Processor Configuration Space

The processor includes configuration space as described in section 3 [Registers] on page 135. Accesses to unimplemented registers of implemented functions are ignored: writes dropped; reads return 0's. Accesses to unimplemented functions are also ignored: writes are dropped; however, reads return all F's. The processor does not log any master abort events for accesses to unimplemented registers or functions.

Accesses to device numbers of non-existent processors (e.g., device 25 of a single-node system) are routed based on the configuration map registers. If such requests are master aborted, then the processor can log the event.

# 2.12 Debug Support

#### 2.12.1 Built In Self Test (BIST)

#### 2.13 RAS and Advanced Server Features

This section applies reliability, availability, and serviceability, or *RAS*, and related advanced server considerations.

#### 2.13.1 Machine Check Architecture

The processor contains logic and registers to detect, log, and (if possible) correct errors in the data or control

paths in each CPU core and the Northbridge.

Refer to the *AMD64 Architecture Programmer's Manual* for an architectural overview and methods for determining the processor's level of MCA support. See section 1.2 [Reference Documents] on page 12.

## 2.13.1.1 Machine Check Registers

The presence of the machine check registers is indicated by CPUID Fn[8000\_0001, 0000\_0001]\_EDX[MCA]. The ability of hardware to generate a machine check exception upon an error is indicated by CPUID Fn[8000\_0001, 0000\_0001]\_EDX[MCE].

The machine check register set includes:

- Global status and control registers:
  - [The Global Machine Check Capabilities Register (MCG\_CAP)] MSR0000\_0179
  - [The Global Machine Check Status Register (MCG STAT)] MSR0000 017A
  - [The Global Machine Check Exception Reporting Control Register (MCG\_CTL)] MSR0000\_017B
- Most of the machine check MSRs are organized as a 4-register-type by 6-register-bank matrix.
  - The four register types are:
    - MCi\_CTL, The Machine Check Control Register: Enables error reporting via machine check exception (MCE). The MCi\_CTL register in each bank must be enabled by the corresponding enable bit in MCG\_CTL (MSR0000\_017B).
    - MCi\_STATUS: The Machine Check Status Register: Logs information associated with errors.
    - MCi\_ADDR: The Machine Check Address Register: Logs address information associated with errors.
    - MCi\_MISC: The Machine Check Miscellaneous Registers: Log miscellaneous information associated with errors, as defined by each error type.
  - The six error-reporting register banks supported are:
    - MC0, DC: MSR0000 04[03:00], data cache machine check registers.
    - MC1, IC: MSR0000\_04[07:04], instruction cache machine check registers.
    - MC2, BU: MSR0000\_04[0B:08], bus unit machine check registers.
    - MC3, LS: MSR0000 04[0F:0C], load-store machine check registers.
    - MC4, NB: MSR0000\_04[13:10], Northbridge machine check registers. The NB MC registers also include MSRC000\_04[0A:08]. These MSRs are accessible from configuration space as well.
    - MC5, FR: MSR00000 04[17:14], fixed-issue reorder buffer machine check registers.

Once system software has determined that machine check registers exist via the CPUID instruction, MSR0000\_0179 may be read to determine how many machine check banks are implemented and if [The Global Machine Check Exception Reporting Control Register (MCG\_CTL)] MSR0000\_017B is present.

Table 36 identifies the addresses associated with each MCA register.

Table 36: MCA register cross-reference table

| Register   |              |              | MCA Regi     | ster         |              |
|------------|--------------|--------------|--------------|--------------|--------------|
| Bank (MCi) | CTL          | STATUS       | ADDR         | MISC         | CTL_MASK     |
| MC0        | MSR0000_0400 | MSR0000_0401 | MSR0000_0402 | MSR0000_0403 | MSRC001_0044 |
| MC1        | MSR0000_0404 | MSR0000_0405 | MSR0000_0406 | MSR0000_0407 | MSRC001_0045 |
| MC2        | MSR0000_0408 | MSR0000_0409 | MSR0000_040A | MSR0000_040B | MSRC001_0046 |
| MC3        | MSR0000_040C | MSR0000_040D | MSR0000_040E | MSR0000_040F | MSRC001_0047 |

| Register   |              |              | MCA Regi     | ster                              |              |
|------------|--------------|--------------|--------------|-----------------------------------|--------------|
| Bank (MCi) | CTL          | STATUS       | ADDR         | MISC                              | CTL_MASK     |
| MC4        | MSR0000_0410 | MSR0000_0411 | MSR0000_0412 | MSR0000_0413<br>MSRC000_04[0A:08] | MSRC001_0048 |
| MC5        | MSR0000_0414 | MSR0000_0415 | MSR0000_0416 | MSR0000_0417                      | MSRC001_0049 |

Table 36: MCA register cross-reference table

Correctable and uncorrectable errors that are enabled in MCi\_CTL are logged in MCi\_STATUS and MCi\_ADDR as they occur. Uncorrectable errors immediately result in a Machine Check exception. For the NB, some errors only increment a counter in MC4\_MISC, which may trigger an interrupt (see 2.13.1.4 [Error Thresholding] on page 118).

Each MCi\_CTL register must be enabled by the corresponding enable bit in [The Global Machine Check Exception Reporting Control Register (MCG\_CTL)] MSR0000\_017B.

Additionally, [The Machine Check Control Mask Registers (MCi\_CTL\_MASK)] MSRC001\_00[49:44] allow BIOS to mask the presence of any error source enables from software for test and debug. When error sources are masked, it is as if the error was not detected. Such masking consequently prevents error responses.

Each register bank implements a number of machine check miscellaneous registers, denoted as MCi\_MISCj, where j goes from 0 to a maximum of 8. The presence of valid information in the first MCi\_MISC register (MCi\_MISC0) is indicated by MCi\_STATUS[MiscV], and in subsequent registers by MCi\_MISCj[Valid]. If there is more than one MCi\_MISC register in a given bank, a non-zero value in MCi\_MISC0[BlkPtr] points to the contiguous block of additional registers.

#### 2.13.1.2 Machine Check Errors

There are two classes of machine check errors defined:

- Correctable: errors that can be corrected by hardware or microcode and cause no loss of data or corruption of processor state.
- Uncorrectable: errors that cannot be corrected by hardware or microcode and may have caused the loss of data or corruption of processor state.

Correctable errors are always corrected (unless disabled by implementation-specific bits in control registers for test or debug reasons). If they are enabled for logging, the status and address registers in the corresponding register bank are written with information that identifies the source of the error.

Uncorrectable errors, if enabled for logging, update the status and address registers, and if enabled for reporting, cause a machine check exception. If there is information in the status and address registers from a previous correctable error, it is overwritten. If an uncorrectable error is not enabled for logging, the error is ignored.

The implications of the two main categories of errors are (shown with a non-exhaustive list of examples):

- 1. Corrected error; the problem was dealt with.
  - Operationally (error handling), no action needs to be taken, because program flow is unaffected.
  - Diagnostically (fault management), software may collect information to determine if any components should be de-configured or serviced.
  - Examples include:
    - Correctable ECC, corrected online.

- 2. Uncorrected error; the problem was not dealt with.
  - Operationally (error handling), action does need to be taken, because program flow is affected.
  - Diagnostically (fault management), software may collect information to determine if and what components should be de-configured or serviced.
  - Examples include:
    - Uncorrectable ECC, no way to avoid passing it to process.

Machine check conditions can be simulated by using MSRC001\_0015[McStatusWrEn]. This is useful for debugging machine check handlers.

### 2.13.1.2.1 Machine Check Error Logging and Reporting

An error is considered enabled for logging if:

- The global enable for the corresponding error-reporting bank in [The Global Machine Check Exception Reporting Control Register (MCG\_CTL)] MSR0000\_017B is set to 1.
- The corresponding mask bit for the error in [The Machine Check Control Mask Registers (MCi\_CTL\_MASK)] MSRC001\_00[49:44] is cleared to 0.

An error is considered enabled for reporting if:

- The error is enabled for logging.
- The corresponding enable bit for the error in MCi\_CTL is set to 1.

# 2.13.1.2.2 Machine Check Error Logging Overwrite During Overflow

During error overflow conditions (see MSR0000\_0401[Over] and MSR0000\_0411[Over]), an error which has already been logged in the status register may be overwritten.

Table 37 indicates which errors are overwritten in the MC0 and MC4 error status registers. Table 38 indicates which errors are overwritten in the MC1, MC2, and MC3 error status registers.

Table 37: MC0 and MC4 Overwrite Priorities

|             |               |          |         | Older     | Error     |           |
|-------------|---------------|----------|---------|-----------|-----------|-----------|
|             |               |          | Uncor   | rectable  | Correc    | ctable    |
|             |               |          | Enabled | Disabled  | Enabled   | Disabled  |
|             | Uncorrectable | Enabled  | 1       | Overwrite | Overwrite | Overwrite |
| Younger     |               | Disabled | -       | Overwrite | Overwrite | Overwrite |
| Error       | Correctable   | Enabled  | 1       | Overwrite | Overwrite | Overwrite |
| Correctable |               | Disabled | -       | Overwrite | Overwrite | Overwrite |

Table 38: MC1, MC2, and MC3 Overwrite Priorities

|             |                       |          |         | Older     | Error     |           |
|-------------|-----------------------|----------|---------|-----------|-----------|-----------|
|             |                       |          | Uncor   | rectable  | Correc    | ctable    |
|             |                       |          | Enabled | Disabled  | Enabled   | Disabled  |
|             | Uncorrectable Younger | Enabled  | -       | Overwrite | Overwrite | Overwrite |
| Younger     |                       | Disabled | -       | Overwrite | Overwrite | Overwrite |
| Error       | Correctable           | Enabled  | -       | Overwrite | -         | Overwrite |
| Correctable |                       | Disabled | -       | Overwrite | -         | Overwrite |

### 2.13.1.3 Handling Machine Check Exceptions

At a minimum, the machine check handler must be capable of logging errors for later examination. The handler should log as much information as is needed to diagnose the error.

More thorough exception handler implementations can analyze errors to determine if each error is recoverable. If a recoverable error is identified, the exception handler can attempt to correct the error and restart the interrupted program. Keep in mind that an error may not be recoverable for the process it directly affects, but may be containable to only that process, so that other processes in the system are unaffected.

Machine check exception handlers that attempt to recover must be thorough in their analysis and the corrective actions they take. The following guidelines should be used when writing such a handler:

- All status registers in the error-reporting banks must be examined to identify the cause of the machine check exception. Read [The Global Machine Check Capabilities Register (MCG\_CAP)]
   MSR0000\_0179[Count] to determine the number of status registers visible to each CPU core. The status registers are numbered from 0 to one less than the value found in MSR0000\_0179[Count]. For example, if the Count field indicates five status registers are supported, they are numbered MC0\_STATUS to MC4\_STATUS.
- Check the valid bit in each status register (MCi\_STATUS[Val]). The remainder of the MCi\_STATUS register does not need to be examined when its valid bit is clear.
- When identifying the error condition, portable exception handlers should examine MCi\_STATUS[Error Code] and [ErrorCodeExt].
- When logging errors, particularly those that are not recoverable, check [The Global Machine Check Status Register (MCG\_STAT)] MSR0000\_017A[EIPV] to see if the instruction pointer address pushed onto the exception handler stack is related to the machine check. If EIPV is clear, the address is not guaranteed to be related to the error.
- Check the valid MCi\_STATUS registers to see if error recovery is possible. Error recovery is not possible when:
  - The processor context corrupt indicator (MCi\_STATUS[PCC]) is set to 1.
  - The error overflow status indicator (MCi\_STATUS[Over]) is set to 1. This indicates that more than one machine check error has occurred, but only one error is reported by the status register.

If error recovery is not possible, the handler should log the error information and return to the operating system.

- Check MCi\_STATUS[UC] to see if the processor corrected the error. If UC is set, the processor did not correct the error, and the exception handler must correct the error prior to attempting to restart the interrupted program. If the handler cannot correct the error, it should log the error information and return to the operating system.
- If [The Global Machine Check Status Register (MCG\_STAT)] MSR0000\_017A[RIPV] is set, the interrupted program can be restarted reliably at the instruction pointer address pushed onto the exception handler stack. If RIPV is clear, the interrupted program cannot be restarted reliably, although it may be possible to restart it for debugging purposes.
- Prior to exiting the machine check handler, be sure to clear [The Global Machine Check Status Register (MCG\_STAT)] MSR0000\_017A[MCIP]. MCIP indicates that a machine check exception is in progress. If this bit is set when another machine check exception occurs, the processor enters the shutdown state.
- When an exception handler is able to successfully log an error condition, clear the MCi\_STATUS registers prior to exiting the machine check handler. Software is responsible for clearing at least MCi\_STATUS[Val].

Additional machine check handler portability can be added by having the handler use the CPUID instruction to identify the processor and its capabilities. Implementation specific software can be added to the machine check

exception handler based on the processor information reported by CPUID.

# 2.13.1.4 Error Thresholding

For some types of errors, the hardware maintains counts of correctable errors. When the counter reaches a programmable threshold, an event may optionally be triggered to inform software. This is known as error thresholding. Thresholding is performed for the following "Error Threshold Groups" as identified in Table 53 on page 214:

- DRAM
  - Spare memory can replace memory with excessive errors. See 2.8.10 [On-Line Spare] on page 106.
- Links
- L3 cache

For more details, see [The NB Machine Check Misc (Thresholding) Registers] F3x1[78, 70, 68, 60].

#### 2.13.2 DRAM Considerations for ECC

DRAM is protected against errors by an error correcting code (ECC). The DRAM error correcting code employed is a 128/16 (data bits/check bits) SSC-DSD (Single Symbol Correction, Double Symbol Detection) BCH code. A symbol is a group of 4 bits which are 4-bit aligned. Bits 0–3 make symbol 0, bits 4–7 make symbol 1, and so on.

A single symbol error is any bit error combination within one symbol. The ECC is able to detect and correct any number of incorrect bits in a single symbol, to detect any number of incorrect bits in two separate symbols, and may detect more than two symbol errors depending on the position of corrupted symbols.

ECC has different characteristics depending on the physical configuration of the memory, including DRAM device width, ganged vs. unganged DRAM modes, and data interleaving. DRAM device width refers to the number of bits sourced simultaneously from a single memory chip. Ganged refers to the use of both DRAM controllers within a memory controller acting in concert to access memory. For a description of ganged (128-bit DRAM data width) and unganged (64-bit DRAM data width) DRAM modes, see section 2.8 [DRAM Controllers (DCTs)] on page 60. Data interleaving refers to the way bits from the different memory beats are organized in a line. For the proper setting of data interleaving while in unganged mode, see F2x110[DctDatIntLv].

In certain configurations, the ECC provides "chipkill" functionality; all single symbol errors caused by a failed DRAM device are corrected. Chipkill recovery is only possible when indicated in F3x44[ChipKillEccEn], and requires a symbol size greater than or equal to the DRAM device width. When a DRAM device fails, the code is able to correct the entire lost symbol, as long as there are no other symbols with errors. In cases where the symbol size is smaller than the DRAM device width, DRAM device failures result in multiple symbol errors, and cannot be corrected.

For an indication of the current hardware settings regarding chipkill, see F3x44[ChipKillEccEn].

The configuration specific recommendations and detection and correction characteristics are as follows:

- For x4 DRAM devices in ganged mode; the failure of a DRAM device results in an error to a single symbol and can be corrected (chipkill).
- For x4 DRAM devices in unganged mode; the failure of a DRAM device results in errors to two symbols, and can be detected but cannot be corrected.
- For DRAM devices wider than x4; the failure of a DRAM device results in errors to multiple symbols, and

can be detected with a high probability but cannot be corrected. Note that DRAM devices wider than the symbol size are not recommended for high availability systems, due to the higher potential for undetected or miscorrected errors.

### 2.13.2.1 Unganged Interleaving

Note that in unganged DRAM mode (section 2.8 [DRAM Controllers (DCTs)] on page 60), even and odd bits from two 64-bit DRAM data beats are interleaved to create a 128-bit line as shown in Figure 10. The ECC function is applied to this 128-bit result. When using the ECC syndrome to find the bits in error, use Figure 10 to map from the symbol and bit number back to the correct device bit. Refer to 2.8.5 [Routing DRAM Requests] on page 62 for details on how to map to a DIMM and device.



Figure 10: Example of line interleaving from x4 DRAM in unganged DRAM mode

When two lines are interleaved, a partially failing device (e.g., pin failure) contributes two incorrect bits to the same symbol, which can be corrected by the ECC. A totally failing DRAM device (i.e., chip failure) which is wide enough to contribute error bits to two different symbols results in an uncorrectable error.

### 2.13.2.2 ECC Syndromes

For correctable errors, the DIMM in error is uniquely identified by the error address (F3x50[ErrAddr]) and the ECC syndrome (F3x48[Syndrome[15:8]] and F3x4C[Syndrome[7:0]]). The error address maps to the two DIMMs composing the 128-bit line, and the ECC syndrome identifies one DIMM by identifying the symbol within the line.

The syndrome field uniquely identifies the failing bit positions of a correctable ECC error. Only syndromes identified by Table 39 are correctable by the error correcting code.

Symbols 00h-0Fh map to data bits 0-63; symbols 10h-1Fh map to data bits 64-127; symbols 20-21h map to ECC check bits for data bits 0-63; symbols 22-23h map to ECC check bits for data bits 64-127.

To use Table 39, first find the 16-bit syndrome value in the table. This is most easily done by using low order 4 bits of the syndrome to select the appropriate error bitmask column. The entire four digit syndrome should then be in one of the rows of that column. The row "Symbol in error" indicates which symbol, and therefore which DIMM, and the column indicates which bits within the symbol.

For example, if the ECC syndrome is 6913h, then symbol 05h has the error, and bits 0 and 1 within that symbol

are corrupted, since the syndrome is in column 3h (0011b). Symbol 05h maps to bits 23-20, so the corrupted bits are 20 and 21.

Table 39: ECC correctable syndromes

| Symbol   |      |      |      |      |      |      | Erro | or bitn | nask |                   |      |      |      |      |      |
|----------|------|------|------|------|------|------|------|---------|------|-------------------|------|------|------|------|------|
| in error | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000    | 1001 | 1010              | 1011 | 1100 | 1101 | 1110 | 1111 |
| Data 0   | e821 | 7c32 | 9413 | bb44 | 5365 | c776 | 2f57 | dd88    | 35a9 | a1ba              | 499b | 66cc | 8eed | 1afe | f2df |
| Data 1   | 5d31 | a612 | fb23 | 9584 | c8b5 | 3396 | 6ea7 | eac8    | b7f9 | 4cda              | 11eb | 7f4c | 227d | d95e | 846f |
| Data 2   | 0001 | 0002 | 0003 | 0004 | 0005 | 0006 | 0007 | 0008    | 0009 | 000a              | 000b | 000c | 000d | 000e | 000f |
| Data 3   | 2021 | 3032 | 1013 | 4044 | 6065 | 7076 | 5057 | 8088    | a0a9 | b0ba              | 909b | c0cc | e0ed | f0fe | d0df |
| Data 4   | 5041 | a082 | f0c3 | 9054 | c015 | 30d6 | 6097 | e0a8    | b0e9 | 402a              | 106b | 70fc | 20bd | d07e | 803f |
| Data 5   | be21 | d732 | 6913 | 2144 | 9f65 | f676 | 4857 | 3288    | 8ca9 | e5ba              | 5b9b | 13cc | aded | c4fe | 7adf |
| Data 6   | 4951 | 8ea2 | c7f3 | 5394 | 1ac5 | dd36 | 9467 | a1e8    | e8b9 | 2f4a              | 661b | f27c | bb2d | 7cde | 358f |
| Data 7   | 74e1 | 9872 | ec93 | d6b4 | a255 | 4ec6 | 3a27 | 6bd8    | 1f39 | f3aa              | 874b | bd6c | c98d | 251e | 51ff |
| Data 8   | 15c1 | 2a42 | 3f83 | cef4 | db35 | e4b6 | f177 | 4758    | 5299 | 6d1a              | 78db | 89ac | 9c6d | a3ee | b62f |
| Data 9   | 3d01 | 1602 | 2b03 | 8504 | b805 | 9306 | ae07 | ca08    | f709 | dc0a              | e10b | 4f0c | 720d | 590e | 640f |
| Data 10  | 9801 | ec02 | 7403 | 6b04 | f305 | 8706 | 1f07 | bd08    | 2509 | 510a              | c90b | d60c | 4e0d | 3a0e | a20f |
| Data 11  | d131 | 6212 | b323 | 3884 | e9b5 | 5a96 | 8ba7 | 1cc8    | cdf9 | 7eda              | afeb | 244c | f57d | 465e | 976f |
| Data 12  | e1d1 | 7262 | 93b3 | b834 | 59e5 | ca56 | 2b87 | dc18    | 3dc9 | ae7a              | 4fab | 642c | 85fd | 164e | f79f |
| Data 13  | 6051 | b0a2 | d0f3 | 1094 | 70c5 | a036 | c067 | 20e8    | 40b9 | 904a              | f01b | 307c | 502d | 80de | e08f |
| Data 14  | a4c1 | f842 | 5c83 | e6f4 | 4235 | 1eb6 | ba77 | 7b58    | df99 | 831a              | 27db | 9dac | 396d | 65ee | c12f |
| Data 15  | 11c1 | 2242 | 3383 | c8f4 | d935 | eab6 | fb77 | 4c58    | 5d99 | 6e1a              | 7fdb | 84ac | 956d | абее | b72f |
| Data 16  | 45d1 | 8a62 | cfb3 | 5e34 | 1be5 | d456 | 9187 | a718    | e2c9 | 2d7a              | 68ab | f92c | bcfd | 734e | 369f |
| Data 17  | 63e1 | b172 | d293 | 14b4 | 7755 | a5c6 | c627 | 28d8    | 4b39 | 99aa              | fa4b | 3c6c | 5f8d | 8d1e | eeff |
| Data 18  | b741 | d982 | 6ec3 | 2254 | 9515 | fbd6 | 4c97 | 33a8    | 84e9 | ea2a              | 5d6b | 11fc | a6bd | c87e | 7f3f |
| Data 19  | dd41 | 6682 | bbc3 | 3554 | e815 | 53d6 | 8e97 | 1aa8    | c7e9 | 7c2a              | a16b | 2ffc | f2bd | 497e | 943f |
| Data 20  | 2bd1 | 3d62 | 16b3 | 4f34 | 64e5 | 7256 | 5987 | 8518    | aec9 | b87a              | 93ab | ca2c | e1fd | f74e | dc9f |
| Data 21  | 83c1 | c142 | 4283 | a4f4 | 2735 | 65b6 | e677 | f858    | 7b99 | 391a              | badb | 5cac | df6d | 9dee | 1e2f |
| Data 22  | 8fd1 | c562 | 4ab3 | a934 | 26e5 | 6c56 | e387 | fe18    | 71c9 | 3b7a              | b4ab | 572c | d8fd | 924e | 1d9f |
| Data 23  | 4791 | 89e2 | ce73 | 5264 | 15f5 | db86 | 9c17 | a3b8    | e429 | 2a5a              | 6dcb | f1dc | b64d | 783e | 3faf |
| Data 24  | 5781 | a9c2 | fe43 | 92a4 | c525 | 3b66 | 6ce7 | e3f8    | b479 | 4a3a              | 1dbb | 715c | 26dd | d89e | 8f1f |
| Data 25  | bf41 | d582 | 6ac3 | 2954 | 9615 | fcd6 | 4397 | 3ea8    | 81e9 | eb2a              | 546b | 17fc | a8bd | c27e | 7d3f |
| Data 26  | 9391 | e1e2 | 7273 | 6464 | f7f5 | 8586 | 1617 | b8b8    | 2b29 | 595a              | cacb | dcdc | 4f4d | 3d3e | aeaf |
| Data 27  | cce1 | 4472 | 8893 | fdb4 | 3155 | b9c6 | 7527 | 56d8    | 9a39 | 12aa              | de4b | ab6c | 678d | ef1e | 23ff |
| Data 28  | a761 | f9b2 | 5ed3 | e214 | 4575 | 1ba6 | bcc7 | 7328    | d449 | 8a9a              | 2dfb | 913c | 365d | 688e | cfef |
| Data 29  | ff61 | 55b2 | aad3 | 7914 | 8675 | 2ca6 | d3c7 | 9e28    | 6149 | cb9a              | 34fb | e73c | 185d | b28e | 4def |
| Data 30  | 5451 | a8a2 | fcf3 | 9694 | c2c5 | 3e36 | 6a67 | ebe8    | bfb9 | 43 <del>4</del> a | 171b | 7d7c | 292d | d5de | 818f |
| Data 31  | 6fc1 | b542 | da83 | 19f4 | 7635 | acb6 | c377 | 2e58    | 4199 | 9b1a              | f4db | 37ac | 586d | 82ee | ed2f |
| Check0   | be01 | d702 | 6903 | 2104 | 9f05 | f606 | 4807 | 3208    | 8c09 | e50a              | 5b0b | 130c | ad0d | c40e | 7a0f |

**Table 39: ECC correctable syndromes** 

| Symbol   |      |      |      |      |      |      | Erro | or bitn | nask |      |      |      |      |      |      |
|----------|------|------|------|------|------|------|------|---------|------|------|------|------|------|------|------|
| in error | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000    | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 |
| Check1   | 4101 | 8202 | c303 | 5804 | 1905 | da06 | 9b07 | ac08    | ed09 | 2e0a | 6f0b | f40c | b50d | 760e | 370f |
| Check2   | c441 | 4882 | 8cc3 | f654 | 3215 | bed6 | 7a97 | 5ba8    | 9fe9 | 132a | d76b | adfc | 69bd | e57e | 213f |
| Check3   | 7621 | 9b32 | ed13 | da44 | ac65 | 4176 | 3757 | 6f88    | 19a9 | f4ba | 829b | b5cc | c3ed | 2efe | 58df |

### 2.13.3 Sideband Interface (SBI)

The sideband interface (SBI) is an SMBus v2.0 compatible 2-wire processor slave interface. SBI is also referred as the Advanced Platform Management Link. All I2C v2.1 speeds are supported.

SBI is used to communicate withthe Temperature Sensor Interface (SB-TSI) (see the SBI Temperature Sensor Interface (SB-TSI) Specification, #40821).

#### 2.13.3.1 SBI Processor Information

Processor access to the SBI configuration is via [The SBI Control Register] F3x1E4. The processor can access SB-TSI registers through [The SBI Address Register] F3x1E8 and [The SBI Data Register] F3x1EC.

# 2.14 Interrupts

#### **2.14.1 Local APIC**

The local APIC contains logic to receive interrupts from a variety of sources and to send interrupts to other local APICs, as well as registers to control its behavior and report status. Interrupts can be received from:

- I/O devices including the I/O hub (I/O APICs)
- Other local APICs (inter-processor interrupts)
- APIC timer
- · Thermal events
- Performance counters
- Legacy local interrupts from the I/O hub (INTR and NMI)
- APIC internal errors

The APIC timer, thermal events, performance counters, local interrupts, and internal errors are all considered local interrupt sources, and their routing is controlled by local vector table entries. These entries assign a message type and vector to each interrupt, allow them to be masked, and track the status of the interrupt.

I/O and inter-processor interrupts have their message type and vector assigned at the source and are unaltered by the local APIC. They carry a destination field and a mode bit that together determine which local APIC(s) accepts them. The destination mode (DM) bit specifies if the interrupt request packet should be handled in physical or logical destination mode. If the destination field is FFh, the interrupt is broadcast and is accepted by all local APICs regardless of destination mode.

### 2.14.1.1 Physical Destination Mode

The interrupt is only accepted by the local APIC whose APIC20[ApicId] matches the destination field of the interrupt. Physical mode allows up to 255 APICs to be addressed individually.

# 2.14.1.2 Logical Destination Mode

A local APIC accepts interrupts selected by [The Logical Destination Register] APICD0 and the destination field of the interrupt using either cluster or flat format as configured by APICE0[Format].

If flat destinations are in use, bits 7-0 of APICD0[Destination] are checked against bits 7-0 of the arriving interrupt's destination field. If any bit position is set in both fields, the local APIC is a valid destination. Flat format allows up to 8 APICs to be addressed individually.

If cluster destinations are in use, bits 7-4 of APICD0[Destination] are checked against bits 7-4 of the arriving interrupt's destination field to identify the cluster. If all of bits 7-4 match, then bits 3-0 of APICD0[Destination] and the interrupt destination are checked for any bit positions that are set in both fields to identify processors within the cluster. If both conditions are met, the local APIC is a valid destination. Cluster format allows 15 clusters of 4 APICs each to be addressed.

# 2.14.1.3 Interrupt Delivery

SMI, NMI, INIT, Startup, and External interrupts are classified as non-vectored interrupts.

When an APIC accepts a non-vectored interrupt, it is handled directly by the processor instead of being queued in the APIC. When an APIC accepts a fixed or lowest-priority interrupt, it sets the bit in [The Interrupt Request Registers] APIC[270:200] corresponding to the vector in the interrupt. For local interrupt sources, this comes from the vector field in that interrupt's local vector table entry. If a subsequent interrupt with the same vector arrives when the corresponding bit in APIC[270:200][RequestBits] is already set, the two interrupts are collapsed into one. Vectors 15-0 are reserved.

#### 2.14.1.4 Vectored Interrupt Handling

[The Task Priority Register] APIC80 and [The Processor Priority Register] APICA0 each contain an 8-bit priority divided into a main priority (bits 7-4) and a priority sub-class (bits 3-0). The task priority is assigned by software to set a threshold priority at which the processor is interrupted.

The processor priority is calculated by comparing the main priority (bits 7-4) of APIC80[Priority] to bits 7-4 of the 8-bit encoded value of the highest bit set in [The In-Service Registers] APIC[170:100]. The processor priority is the higher of the two main priorities.

The processor priority is used to determine if any accepted interrupts (indicated by APIC[270:200][Request-Bits]) are high enough priority to be serviced by the processor. When the processor is ready to service an interrupt, the highest bit in APIC[270:200][RequestBits] is cleared, and the corresponding bit is set in APIC[170:100][InServiceBits]. The corresponding bit in [The Trigger Mode Registers] APIC[1F0:180] is set if the interrupt is level-triggered and cleared if edge-triggered.

When the processor has completed service for an interrupt, it performs a write to [The End of Interrupt Register] APICB0, clearing the highest bit in APIC[170:100][InServiceBits] and causing the next-highest interrupt to be serviced. If the corresponding bit in APIC[1F0:180][TriggerModeBits] is set, a write to APICB0 is performed on all APICs to complete service of the interrupt at the source.

### 2.14.1.5 Interrupt Masking

Interrupt masking is controlled by the [The Extended APIC Control Register] APIC410. If APIC410[IerCap] is set, [The Interrupt Enable Registers] APIC[4F0:480] are used to mask interrupts. Any bit in APIC[4F0:480][InterruptEnableBits] that is clear indicates the corresponding interrupt is masked. A masked

interrupt is not serviced and the corresponding bit in APIC[270:200][RequestBits] remains set.

# 2.14.1.6 Spurious Interrupts

In the event that the task priority is set to or above the level of the interrupt to be serviced, the local APIC delivers a spurious interrupt vector to the processor, as specified by [The Spurious Interrupt Vector Register] APICF0. APIC[170:100] is not changed and no write to APICB0 occurs.

# 2.14.1.6.1 Spurious Interrupts Caused by Timer Tick Interrupt

A typical interrupt is asserted until it is serviced. An interrupt is deasserted when software clears the interrupt status bit within the interrupt service routine. Timer tick interrupt is an exception, since it is deasserted regardless of whether it is serviced or not.

The processor is not always able to service interrupts immediately (i.e. when interrupts are masked by clearing EFLAGS.IM).

If the processor is not able to service the timer tick interrupt for an extended period of time, the INTR caused by the first timer tick interrupt asserted during that time is delivered to the local APIC in ExtInt mode and latched, and the subsequent timer tick interrupts are lost. The following cases are possible when the processor is ready to service interrupts:

- An ExtInt interrupt is pending, and INTR is asserted. This results in timer tick interrupt servicing. This occurs 50 percent of the time.
- An ExtInt interrupt is pending, and INTR is deasserted. The processor sends the interrupt acknowledge cycle, but when the PIC receives it, INTR is deasserted, and the PIC sends a spurious interrupt vector. This occurs 50 percent of the time.

There is a 50 percent probability of spurious interrupts to the processor.

### 2.14.1.7 Lowest-Priority Interrupt Arbitration

Fixed, remote read, and non-vectored interrupts are accepted by their destination APICs without arbitration.

Delivery of lowest-priority interrupts requires all APICs to arbitrate to determine which one accepts the interrupt. If APICF0[FocusDisable] is clear, then the focus processor for an interrupt always accepts the interrupt. A processor is the focus of an interrupt if it is already servicing that interrupt (corresponding bit in APIC[170:100][InServiceBits] is set) or if it already has a pending request for that interrupt (corresponding bit in APIC[270:200][RequestBits] is set). If APIC410[IerCap] is set the interrupt must also be enabled in APIC[4F0:480][InterruptEnableBits] for a processor to be the focus processor. If there is no focus processor for an interrupt, or focus processor checking is disabled, then each APIC calculates an arbitration priority value, stored in [The Arbitration Priority Register] APIC90, and the one with the lowest result accepts the interrupt.

The arbitration priority value is calculated by comparing APIC80[Priority] with the 8-bit encoded value of the highest bit set in APIC[270:200][RequestBits] (IRRVec) and the 8-bit encoded value of the highest bit set APIC[170:100][InServiceBits] (ISRVec). If APIC410[IerCap] is set the IRRVec and ISRVec are based off the highest enabled interrupt. The main priority bits 7-4 are compared as follows:

If (APIC80[Priority[7:4]] >= IRRVec[7:4] and APIC80[Priority[7:4]] > ISRVec[7:4])
Then APIC90[Priority] = APIC80[Priority]

Else if (IRRVec[7:4] > ISRVec[7:4]) APIC90[Priority] = {IRRVec[7:4],0h} Else APIC90[Priority] = {ISRVect[7:4],0h}

# 2.14.1.8 Inter-Processor Interrupts

[The Interrupt Command Register Low] APIC300 and [The Interrupt Command Register High] APIC310 provide a mechanism for generating interrupts in order to redirect an interrupt to another processor, originate an interrupt to another processor, or allow a processor to interrupt itself. A write to register APIC300 causes an interrupt to be generated with the properties specified by the APIC300 and APIC310 fields.

# 2.14.1.9 APIC Timer Operation

The local APIC contains a 32-bit timer, controlled by [The Timer Local Vector Table Entry] APIC320, [The Timer Initial Count Register] APIC380, and [The Timer Divide Configuration Register] APIC3E0. The processor bus clock is divided by the value in APIC3E0[Div] to obtain a time base for the timer. When APIC380[Count] is written, the value is copied into [The Timer Current Count Register] APIC390. APIC390[Count] is decremented at the rate of the divided clock. When the count reaches 0, a timer interrupt is generated with the vector specified in APIC320[Vector]. If APIC320[Mode] specifies periodic operation, APIC390[Count] is reloaded with the APIC380[Count] value, and it continues to decrement at the rate of the divided clock. If APIC320[Mask] is set, timer interrupts are not generated.

#### 2.14.1.10 Generalized Local Vector Table

All LVTs (APIC320 through APIC370 and APIC[530:500]) support a generalized message type when MSRC001\_001F[DisGenLvtInt] is not set. The generalized values for MsgType are:

- 000b=Fixed)
- 010b=SMI
- 100b=NMI
- 111b=ExtINT

#### 2.14.1.11 State at Reset.

At power-up or reset, the APIC is hardware disabled (MSR0000\_001B[ApicEn]=0) so only SMI, NMI, INIT, and ExtInt interrupts may be accepted.

The APIC can be software disabled through APICF0[APICSWEn]. The software disable has no effect when the APIC is hardware disabled.

When a processor accepts an INIT interrupt, the APIC is reset as at power-up, with the exception that APIC20[ApicId] is unaffected.

### 2.14.2 System Management Mode (SMM)

System management mode (SMM) is typically used for system control activities such as power management. These activities are typically transparent to the operating system.

#### **2.14.2.1 SMM Overview**

SMM is entered by a CPU core on the next instruction boundary after a system management interrupt (SMI) is received and recognized. A CPU may be programmed to broadcast a special cycle to the system, indicating that it is entering SMM mode. The CPU core then saves its state into the SMM memory state save area and jumps to the SMI service routine (or SMI handler). The pointer to the SMI handler is specified by MSRs. The code

and data for the SMI handler are stored in the SMM memory area, which may be isolated from the main memory accesses.

The CPU core returns from SMM by executing the RSM instruction from the SMI handler. The CPU core restores its state from the SMM state save area and resumes execution of the instruction following the point where it entered SMM. The CPU core may be programmed to broadcast a special bus cycle to the system, indicating that it is exiting SMM mode.

#### 2.14.2.2 Operating Mode and Default Register Values

The software environment after entering SMM has the following characteristics:

- Addressing and operation is in Real mode. A far branch in the SMI handler can only address the lower 1M of memory, unless the SMI handler first switches to protected mode.
- 4-Gbyte segment limits.
- Default 16-bit operand, address, and stack sizes (instruction prefixes can override these defaults).
- Control transfers that do not override the default operand size truncate the EIP to 16 bits.
- Far jumps or calls cannot transfer control to a segment with a base address requiring more than 20 bits, as in Real mode segment-base addressing, unless a change is made into protected mode.
- A20M# is disabled. A20M# assertion or deassertion have no affect during SMM.
- Interrupt vectors use the Real mode interrupt vector table.
- The IF flag in EFLAGS is cleared (INTR is not recognized).
- The TF flag in EFLAGS is cleared.
- The NMI and INIT interrupts are masked.
- Debug register DR7 is cleared (debug traps are disabled).

The SMM base address is specified by [The SMM Base Address Register (SMM\_BASE)]

MSRC001\_0111[SMM\_BASE]. Important offsets to the base address pointer are:

- MSRC001\_0111[SMM\_BASE] + 8000h: SMI handler entry point.
- MSRC001\_0111[SMM\_BASE] + FE00h FFFFh: SMM state save area.

### 2.14.2.3 SMI Sources And Delivery

The processor accepts SMIs as link-defined interrupt messages only. The core/node destination of these SMIs is a function of the destination field of these messages. However, the expectation is that all such SMI messages are specified to be delivered globally (to all CPU cores of all nodes).

There are also several local events that can trigger SMIs. However, these local events do not generate SMIs directly. Each of them triggers a programmable IO cycle that is expected to target the SMI command port in the IO Hub and trigger a global SMI interrupt message back to the coherent fabric.

Local sources of SMI events that generate the IO cycle specified in [The SMI Trigger IO Cycle Register] MSRC001\_0056 are:

- In the CPU core, as specified by:
  - [The Machine Check Exception Redirection Register] MSRC001 0022.
  - [The IO Trap Registers (SMI\_ON\_IO\_TRAP\_[3:0])] MSRC001\_00[53:50].
  - [The MMIO Configuration Trap Address Registers] MSRC001\_00[5D:5A].
- In the NB, as specified by:
  - [The On-Line Spare Control Register] F3xB0.
  - [The NB Machine Check Misc (Thresholding) Registers] F3x1[78, 70, 68, 60].

• All local APIC LVT registers programmed to generate SMIs.

The status for these is stored in SMMFEC4.

In addition, there are SMI events that trigger IO cycles defined by [The Interrupt Pending and CMP-Halt Register] MSRC001\_0055; see that register for the events.

#### 2.14.2.4 SMM Initial State

After storing the save state, execution starts at MSRC001\_0111[SMM\_BASE] + 08000h. The SMM initial state is specified in the following table.

**Table 40: SMM initial state** 

| Register                  | SMM Initial State                                                          |
|---------------------------|----------------------------------------------------------------------------|
| CS                        | SMM_BASE[19:4]                                                             |
| DS                        | 0000h                                                                      |
| ES                        | 0000h                                                                      |
| FS                        | 0000h                                                                      |
| GS                        | 0000h                                                                      |
| SS                        | 0000h                                                                      |
| General-Purpose Registers | Unmodified                                                                 |
| EFLAGS                    | 0000_0002h                                                                 |
| RIP                       | 0000_0000_0000_8000h                                                       |
| CR0                       | Bits 0, 2, 3, and 31 cleared (PE, EM, TS, and PG); remainder is unmodified |
| CR4                       | 0000_0000_0000_0000h                                                       |
| GDTR                      | Unmodified                                                                 |
| LDTR                      | Unmodified                                                                 |
| IDTR                      | Unmodified                                                                 |
| TR                        | Unmodified                                                                 |
| DR6                       | Unmodified                                                                 |
| DR7                       | 0000_0000_0000_0400h                                                       |
| EFER                      | All bits are cleared except bit 12 (SVME) which is unmodified.             |

#### **2.14.2.5 SMM Save State**

In the following table, the offset field provides the offset from the SMM base address specified by [The SMM Base Address Register (SMM\_BASE)] MSRC001\_0111.

**Table 41: SMM Save State** 

| Offset | Size     | Conten | nts                         | Access    |
|--------|----------|--------|-----------------------------|-----------|
| FE00h  | Word     | ES     | Selector                    | Read-only |
| FE02h  | 6 Bytes  |        | reserved                    |           |
| FE08h  | Quadword |        | Descriptor in memory format |           |
| FE10h  | Word     | CS     | Selector                    | Read-only |
| FE12h  | 6 Bytes  |        | reserved                    |           |
| FE18h  | Quadword |        | Descriptor in memory format | ]         |

**Table 41: SMM Save State** 

| Offset | Size       | Conten  | nts                                                             | Access     |
|--------|------------|---------|-----------------------------------------------------------------|------------|
| FE20h  | Word       | SS      | Selector                                                        | Read-only  |
| FE22h  | 6 Bytes    |         | reserved                                                        |            |
| FE28h  | Quadword   |         | Descriptor in memory format                                     |            |
| FE30h  | Word       | DS      | Selector                                                        | Read-only  |
| FE32h  | 6 Bytes    |         | reserved                                                        |            |
| FE38h  | Quadword   |         | Descriptor in memory format                                     |            |
| FE40h  | Word       | FS      | Selector                                                        | Read-only  |
| FE42h  | 2 Bytes    |         | reserved                                                        |            |
| FE44h  | Doubleword |         | FS Base {16'b[47], 47:32} (see note 1 at the end of this table) |            |
| FE48h  | Quadword   |         | Descriptor in memory format                                     |            |
| FE50h  | Word       | GS      | Selector                                                        | Read-only  |
| FE52h  | 2 Bytes    |         | reserved                                                        |            |
| FE54h  | Doubleword |         | GS Base {16'b[47], 47:32} (see note 1 at the end of this table) |            |
| FE58h  | Quadword   |         | Descriptor in memory format                                     |            |
| FE60h  | 4 Bytes    | GDTR    | reserved                                                        | Read-only  |
| FE64h  | Word       |         | Limit                                                           |            |
| FE66h  | 2 Bytes    |         | reserved                                                        |            |
| FE68h  | Quadword   |         | Descriptor in memory format                                     |            |
| FE70h  | Word       | LDTR    | Selector                                                        | Read-only  |
| FE72h  | Word       |         | Attributes                                                      |            |
| FE74h  | Doubleword |         | Limit                                                           |            |
| FE78h  | Quadword   |         | Base                                                            |            |
| FE80h  | 4 Bytes    | IDTR    | reserved                                                        | Read-only  |
| FE84h  | Word       |         | Limit                                                           |            |
| FEB6h  | 2 Bytes    |         | reserved                                                        |            |
| FE88h  | Quadword   |         | Base                                                            |            |
| FE90h  | Word       | TR      | Selector                                                        | Read-only  |
| FE92h  | Word       |         | Attributes                                                      |            |
| FE94h  | Doubleword |         | Limit                                                           |            |
| FE98h  | Quadword   |         | Base                                                            |            |
| FEA0h  | Quadword   | IO_RE   | START_RIP                                                       | Read-only  |
| FEA8h  | Quadword   | IO_RE   | START_RCX                                                       |            |
| FEB0h  | Quadword   | IO_RE   | START_RSI                                                       |            |
| FEB8h  | Quadword   | IO_RE   | START_RDI                                                       |            |
| FEC0h  | Doubleword | [The SI | MM IO Trap Offset] SMMFEC0                                      | Read-only  |
| FEC4   | Doubleword | [The Lo | ocal SMI Status] SMMFEC4                                        | Read-only  |
| FEC8h  | Byte       | [The SI | MM IO Restart Byte] SMMFEC8                                     | Read-write |
| FEC9h  | Byte       | [The A  | uto Halt Restart Offset] SMMFEC9                                | Read-write |

**Table 41: SMM Save State** 

| Offset | Size       | Contents                                              | Access     |
|--------|------------|-------------------------------------------------------|------------|
| FECAh  | Byte       | [The NMI Mask] SMMFECA                                | Read-write |
| FECBh  | 5 Bytes    | reserved                                              |            |
| FED0h  | Quadword   | EFER                                                  | Read-only  |
| FED8h  | Quadword   | SVM State                                             | Read-only  |
| FEE0h  | Quadword   | Guest VMCB physical address                           | Read-only  |
| FEE8h  | Quadword   | SVM Virtual Interrupt Control                         | Read-only  |
| FEF0h  | 16 Bytes   | reserved                                              |            |
| FEFCh  | Doubleword | [The SMM-Revision Identifier] SMMFEFC                 | Read-only  |
| FF00h  | Doubleword | [The SMM Base Address Register (SMM_BASE)]<br>SMMFF00 | Read-write |
| FF04h  | 28 Bytes   | reserved                                              |            |
| FF20h  | Quadword   | Guest PAT                                             | Read-only  |
| FF28h  | Quadword   | Host EFER                                             |            |
| FF30h  | Quadword   | Host CR4                                              |            |
| FF38h  | Quadword   | Host CR3                                              |            |
| FF40h  | Quadword   | Host Cr0                                              |            |
| FF48h  | Quadword   | CR4                                                   |            |
| FF50h  | Quadword   | CR3                                                   |            |
| FF58h  | Quadword   | CR0                                                   |            |
| FF60h  | Quadword   | DR7                                                   | Read-only  |
| FF68h  | Quadword   | DR6                                                   |            |
| FF70h  | Quadword   | RFLAGS                                                | Read-write |
| FF78h  | Quadword   | RIP                                                   | Read-write |
| FF80h  | Quadword   | R15                                                   |            |
| FF88h  | Quadword   | R14                                                   |            |
| FF90h  | Quadword   | R13                                                   |            |
| FF98h  | Quadword   | R12                                                   |            |
| FFA0h  | Quadword   | R11                                                   |            |
| FFA8h  | Quadword   | R10                                                   |            |
| FFB0h  | Quadword   | R9                                                    |            |
| FFB8h  | Quadword   | R8                                                    |            |
| FFC0h  | Quadword   | RDI                                                   | Read-write |
| FFC8h  | Quadword   | RSI                                                   |            |
| FFD0h  | Quadword   | RBP                                                   |            |
| FFD8h  | Quadword   | RSP                                                   |            |
| FFE0h  | Quadword   | RBX                                                   |            |
| FFE8h  | Quadword   | RDX                                                   |            |
| FFF0h  | Quadword   | RCX                                                   |            |
| FFF8h  | Quadword   | RAX                                                   |            |

Note 1: this notation specifies that bit[47] is replicated in each of the 16 MSBs of the DW (sometimes called *sign extended*). The 16 LSBs contain bits[47:32].

The SMI save state includes most of the integer execution unit. Not included in the save state are: the floating point state, MSRs, and CR2. In order to be used by the SMI handler, these must be saved and restored. The save state is the same, regardless of the operating mode (32-bit or 64-bit).

The following are some offsets in the SMM save state area. The mnemonic for each offset is in the form SMMxxxx, where xxxx is the offset in the save state.

### **SMMFEC0 SMM IO Trap Offset**

If the assertion of SMI is recognized on the boundary of an IO instruction, [The SMM IO Trap Offset] SMMFEC0 contains information about that IO instruction. For example, if an IO access targets an unavailable device, the system can assert SMI and trap the IO instruction. SMMFEC0 then provides the SMI handler with information about the IO instruction that caused the trap. After the SMI handler takes the appropriate action, it can reconstruct and then re-execute the IO instruction from SMM. Or, more likely, it can use [The SMM IO Restart Byte] SMMFEC8, to cause the CPU core to re-execute the IO instruction immediately after resuming from SMM.

| Bits  | Description                                                                                                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Port: trapped IO port address. Read-only. This provides the address of the IO instruction.                                                                                                    |
| 15:12 | BPR: IO breakpoint match. Read-only.                                                                                                                                                          |
| 11    | TF: EFLAGS TF value. Read-only.                                                                                                                                                               |
| 10:7  | Reserved.                                                                                                                                                                                     |
| 6     | SZ32: size 32 bits. Read-only. 1=Port access was 32 bits.                                                                                                                                     |
| 5     | SZ16: size 16 bits. Read-only.1= Port access was 16 bits.                                                                                                                                     |
| 4     | SZ8: size 8 bits. Read-only. 1=Port access was 8 bits.                                                                                                                                        |
| 3     | REP: repeated port access. Read-only.                                                                                                                                                         |
| 2     | STR: string-based port access. Read-only.                                                                                                                                                     |
| 1     | <b>V: IO trap word valid</b> . Read-only. 1=The CPU core entered SMM on an IO instruction boundary; all information in this offset is valid. 0=The other fields of this offset are not valid. |
| 0     | RW: port access type. Read-only. 0=IO write (OUT instruction). 1=IO read (IN instruction).                                                                                                    |

#### **SMMFEC4 Local SMI Status**

This offset stores status bits associated with SMI sources local to the CPU core. For each of these bits, 1=The associated mechanism generated an SMI.

| Bits  | Description                                                                                                                                                                                                                   |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | Reserved.                                                                                                                                                                                                                     |
|       | <b>SmiSrcOnLineSpare: SMI source on-line spare</b> . This bit is associated with the SMI sources specified in [The On-Line Spare Control Register] F3xB0.                                                                     |
| 21    | Reserved.                                                                                                                                                                                                                     |
| 20    | SmiSrcThrCntL3: SMI source L3 cache thresholding. This bit is associated with the SMI source specified in the L3 cache thresholding register (see [The NB Machine Check Misc (Thresholding) Registers] F3x1[78, 70, 68, 60]). |

| 19    | <b>SmiSrcThrCntHt: SMI source link thresholding</b> . This bit is associated with the SMI source specified in the link thresholding register (see [The NB Machine Check Misc (Thresholding) Registers] F3x1[78, 70, 68, 60]).   |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18    | <b>SmiSrcThrCntDram: SMI source DRAM thresholding</b> . This bit is associated with the SMI source specified in the DRAM thresholding register (see [The NB Machine Check Misc (Thresholding) Registers] F3x1[78, 70, 68, 60]). |
| 17    | <b>SmiSrcLvtExt: SMI source LVT extended entry</b> . This bit is associated with the SMI sources specified in [The Extended Interrupt [3:0] Local Vector Table Registers] APIC[530:500].                                        |
| 16    | <b>SmiSrcLvtLcy: SMI source LVT legacy entry</b> . This bit is associated with the SMI sources specified by the non-extended LVT entries of the APIC.                                                                           |
| 15:11 | Reserved.                                                                                                                                                                                                                       |
| 10    | <b>IntPendSmiSts: interrupt pending SMI status</b> . This bit is associated with the SMI source specified in [The Interrupt Pending and CMP-Halt Register] MSRC001_0055[IntrPndMsg] (when that bit is high).                    |
| 9     | SmiOnCmpHaltSts: SMI on CMP halt status. This bit is associated with the SMI source specified in [The Interrupt Pending and CMP-Halt Register] MSRC001_0055[SmiOnCmpHalt].                                                      |
| 8     | MceRedirSts: machine check exception redirection status. This bit is associated with the SMI source specified in [The Machine Check Exception Redirection Register] MSRC001_0022[RedirSmiEn].                                   |
| 7:4   | MmioCfgTrapSts: memory mapped IO configuration trap status. Each of these bits is associated with each of the respective SMI sources specified in [The MMIO Configuration Trap Address Registers] MSRC001_00[5D:5A].            |
| 3:0   | <b>IoTrapSts: IO trap status</b> . Each of these bits is associated with each of the respective SMI sources specified in [The IO Trap Registers (SMI_ON_IO_TRAP_[3:0])] MSRC001_00[53:50].                                      |

# **SMMFEC8 SMM IO Restart Byte**

00h on entry into SMM.

If the CPU core entered SMM on an IO instruction boundary, the SMI handler may write this to FFh. This causes the CPU core to re-execute the trapped IO instruction immediately after resuming from SMM. The SMI handler should only write to this byte if SMMFEC0[V]=1; otherwise, the behavior is undefined.

If a second SMI is asserted while a valid IO instruction is trapped by the first SMI handler, the CPU services the second SMI prior to re-executing the trapped IO instruction. SMMFEC0[V]=0 during the second entry into SMM, and the second SMI handler must not rewrite this byte.

If there is a simultaneous SMI IO instruction trap and debug breakpoint trap, the processor first responds to the SMI and postpones recognizing the debug exception until after resuming from SMM. If debug registers other than DR6 and DR7 are used while in SMM, they must be saved and restored by the SMI handler. If [The SMM IO Restart Byte] SMMFEC8, is set to FFh when the RSM instruction is executed, the debug trap does not occur until after the IO instruction is re-executed.

| Bits | Description                           |
|------|---------------------------------------|
| 7:0  | RST: SMM IO Restart Byte. Read-write. |

# **SMMFEC9** Auto Halt Restart Offset

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:1  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0    | <b>HLT:</b> halt restart. Read-write. Upon SMM entry, this bit indicates whether SMM was entered from the halt state. 0=Entered SMM on a normal x86 instruction boundary. 1=Entered SMM from the halt state.                                                                                                                                                                                                                                                                                                                                                                                     |
|      | Before returning from SMM, this bit can be written by the SMI handler to specify whether the return from SMM should take the processor back to the halt state or to the instruction-execution state specified by the SMM state save area (normally, the instruction after the halt). 0=Return to the instruction specified in the SMM save state. 1=Return to the halt state. If the return from SMM takes the processor back to the halt state, the HLT instruction is not refetched and re-executed. However, the halt special bus cycle is broadcast and the processor enters the halt state. |

# **SMMFECA NMI Mask**

| Bits | Description                                                                                                      |
|------|------------------------------------------------------------------------------------------------------------------|
| 7:1  | Reserved.                                                                                                        |
| 0    | <b>NmiMask</b> . Read-write. Specifies whether NMI was masked upon entry to SMM. 0=NMI not masked. 1=NMI masked. |

### **SMMFED8 SMM SVM State**

This offset stores the SVM state of the processor upon entry into SMM.

|   | Bits | S Description                                                                              |  |
|---|------|--------------------------------------------------------------------------------------------|--|
| Ī | 7:0  | SVM State. Read-only. 00h=SMM entered from a non-guest state. 02h=SMM entered from a guest |  |
|   |      | state. 06h=SMM entered from a guest state with nested paging enabled.                      |  |

# **SMMFEFC SMM-Revision Identifier**

| SMM entry | state: | 0003_ | 0064h |
|-----------|--------|-------|-------|
|-----------|--------|-------|-------|

| Bits  | Description                                |  |
|-------|--------------------------------------------|--|
| 31:18 | 31:18 Reserved.                            |  |
| 17    | BRL. Read-only. Base relocation supported. |  |
| 16    | IOTrap. Read-only. IO trap supported.      |  |
| 15:0  | Revision. Read-only.                       |  |

# SMMFF00 SMM Base Address Register (SMM\_BASE)

This offset is loaded with the contents of MSRC001\_0111. See that register for more details.

### 2.14.2.6 Exceptions and Interrupts in SMM

When SMM is entered, the CPU masks INTR, NMI, SMI, INIT, and A20M interrupts. The CPU clears the IF flag to disable INTR interrupts. To enable INTR interrupts within SMM, the SMM handler must set the IF flag to 1. A20M is disabled so that address bit 20 is never masked when in SMM.

Generating an INTR interrupt can be used for unmasking NMI interrupts in SMM. The CPU recognizes the assertion of NMI within SMM immediately after the completion of an IRET instruction. Once NMI is recognized within SMM, NMI recognition remains enabled until SMM is exited, at which point NMI masking is restored to the state it was in before entering SMM.

While in SMM, the CPU responds to the DBREQ and STPCLK interrupts, as well as to all exceptions that may be caused by the SMI handler.

# 2.14.2.7 The Protected ASeg and TSeg Areas

These ranges are controlled by MSRC001\_0112 and MSRC001\_0113; see those registers for details.

# 2.14.2.8 SMM Special Cycles

Special cycles can be initiated on entry and exit from SMM to acknowledge to the system that these transitions are occurring. These are controlled by MSRC001\_0015[SMISPCYCDIS, RSMSPCYCDIS].

# **2.14.2.9** Locking SMM

The SMM registers (MSRC001\_0112 and MSRC001\_0113) can be locked from being altered by setting MSRC001\_0015[SmmLock]. The BIOS can lock the SMM registers after initialization to prevent unexpected changes to these registers.

### 2.15 Secure Virtual Machine Mode (SVM)

Support for SVM mode is indicated by CPUID Fn8000\_0001\_ECX[SVM]. If SVM is supported, then the DEV registers starting at F3xF0 are visible.

#### 2.15.1 BIOS support for SVM Disable

The BIOS should include the following user setup options to disable AMD Virtualization<sup>TM</sup>.

- Enable AMD Virtualization<sup>TM</sup>.
  - MSRC001\_0114[Svm\_Disable] = 0.
  - MSRC001\_0114[Lock] = 1.
  - MSRC001\_0118[SvmLockKey] = 0000\_0000\_0000\_0000h.
- Disable AMD Virtualization<sup>TM</sup>.
  - MSRC001 0114[Svm Disable]=1.
  - MSRC001\_0114[Lock]=1.
  - MSRC001\_0118[SvmLockKey] = 0000\_0000\_0000\_0000h.

The BIOS may also include the following user setup options to disable AMD Virtualization<sup>TM</sup>.

- Disable AMD Virtualization<sup>TM</sup>, with a user supplied key.
  - MSRC001\_0114[Svm\_Disable]=1.
  - MSRC001\_0114[Lock]=1.

 MSRC001\_0118[SvmLockKey] programmed with value supplied by user. This value should be NVRAM.

#### 2.16 CPUID Instruction

The CPUID instruction provides data about the features supported by the processor. See section 3.9 [CPUID Instruction Registers] on page 283 for details.

# 2.16.1 Multi-Core Support

There are two methods for determining multi-core support. A recommended mechanism is provided and a legacy method is also available for existing operating systems. System software should use the correct architectural mechanism to detect the number of physical cores by observing CPUID Fn8000\_0008\_ECX[NC]. The legacy method utilizes the CPUID Fn0000\_0001\_EBX[LogicalProcessorCount].

# 2.16.2 L3 Cache Support

The BIOS must determine if the processor includes a third level memory cache (L3) by reading [The L2/L3 Cache and L2 TLB Identifiers] CPUID Fn8000\_0006 and take steps to correctly display cache size information on the POST video screen:

- Issue CPUID Fn8000\_0006. If EDX[31:16] is not zero then the processor includes an L3. The L3Size field indicates the L3 cache size.
- If the *total* cache size is displayed on the screen then the BIOS must correctly calculate the total of L1+L2+L3 sizes.
- It is preferred that the BIOS shows the exact breakdown between the L1, L2, and L3 cache sizes and the total. For example, specify L1 (128 Kbytes) + L2 (size of L2 in Kbytes) + L3 (size of L3 in Kbytes) = total cache size in Kbytes.

### 2.17 Performance Monitoring

The processor includes support for two methods of monitoring processor performance: performance monitor counters and instruction based sampling (IBS).

### 2.17.1 Performance Monitor Counters

The performance monitor counters are used by software to count specific events that occur in the processor. [The Performance Event Select Register (PERF\_CTL[3:0])] MSRC001\_00[03:00] and [The Performance Event Counter Registers (PERF\_CTR[3:0])] MSRC001\_00[07:04] specify the events to be monitored and how they are monitored. All of the events are specified in section 3.14 [Performance Counter Events] on page 337.

# 2.17.2 Instruction Based Sampling (IBS)

IBS is a code profiling mechanism that enables the processor to select a random instruction fetch or micro-op after a programmed time interval has expired and record specific performance information about the operation. An interrupt is generated when the operation is complete as specified by [The IBS Control Register] F3x1CC. An interrupt handler can then read the performance information that was logged for the operation.

The IBS mechanism is split into two parts: instruction fetch performance controlled through [The IBS Fetch Control Register (IbsFetchCtl)] MSRC001\_1030; and instruction execution performance controlled through [The IBS Execution Control Register (IbsOpCtl)] MSRC001\_1033. Instruction fetch sampling provides infor-

mation about instruction TLB and instruction cache behavior for fetched instructions. Instruction execution sampling provides information about micro-op execution behavior. The data collected for instruction fetch performance is different from the data collected for instruction execution performance.

Instruction fetch performance is profiled by recording the following performance information (see MSRC001\_1030, MSRC001\_1031, MSRC001\_1032 for details of the events) for the tagged instruction fetch:

- If the instruction fetch completed or was aborted.
- The number of clock cycles spent on the instruction fetched.
- If the instruction fetch hit or missed the instruction cache.
- If the instruction fetch hit or missed the L1 and L2 TLBs.
- The linear and physical address associated with the fetch.

Instruction execution performance is profiled by tagging one micro-op associated with an instruction. Instructions that decode to more than one micro-op return different performance data depending upon which micro-op associated with the instruction is tagged. The following performance information (see MSRC001\_1034, MSRC001\_1035, MSRC001\_1036, MSRC001\_1037, MSRC001\_1038, and MSRC001\_1039 for details of the events) is returned for the tagged micro-op:

- Branch status for branch micro-ops.
- The number clocks from when the micro-op was tagged until the micro-op retires.
- The number clocks from when the micro-op completes execution until the micro-op retires.
- Source information for DRAM, MMIO and IO access.
- L3 cache state for accesses that hit the L3 cache.
- If the operation was a load or store that missed the data cache.
- If the operation was a load or store that hit or missed the L1 and L2 TLBs.
- The linear and physical address associated with a load or store operation.

# 3 Registers

This section provides detailed field definitions for the register sets in the processor.

# 3.1 Register Descriptions and Mnemonics

Each register in this document is referenced with a mnemonic. Each mnemonic is a concatenation of the register-space indicator and the offset of the register. Here are the mnemonics for the various register spaces:

- IOXXX: x86-defined input and output address space registers; XXX specifies the byte address of the IO instruction. This space includes IO-space configuration access registers [The IO-Space Configuration Address Register] IOCF8 and [The IO-Space Configuration Data Port] IOCFC. Accesses to these registers from each CPU core of a node target the same registers of that node; it is not possible for a node to access these registers on a different node.
- FYxXXX: PCI-defined configuration space; XXX specifies the byte address of the configuration register (this may be 2 or 3 digits); Y specifies the function number; e.g., F3x40 specifies the register at function 3, address 40h. See 2.11 [Configuration Space] on page 112, for details about configuration space. There is one set of these registers per node; these registers in any node are accessible through any CPU core of any node.
- **APICXX**: APIC memory-mapped registers; XX is the byte address offset from the base address. The base address for this space is specified by [The APIC Base Address Register (APIC\_BAR)] MSR0000\_001B.
- **CPUID FnXXXX\_XXXX**: processor capabilities information returned by the CPUID instruction. See section 3.9 [CPUID Instruction Registers] on page 283. Each CPU core may only access this information for itself.
- MSRXXXX\_XXXX: model specific registers; XXXX\_XXXX is the MSR number. This space is accessed through x86-defined RDMSR and WRMSR instructions. There is one set of these registers per CPU core; each CPU core may only access its own set of these registers.

Each node includes a single set of IO-space and configuration-space registers. However, APIC, CPUID, and MSR register spaces are implemented once per processor core. Note: access to IO-space and configuration space registers may require software-level techniques to ensure that no more than one CPU core attempts to access a register at a time.

The following is terminology found in the register descriptions.

**Table 42: Terminology in register descriptions** 

| Terminology                    | Description                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read or read-only              | Capable of being read by software. Read-only implies that the register cannot be written by software.                                                                                                                                                                                                                                            |
| Write                          | Capable of being written by software.                                                                                                                                                                                                                                                                                                            |
| Read-write                     | Capable of being written by software and read by software.                                                                                                                                                                                                                                                                                       |
| Set-or-cleared-by-<br>hardware | Register bit is set high or cleared low by hardware.                                                                                                                                                                                                                                                                                             |
| Write-once                     | After RESET_L is asserted, these registers may be written to once. After being written, they become read-only until the next RESET_L assertion. The write-once control is byte based. So, for example, software may write each byte of a write-once DWORD as four individual transactions. As each byte is written, that byte becomes read-only. |
| Write-1-to-clear               | Software must write a 1 to the bit in order to clear it. Writing a 0 to these bits has no effect.                                                                                                                                                                                                                                                |

**Table 42: Terminology in register descriptions** 

| Terminology                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write-0-to-clear                 | Software must write a 0 to the bit in order to clear it. Writing a 1 to these bits has no effect.                                                                                                                                                                                                                                                                                                                                                                                    |
| Write-1-only                     | Software can set the bit high by writing a 1 to it. Writes of 0 have no effect. Cleared by hardware.                                                                                                                                                                                                                                                                                                                                                                                 |
| Reserved                         | Field is reserved for future use. Software is required to preserve the state read from these bits when writing to the register. Software may not depend on the state of reserved fields nor on the ability of such fields to return the state previously written.                                                                                                                                                                                                                    |
| MBZ                              | Must be zero. If software attempts to set an MBZ bit to 1, a general-protection exception (#GP) occurs.                                                                                                                                                                                                                                                                                                                                                                              |
| RAZ                              | Read as zero. Writes are ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| SBZ                              | Should be zero. If software attempts to set an SBZ bit to 1, it results in undefined behavior.                                                                                                                                                                                                                                                                                                                                                                                       |
| "Must be low" or "Must be high". | The field is required to be in the state indicated; if the bit is programmed in other than the specified state, undefined behavior may result.                                                                                                                                                                                                                                                                                                                                       |
| Reset                            | The reset value of each register is provided below the mnemonic or in the field description. Unless otherwise noted, the register state matches the reset value when RESET_L is asserted (either a cold or a warm reset). Reset values may include:  ?: a question mark in the reset value indicates that the reader should look at the bit description for reset-value details.  X: an X in the reset value indicates that the field resets (warm or cold) to an unspecified state. |
| Cold reset                       | The field state is not affected by a warm reset (even if the field is labeled "cold reset: X"); it is placed into the reset state when PWROK is deasserted. See "Reset" above for the definition of characters that may be found in the cold reset value.                                                                                                                                                                                                                            |

# 3.1.1 Northbridge MSRs In Multi-Core Products

MSRs that control Northbridge functions are shared between all cores on the node in a multi-core processor (e.g. MSR0000\_0410). If control of Northbridge functions is shared between software on all cores, software must ensure that only one core at a time is allowed to access the shared MSR.

#### 3.2 IO Space Registers

See section 3.1 [Register Descriptions and Mnemonics] on page 135 for a description of the register naming convention.

### **IOCF8 IO-Space Configuration Address Register**

Reset: 0000 0000h. [The IO-Space Configuration Address Register] IOCF8, and [The IO-Space Configuration Data Port] IOCFC, are used to access system configuration space, as defined by the PCI specification. IOCF8 provides the address register and IOCFC provides the data port. Software sets up the configuration address by writing to IOCF8. Then, when an access is made to IOCFC, the processor generates the corresponding configuration access to the address specified in IOCF8. See also section 2.11 [Configuration Space] on page 112.

IOCF8 may only be accessed through aligned, DW IO reads and writes; otherwise, the accesses are passed to the appropriate IO link. Accesses to IOCF8 and IOCFC received from an IO link are treated as all other IO transactions received from an IO link and are forwarded based on the settings in [The IO-Space Base/Limit

Registers] F1x[DC:C0]. IOCF8 and IOCFC in the processor are not accessible from an IO link.

| Bits  | Description                                                                                                                                                                                                                                                                                                   |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | <b>ConfigEn: configuration space enable.</b> Read-write. 1=IO read and write accesses to IOCFC are translated into configuration cycles at the configuration address specified by this register. 0=IO read and write accesses are passed to the appropriate IO link and no configuration access is generated. |
| 30:28 | Reserved.                                                                                                                                                                                                                                                                                                     |
| 27:24 | <b>ExtRegNo:</b> extended register number. Read-write. ExtRegNo provides bits[11:8] and RegNo provides bits[7:2] of the byte address of the configuration register. ExtRegNo is reserved unless it is enabled by MSRC001_001F[EnableCf8ExtCfg].                                                               |
| 23:16 | BusNo: bus number. Read-write. Specifies the bus number of the configuration cycle.                                                                                                                                                                                                                           |
| 15:11 | <b>Device: bus number.</b> Read-write. Specifies the device number of the configuration cycle.                                                                                                                                                                                                                |
| 10:8  | <b>Function.</b> Read-write. Specifies the function number of the configuration cycle.                                                                                                                                                                                                                        |
| 7:2   | RegNo: register address. Read-write. See IOCF8[ExtRegNo].                                                                                                                                                                                                                                                     |
| 1:0   | Reserved.                                                                                                                                                                                                                                                                                                     |

# **IOCFC IO-Space Configuration Data Port**

Reset: 0000 0000h.

| Bits | Description                            |
|------|----------------------------------------|
| 31:0 | See IOCF8 for details about this port. |

# 3.3 Function 0 HyperTransport<sup>TM</sup> Technology Configuration Registers

See section 3.1 [Register Descriptions and Mnemonics] on page 135 for a description of the register naming convention. See section 2.11 [Configuration Space] on page 112 for details about how to access this space.

# F0x00 Device/Vendor ID Register

| Reset: 1200 1022h. |                                 |  |
|--------------------|---------------------------------|--|
| Bits               | Description                     |  |
| 31:16              | DeviceID: device ID. Read-only. |  |
| 15:0               | VendorID: vendor ID. Read-only. |  |

# F0x04 Status/Command Register

| Reset: | 0010 | 0000h. |
|--------|------|--------|
|        |      |        |

| Bits  | Description                                                                                           |  |  |
|-------|-------------------------------------------------------------------------------------------------------|--|--|
| 31:16 | <b>Status.</b> Read-only. Bit[20] is set to indicate the existence of a PCI-defined capability block. |  |  |
| 15:0  | Command. Read-only.                                                                                   |  |  |

#### F0x08 Class Code/Revision ID Register

| Reset: 0600 0000h. |                                                                                                |  |
|--------------------|------------------------------------------------------------------------------------------------|--|
| Bits               | Description                                                                                    |  |
| 31:8               | ClassCode. Read-only. Provides the host bridge class code as defined in the PCI specification. |  |
| 7:0                | RevID: revision ID. Read-only.                                                                 |  |

# F0x0C Header Type Register

| ] | Reset: 0080 0000h. |                                                                                                      |  |
|---|--------------------|------------------------------------------------------------------------------------------------------|--|
| Ī | Bits               | Description                                                                                          |  |
|   |                    | <b>HeaderTypeReg.</b> Read-only. These bits are fixed at their default values. The header type field |  |
|   |                    | indicates that there are multiple functions present in this device.                                  |  |

# F0x34 Capabilities Pointer Register

| Reset: 0000 00??h. |                                                                                                       |                                                                |
|--------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| Bits               | Description                                                                                           |                                                                |
| 31:8               | Reserved.                                                                                             |                                                                |
| 7:0                | CapPtr: capabilities pointer. Read-only. Specifies the offset of the link capabilities block based on |                                                                |
|                    | the links that are supported by the node. The value provided is:                                      |                                                                |
|                    | 80h                                                                                                   | If link 0 is supported.                                        |
|                    | A0h                                                                                                   | If link 0 is not supported and link 1 is supported.            |
|                    | C0h                                                                                                   | If link 0 and 1 are not supported and link 2 is supported.     |
|                    | E0h                                                                                                   | If link 0, 1, and 2 are not supported and link 3 is supported. |

# F0x[5C:40] Routing Table Registers

Reset: 0004 0201h. Each of these eight registers, F0x[5C, 58, 54, 50, 4C, 48, 44, 40], corresponds to a node ID for up to 8 nodes in the coherent fabric. F0x40 corresponds to node 0; F0x44 corresponds to node 1; etc. As each packet is processed by the node, it is routed to the appropriate links, or remains in the node that is processing the packet, based on the source/destination node and the type of packet being processed. The destination of requests and responses determines which of these eight registers is used to route the packet; the source of probes and broadcasts determines which of these eight registers is used to route the packet. Once the routing table register is identified, the packet is routed to the destinations based on the state of the field (in that routing table register) that corresponds to the packet type.

For each of the 9-bit fields in this register:

bit[0] = route to this node.

bit[1] = route to link 0, sublink 0.

bit[2] = route to link 1, sublink 0.

bit[3] = route to link 2, sublink 0.

bit[4] = route to link 3, sublink 0.

bit[5] = route to link 0, sublink 1.

bit[6] = route to link 1, sublink 1.

bit[7] = route to link 2, sublink 1.

bit[8] = route to link 3, sublink 1.

| Bits  | Description                                                                                               |  |
|-------|-----------------------------------------------------------------------------------------------------------|--|
| 31:27 | Reserved.                                                                                                 |  |
| 26:18 | <b>BCRoute:</b> broadcast route. Read-write. Specifies the routing information for broadcasts and probes. |  |
| 17:9  | <b>RPRoute: response route.</b> Read-write. Specifies the routing information for responses.              |  |
| 8:0   | <b>RQRoute: request route.</b> Read-write. Specifies the routing information for requests.                |  |

# F0x60 Node ID Register

| Reset: | Reset: 0000 000?h.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| 31:24  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 23:21  | Must be zero. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 20:16  | <b>CpuCnt[4:0]: CPU count bits[4:0].</b> Read-write. This field specifies the number of CPU cores to be enabled in the system (the boot core of all nodes plus those cores enabled through F0x68[Cpu1En] and F0x168[Cpu3En, Cpu2En]). $00h = 1$ CPU $1Fh = 32$ CPUs. This field matches F0x60[NodeCnt] if each nodes in the system has one CPU core; otherwise, it would be greater than F0x60[NodeCnt].                                                                                                 |  |  |
| 15     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 14:12  | <b>LkNode</b> [2:0]: lock node ID bits[2:0]. Read-write. This field specifies the node ID of the node that contains the lock controller.                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 11     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 10:8   | SbNode[2:0]: Southbridge (IO Hub) node ID bits[2:0]. Read-write. Specifies the node ID of the node that owns the link that connects to the system IO Hub.                                                                                                                                                                                                                                                                                                                                                |  |  |
| 7      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 6:4    | <b>NodeCnt[2:0]: node count bits[2:0].</b> Read-write. This specifies the number of coherent nodes in the system. Hardware only allows values to be programmed into this field that are consistent with the multiprocessor capabilities of the device, as specified in [The Northbridge Capabilities Register] F3xE8[MpCap]. Attempts to write values inconsistent with the capabilities of the processor result in this field not being updated. 0h = 1 node; 1h = 2 nodes; 2h = 3 nodes; 7h = 8 nodes. |  |  |
| 3      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 2:0    | <b>NodeId[2:0]: node ID bits[2:0].</b> Read-write. This specifies the node ID of the node. It is reset to 0h for the boot strap processor (BSP); it is reset to 07h for all other nodes. It is expected that system configuration software programs the Node ID. The node IDs must be contiguous. For example, the node IDs in a 4-node system may be $\{0, 1, 2, 3\}$ ; an example of an incorrect node ID assignment in this system is $\{0, 1, 3, 4\}$ . See also MSRC001_001F[InitApicIdCpuIdLo].    |  |  |

# F0x64 Unit ID Register

| Reset: 0000 00E0h. |             |  |
|--------------------|-------------|--|
| Bits               | Description |  |
| 31:11              | Reserved.   |  |

| 10:8 | <b>SbLink:</b> Southbridge (IO Hub) link ID. Read-write; set-by-hardware. This field specifies the link to which the system IO Hub is connected. It is only used by the node which owns the IO Hub, as indicated in F0x60[NodeId]. For bits[9:8]: 00b = link 0; 01b = link 1; 10b = link 2; 11b = link 3. If the link is unganged, then bit[10] specifies the sublink: 0b = sublink 0; 1b = sublink 1. If the link is ganged, bit[10] is required to be low. |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6  | <b>HbUnit:</b> host bridge Unit ID. Read-only. This field specifies the coherent link Unit ID of the host bridge used by the coherent fabric.                                                                                                                                                                                                                                                                                                                |
| 5:4  | <b>MctUnit: memory controller Unit ID.</b> Read-only. This field specifies the coherent link Unit ID of the memory controller.                                                                                                                                                                                                                                                                                                                               |
| 3:2  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1:0  | <b>CpuUnit: CPU Unit ID.</b> Read-only. This field specifies the coherent link Unit ID used for CPU core transactions.                                                                                                                                                                                                                                                                                                                                       |

# **F0x68 Link Transaction Control Register**

| Reset: 0000 0000h. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 31                 | <b>EnPReqHiPriTblWlk:</b> isoc table walk enable for posted requests. Read-write. 1=Enables the use of the Isoc channel for DEV/GART table walk requests issued for base channel posted requests. To use the Isoc channel for DEV/GART requests ICFM must be enabled, one F3x1[54, 50, 4C, 48][IsocReqTok] must be allocated on each link that can receive DEV/GART table walk requests, and one F3x1[54, 50, 4C, 48][IsocRspTok] must be allocated on each link that can receive DEV/GART table walk responses. |  |
| 30:26              | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| 25                 | <b>CHtExtAddrEn: coherent link extended address enable</b> . Read-write; however this bit is read-only, 0, for uniprocessor systems as indicated by F3xE8[MpCap]. 1=The coherent fabric supports physical addresses of greater than 40 bits. When this bit is clear, requests to addresses above 1 terabyte result in a master abort.                                                                                                                                                                            |  |
| 24                 | <b>DispRefModeEn</b> . Read-write. 1=Enables support for display-refresh ordering rules. BIOS must not set this bit until display-refresh buffers have been allocated and a warm reset has occurred. See section 2.6.4.2.4 [F0x[5C:40]Display Refresh And IFCM] on page 54.                                                                                                                                                                                                                                      |  |
| 23                 | <b>InstallStateS.</b> Read-write. 1=Forces the default read block (RdBlk) install state to be shared instead of exclusive.                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 22:21              | DsNpReqLmt: downstream non-posted request limit. Read-write. This specifies the maximum number of downstream non-posted requests issued by CPU core(s) which may be outstanding on the IO links attached to this node at one time.  00b = no limit.  01b = limited to 1.  10b = limited to 4.  11b = limited to 8.  BIOS should set this to 10b for all products.                                                                                                                                                |  |

| 20    | <b>SeqIdSrcNodeEn: sequence ID source node enable.</b> Read-write. 1=The source node ID of requests is provided in the SeqID field of the corresponding downstream IO link request packets. This may be useful for debug applications, in order to match downstream packets with their originating node. For normal operation, this bit should be cleared. Correct ordering of requests between different nodes is not guaranteed when this bit is set. Semaphore sharing between differing nodes may not work properly in systems which are capable of processing IO requests with differing non-zero seqids out of request order. |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19    | ApicExtSpur: APIC extended spurious vector enable. Read-write. This enables the extended APIC spurious vector functionality; it affects APICF0[Vector]. 0=The lower 4 bits of the spurious vector are read-only 1111b. 1=The lower 4 bits of the spurious vector are writable.                                                                                                                                                                                                                                                                                                                                                      |
| 18    | <b>ApicExtId: APIC extended ID enable.</b> Read-write. This enables the extended APIC ID functionality. 0=APIC ID is 4 bits. 1=APIC ID is 8 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 17    | <b>ApicExtBrdCst: APIC extended broadcast enable.</b> Read-write. This enables the extended APIC broadcast functionality. 0=APIC broadcast is 0Fh. 1=APIC broadcast is FFh.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 16    | <b>LintEn: local interrupt conversion enable.</b> Read-write. 1=Enables the conversion of broadcast ExtInt and NMI interrupt requests to LINT0 and LINT1 local interrupts, respectively, before delivering to the local APIC. This conversion only takes place if the local APIC is hardware enabled. LINT0 and LINT1 are controlled by APIC350 and APIC360. 0=ExtInt/NMI interrupts delivered unchanged.                                                                                                                                                                                                                           |
| 15    | LimitCldtCfg: limit coherent link configuration space range. Read-write. 1=Configuration accesses that (1) normally map to the configuration space within another node in the coherent fabric and (2) target a non-existent node as specified by F0x60[NodeCnt] are sent to an IO link instead. This bit should be set by BIOS once coherent fabric initialization is complete. Failure to do so may result in PCI configuration accesses to nonexistent nodes being sent into the coherent fabric, causing the system to hang.                                                                                                     |
| 14:13 | <b>BufRelPri:</b> buffer release priority select. Read-write. Specifies the number of link DWs sent while a buffer release is pending before the buffer release is inserted into the command/data stream of a busy link. $00b = 64$ ; $01b = 16$ ; $10b = 8$ ; $11b = 2$ . It is recommended that this be set to a value of 10b in order to maximize link bandwidth.                                                                                                                                                                                                                                                                |
| 12    | Reserved. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11    | <b>RespPassPW:</b> response PassPW. Read-write. 1=The PassPW bit in all downstream link responses is set, regardless of the originating request packet. This technically breaks the PCI ordering rules but it is not expected to be an issue in the downstream direction. Setting this bit improves the latency of upstream requests by allowing the downstream responses to pass posted writes. 0=The PassPW bit in downstream responses is based on the RespPassPW bit of the original request.                                                                                                                                   |
| 10    | <b>DisFillP: disable fill probe.</b> Read-write. Controls probes for CPU core-generated fills (must be 0 for multi-CPU core or L3-cache systems; recommended to be 1 for uniprocessor, single CPU core, no L3-cache systems). 0=Probes issued for cache fills. 1=Probes not issued for cache fills.                                                                                                                                                                                                                                                                                                                                 |
| 9     | <b>DisRmtPMemC:</b> disable remote probe memory cancel. Read-write. 1=Only probed caches on the same node as the target memory controller may generate MemCancel coherent link packets. MemCancels are used to attempt to save DRAM and/or link bandwidth associated with the transfer of stale DRAM data. 0=Probes hitting dirty blocks may generate MemCancel packets, regardless of the location of the probed cache.                                                                                                                                                                                                            |
| 8     | <b>DisPMemC:</b> disable probe memory cancel. Read-write. Controls generation of MemCancel coherent link packets. MemCancels are used to attempt to save DRAM and/or coherent link bandwidth associated with the transfer of stale DRAM data. 0=Probes hitting dirty blocks of the CPU core cache may generate MemCancel packets. 1=Probes may not generate MemCancel packets.                                                                                                                                                                                                                                                      |

| 7 | <b>CPURdRspPassPW: CPU read response PassPW.</b> Read-write. 1=Read responses to CPU coregenerated reads are allowed to pass posted writes. 0=CPU core responses do not pass posted writes. This bit is not expected to be set. This bit may only be set during the boot process.                                                                                                |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 | <b>CPUReqPassPW: CPU request PassPW.</b> Read-write. 1=CPU core-generated requests are allowed to pass posted writes. 0=CPU core requests do not pass posted writes. This bit is not expected to be set. This bit may only be set during the boot process.                                                                                                                       |
| 5 | <b>Cpu1En: CPU core 1 enable</b> . Read-write. This bit and F0x168[Cpu3En and Cpu2En] are used to enable each of the CPU cores after a reset. 1=Enable the CPU core to start fetching and executing code from the boot vector. Note: the CPU core numbers referred to in these bits are affected by down-coring; see CpuCoreNum in section [The CPU Cores and Downcoring] 2.9.2. |
| 4 | <b>DisMTS: disable memory controller target start.</b> Read-write. 1=Disables use of TgtStart. TgtStart is used to improve scheduling of back-to-back ordered transactions by indicating when the first transaction is received and ordered at the memory controller.                                                                                                            |
| 3 | <b>DisWrDwP: disable write doubleword probes.</b> Read-write. 1=Disables generation of probes for CPU core-generated, WrSized doubleword commands (must be 0 for multi-CPU core or L3-cache systems; recommended to be 1 for uniprocessor, single CPU core, no L3-cache systems).                                                                                                |
| 2 | <b>DisWrBP: disable write byte probes.</b> Read-write. 1=Disables generation of probes for CPU coregenerated, WrSized byte commands (must be 0 for multi-CPU core or L3-cache systems; recommended to be 1 for uniprocessor, single CPU core, no L3-cache systems).                                                                                                              |
| 1 | <b>DisRdDwP: disable read doubleword probe.</b> Read-write. 1=Disables generation of probes for CPU core-generated, RdSized doubleword commands (must be 0 for multi-CPU core or L3-cache systems; recommended to be 1 for uniprocessor, single CPU core, no L3-cache systems).                                                                                                  |
| 0 | <b>DisRdBP: disable read byte probe.</b> Read-write. 1=Disables generation of probes for CPU core-generated, RdSized byte commands (must be 0 for multi-CPU core or L3-cache systems; recommended to be 1 for uniprocessor, single CPU core, no L3-cache systems).                                                                                                               |

# F0x6C Link Initialization Control Register

| Reset.     | 0002 | 2222h: see | individual | hit definitions | for reset details |
|------------|------|------------|------------|-----------------|-------------------|
| IX C S C I |      |            |            |                 |                   |

| Bits  | Description                                                                                                                                                                                                                                                                                                                            |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved.                                                                                                                                                                                                                                                                                                                              |
| 19:16 | Must be zero. Read-write.                                                                                                                                                                                                                                                                                                              |
| 15:12 | Reserved.                                                                                                                                                                                                                                                                                                                              |
| 11    | DefLnk[2]: default link. Read-only. See DefLnk[1:0], below.                                                                                                                                                                                                                                                                            |
| 10:9  | BiosRstDet[2:1]: BIOS reset detect bits[2:1]. Read-write. Cold reset: 0. See bit[5] of this register.                                                                                                                                                                                                                                  |
| 8     | <b>DefSubLnk: default sublink</b> . Read-only. Used in conjunction with F0x6C[DefLnk]. 0=Sublink 0. 1=Sublink 1.                                                                                                                                                                                                                       |
| 7     | Reserved.                                                                                                                                                                                                                                                                                                                              |
| 6     | <b>InitDet: CPU initialization command detect.</b> Read-write. This bit may be used by software to distinguish between an INIT and a warm/cold reset by setting it to a 1 before an initialization event is generated. This bit is cleared by RESET_L but not by an INIT command.                                                      |
| 5     | <b>BiosRstDet[0]: BIOS reset detect bit[0].</b> Read-write. Cold reset: 0. This bit, along with BiosRst-Det[2:1], may be used to distinguish between a reset event generated by the BIOS versus a reset event generated for any other reason by setting one or more of the bits to a 1 before initiating a BIOS-generated reset event. |

| 4   | <b>ColdRstDet: cold reset detect.</b> Read-write. Cold reset: 0. This bit may be used to distinguish between a cold versus a warm reset event by setting the bit to a 1 before an initialization event is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 3:2 | DefLnk[1:0]: default link. Read-only. These bits, along with DefLnk[2], above, are updated every time an incoming request is received with the link ID of the link on which the packet arrived. It is used by hardware to route packets during initialization, while F0x6C[RouteTblDisRouting]=1, and only one outstanding request is active in the system at a time. During this interval, responses are routed to the link indicated by this field. Thus, responses are properly returned to the link, or to this node, based on the source of the request. F0x6C[DefSubLnk] is used to delineate sublinks as well.  DefLnk[2, 1:0] Definition  000b Request came from link 0 (power-up default).  010b Request came from link 1.  010b Request came from link 2.  011b Request came from link 3.  100bRequest came from a CPU core on same node. |  |  |
| 1   | <b>ReqDis: request disable.</b> Read-write; set-by-hardware. This bit specifies if the node is allowed to generate request packets. It resets to 0 for the BSP and to 1 for all other nodes. This bit should be cleared by BIOS once the system has been initialized from the BSP. This bit is set by hardware and cleared by software. 0=Request packets may be generated. 1=Request packets may not be generated. See section 2.3 [Processor Initialization] on page 22.                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 0   | <b>RouteTblDis:</b> routing table disable. Read-write. 1=Responses are routed based on F0x6C[DefLnk] and configuration-space requests received by this node are treated as if they target this node regardless of the bus number and device number. 0=Packets are routed according to [The Routing Table Registers] F0x[5C:40]. This bit is reset to 1. Once the routing tables have been set up this bit should be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |

# F0x[E0, C0, A0, 80] Link Capabilities Registers

F[4, 0]x[98:80] are associated with link 0. F[4, 0]x[B8:A0] are associated with link 1. F[4, 0]x[D8:C0] are associated with link 2. F[4, 0]x[F8:E0] are associated with link 3. The function 0 registers are associated with the whole link if it is ganged or sublink 0 if it is unganged; the function 4 register are associated with sublink 1 if the link is unganged. If the node does not support a link, then the corresponding register addresses become reserved. This register is derived from the link capabilities register defined in the  $HyperTransport^{TM}I/OLink$  Specification.

| Bits  | Description                                                    |
|-------|----------------------------------------------------------------|
| 31:29 | CapType: capability type. Read-only, 001b.                     |
| 28    | <b>DropOnUnInit: drop on uninitialized link.</b> Read-only, 0. |
| 27    | InbndEocErr: inbound end-of-chain error. Read-only, 0.         |
| 26    | ActAsSlave: act as slave. Read-only, 0.                        |
| 25    | Reserved.                                                      |
| 24    | HostHide. Read-only, 1.                                        |
| 23    | ChainSide. Read-only, 0.                                       |
| 22:18 | DevNum: device number. Read-only, 00h.                         |
| 17    | <b>DblEnded: double ended.</b> Read-only, 0.                   |
| 16    | WarmReset. Read-only, 1.                                       |

| 15:8 | CapPtr: capabilities pointer. Read-only. Specifies the offset of the next link capabilities block based |
|------|---------------------------------------------------------------------------------------------------------|
|      | on the links that are supported by the node. Depending on which links are supported, this may be A0h,   |
|      | C0h, E0h, or 00h (in the case of the last link).                                                        |
| 7:0  | CapID: capabilities ID. Read-only. Reset: 08h. Indicates HyperTransport™ technology capability.         |

# F0x[E4, C4, A4, 84] Link Control Registers

F[4, 0]x[98:80] are associated with link 0. F[4, 0]x[B8:A0] are associated with link 1. F[4, 0]x[D8:C0] are associated with link 2. F[4, 0]x[F8:E0] are associated with link 3. The function 0 registers are associated with the whole link if it is ganged or sublink 0 if it is unganged; the function 4 register are associated with sublink 1 if the link is unganged. If the node does not support a link, then the corresponding register addresses become reserved. This register is derived from the link control register defined in the  $HyperTransport^{TM}$  I/O Link Specification

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 30:28 | WidthOut: link width out. Read-write. Cold reset: (see text below). Specifies the operating width of the outgoing link. Legal values are:    Bits   Link width   Bits   Link width     001b   16 bits   111b   not connected     000b   8 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|       | ware, the link width does not change until either a warm reset or a link disconnect sequence occurs through LDTSTOP_L.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 27    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 26:24 | <b>WidthIn:</b> link width in. Read-write. Cold reset: (see text below). Specifies the operating width of the incoming link. See F0x[E4, C4, A4, 84][WidthOut] for legal values. The cold reset value of this field depends on the widths of the links of the connecting device, per the link specification. This field cannot be set to 16 bits when reganging a link until F0x[18C:170][Ganged] has been set to 1. This field cannot be changed by software if the link was determined to be disconnected by hardware at cold reset. Note: After this field is written to by software, the link width does not change until either a warm reset or a link disconnect sequence occurs through LDTSTOP_L. |  |  |
| 23    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 22:20 | <b>MaxWidthOut: max link width out.</b> Read-only. This specifies the width of the outgoing link to be 8 bits or 16 bits wide, depending on the processor version. See F0x[E4, C4, A4, 84][WidthOut] for the encoding. Note: this indicates an 8-bit link if the link is unganged.                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 19    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 18:16 | <b>MaxWidthIn:</b> max link width in. Read-only. This specifies the width of the incoming link to be 8 bits or 16 bits wide, depending on the processor version. See F0x[E4, C4, A4, 84][WidthOut] for the encoding. Note: this indicates an 8-bit link if the link is unganged.                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |

| 15    | Addr64BitEn: 64-bit address packet enable. Read-write. Cold reset: 0. 1=Requests to addresses greater than FF_FFFF_FFFFh are supported by this IO link. 0=Requests to addresses greater than FF_FFFF_FFFFh are master aborted as if the end of chain was reached. BIOS is required to ensure that the link-specification-defined "64 Bit Address Feature" bit in the device on the other side of the link is set prior to setting this bit. For coherent links, this bit is unused. Note: F0x68[CHtExtAddrEn] is required to be set if this bit is set for any IO link. Note: the link specification indicates that this bit is cleared by a <i>warm</i> reset; therefore this bit may be in a different state than an IO device on the other side of the link after a warm reset; care should be taken by BIOS to place devices on both sides of the link in the same state after a warm reset, before any packets to the high-order addresses enabled by this bit are generated. |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14    | <b>ExtCTL:</b> extended control time during initialization. Read-write. Cold reset: 0. This specifies the time in which the link CTL signal is held asserted during the initialization sequence that follows an LDTSTOP_L deassertion, after CTL is detected asserted. 0=At least 16 bit times. 1=About 50 microseconds. This bit is ignored at Gen3 frequencies.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13    | LdtStopTriEn: LDTSTOP tristate enable. Read-write. Cold reset: 0. 1=During the LDTSTOP_L disconnect sequence, the link transmitter signals are placed into the high-impedance state and the receivers are prepared for the high-impedance mode. For the receivers, this includes cutting power to the receiver differential amplifiers and ensuring that there are no resultant high-current paths in the circuits. 0=During the LDTSTOP_L disconnect sequence, the link transmitter signals are driven, but in an undefined state, and the link receiver signals are assumed to be undriven.                                                                                                                                                                                                                                                                                                                                                                                      |
| 12    | <b>IsocEn: isochronous flow-control mode enable.</b> Read-write. Cold reset: 0. This bit is set to place the link into isochronous flow-control mode (IFCM), as defined by the link specification. However, the flow-control mode does not change until a warm reset occurs. 1=IFCM. 0=Normal flow-control mode. Note: all coherent links of the system must use the same flow-control mode. See section 2.6.4.2.4 [F0x[5C:40]Display Refresh And IFCM] on page 54.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11:10 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 9:8   | CrcErr: CRC Error. Read; set-by-hardware; write-1-to-clear. Cold reset: 00b. Bit[1] applies to the upper byte of the link and bit[0] applies to the lower byte. 1=The hardware detected a CRC error on the incoming link while not in retry mode; if in retry mode, then bit[8] may be set to indicate an uncorrectable error was detected; such uncorrectable error cases are:  • Link reconnect fails exceeding the limit in [The Link Global Retry Control Register]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| _     | F0x150[TotalRetryAttempts].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7:6   | F0x150[TotalRetryAttempts].  Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7:6   | Reserved.  InitComplete: initialization complete. Read-only; set-by-hardware. Reset: 0. This bit is set by hardware when low-level link initialization has successfully completed. If there is no device on the other end of the link, or if the device on the other side of the link is unable to properly perform link initialization, then the bit is not set. This bit is not cleared for LDTSTOP# disconnects or retries. Hardware may report 0 during BIST mode or ILM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       | Reserved.  InitComplete: initialization complete. Read-only; set-by-hardware. Reset: 0. This bit is set by hardware when low-level link initialization has successfully completed. If there is no device on the other end of the link, or if the device on the other side of the link is unable to properly perform link initialization, then the bit is not set. This bit is not cleared for LDTSTOP# disconnects or retries.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5     | Reserved.  InitComplete: initialization complete. Read-only; set-by-hardware. Reset: 0. This bit is set by hardware when low-level link initialization has successfully completed. If there is no device on the other end of the link, or if the device on the other side of the link is unable to properly perform link initialization, then the bit is not set. This bit is not cleared for LDTSTOP# disconnects or retries. Hardware may report 0 during BIST mode or ILM.  LinkFail: link failure. Read; set-by-hardware; write-1-to-clear. Cold reset: 0. This bit is set high by the hardware when a CRC error is detected on the link (if enabled by CrcFloodEn), the link fails to                                                                                                                                                                                                                                                                                         |

| 1 | CrcFloodEn: CRC flood enable. Read-write. Reset: 0. 1=Setting either of the CrcErr bits results in        |
|---|-----------------------------------------------------------------------------------------------------------|
|   | sync packets to all enabled outgoing links and the F0x[E4, C4, A4, 84][LinkFail] bit is set. 0=Setting    |
|   | either of the CrcErr bits do not result in sync packets or setting the F0x[E4, C4, A4, 84][LinkFail] bit. |
|   | In Gen3 protocol, exceeding the F0x150[TotalRetryAttempts] limit results in a sync flood regardless       |
|   | of how CrcFloodEn is set. The resulting sync flood does not propagate to other links or set Linkfail      |
|   | unless CrcFloodEn is set.                                                                                 |
|   | This bit is ignored if F3x44[SyncPktGenDis] is set.                                                       |
| 0 | Reserved.                                                                                                 |

## F0x[E8, C8, A8, 88] Link Frequency/Revision Registers

F[4, 0]x[98:80] are associated with link 0. F[4, 0]x[B8:A0] are associated with link 1. F[4, 0]x[D8:C0] are associated with link 2. F[4, 0]x[F8:E0] are associated with link 3. The function 0 registers are associated with the whole link if it is ganged or sublink 0 if it is unganged; the function 4 register are associated with sublink 1 if the link is unganged. If the node does not support a link, then the corresponding register addresses become reserved. This register is derived from the link frequency/revision register defined in the  $HyperTransport^{TM}I/OLink Specification$ 

| Bits  | Description                                                                                                                                                                                                |                      |                                                   |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|---------------------------------------------------|--|--|
| 31:16 | <b>LnkFreqCap: link frequency capability.</b> Read-only. Reset: values vary with product. These bits indicate which link frequencies the processor supports. The bits are encoded as: 1=The link frequency |                      |                                                   |  |  |
|       | is supported; 0=The link frequency as follows:                                                                                                                                                             | y is not supported.  | The bits correspond to different link frequencies |  |  |
|       | Bit 0: 200 MHz (this bit is 1 in                                                                                                                                                                           | _                    | Bit 8: 1400 MHz.                                  |  |  |
|       | Bit 1: 300 MHz (this bit is 0 in                                                                                                                                                                           | all products).       | Bit 9: 1600 MHz.                                  |  |  |
|       | Bit 2: 400 MHz.                                                                                                                                                                                            |                      | Bit 10: 1800 MHz.                                 |  |  |
|       | Bit 3: 500 MHz (this bit is 0 in                                                                                                                                                                           | all products).       | Bit 11: 2000 MHz.                                 |  |  |
|       | Bit 4: 600 MHz.                                                                                                                                                                                            |                      | Bit 12: 2200 MHz.                                 |  |  |
|       | Bit 5: 800 MHz.                                                                                                                                                                                            |                      | Bit 13: 2400 MHz.                                 |  |  |
|       | Bit 6: 1000 MHz.                                                                                                                                                                                           |                      | Bit 14: 2600 MHz.                                 |  |  |
|       | Bit 7: 1200 MHz.                                                                                                                                                                                           | Bit 15: reserved.    |                                                   |  |  |
|       | This field indicates logical support for these frequencies; however, electrical support for these frequencies may vary based on the part number and other system considerations.                           |                      |                                                   |  |  |
| 15:12 | Reserved.                                                                                                                                                                                                  |                      |                                                   |  |  |
| 11:8  | Freq: link frequency. Read-write                                                                                                                                                                           | . Cold reset: 0h for | DC-coupled links and 7h for AC-coupled links.     |  |  |
|       | This specifies the link frequency. I                                                                                                                                                                       | •                    |                                                   |  |  |
|       |                                                                                                                                                                                                            | 8h: 1400 MHz.        |                                                   |  |  |
|       |                                                                                                                                                                                                            | 9h: 1600 MHz.        |                                                   |  |  |
|       |                                                                                                                                                                                                            | Ah: 1800 MHz.        |                                                   |  |  |
|       |                                                                                                                                                                                                            | Bh: 2000 MHz.        |                                                   |  |  |
|       |                                                                                                                                                                                                            | Ch: 2200 MHz.        |                                                   |  |  |
|       | 5h: 800 MHz. Dh: 2400 MHz.                                                                                                                                                                                 |                      |                                                   |  |  |
|       |                                                                                                                                                                                                            | Eh: 2600 MHz.        |                                                   |  |  |
|       | ,,,                                                                                                                                                                                                        | Fh: reserved.        |                                                   |  |  |
|       | After this field is updated, the link frequency does not change until either a warm reset or a link                                                                                                        |                      |                                                   |  |  |
|       | disconnect sequence occurs through LDTSTOP_L. The value read from this field is the last value                                                                                                             |                      |                                                   |  |  |
|       | written. Writes to this field are ign                                                                                                                                                                      | ored if a non-suppo  | orted frequency is written.                       |  |  |
| 7:0   | <b>Revision.</b> Read-only, 60h. Indicate specification.                                                                                                                                                   | es that the processo | r is designed to version 3.00 of the link         |  |  |

### F0x[EC, CC, AC, 8C] Link Feature Capability Registers

F[4, 0]x[98:80] are associated with link 0. F[4, 0]x[B8:A0] are associated with link 1. F[4, 0]x[D8:C0] are associated with link 2. F[4, 0]x[F8:E0] are associated with link 3. The function 0 registers are associated with the whole link if it is ganged or sublink 0 if it is unganged; the function 4 register are associated with sublink 1 if the link is unganged. If the node does not support a link, then the corresponding register addresses become reserved. This register is derived from the link feature capability register defined in the  $HyperTransport^{TM}I/OLINK Specification$ . Unless otherwise specified: 0=The feature is not supported; 1=The feature is supported.

| Bits  | Description                                                                                                                                                                                                                                              |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved.                                                                                                                                                                                                                                                |
| 9     | UpstrCfgCap: upstream configuration capable. Read-only, 0.                                                                                                                                                                                               |
| 8     | ExtRegSet: extended register set. Read-only, 0.                                                                                                                                                                                                          |
| 7:6   | Reserved.                                                                                                                                                                                                                                                |
| 5     | <b>UnitIdReOrderDis: UnitID reorder disable</b> . Read-write. Reset: 0. 1=Upstream reordering for different UnitIDs is not supported; i.e., all upstream packets are ordered as if they have the same UnitID. 0=Reordering based on UnitID is supported. |
| 4     | 64BitAddr: 64-bit link addressing. Read-only, 1.                                                                                                                                                                                                         |
| 3     | ExtCTLRqd: extended CTL required. Read-only, 0.                                                                                                                                                                                                          |
| 2     | CrcTstMode: CRC test mode. Read-only, 0.                                                                                                                                                                                                                 |
| 1     | LdtStopMode: LDTSTOP supported. Read-only, 1.                                                                                                                                                                                                            |
| 0     | IsocMode: isochronous flow control mode. Read-only, 1.                                                                                                                                                                                                   |

#### F0x[F0, D0, B0, 90] Link Base Channel Buffer Count Registers

F[4, 0]x[98:80] are associated with link 0. F[4, 0]x[B8:A0] are associated with link 1. F[4, 0]x[D8:C0] are associated with link 2. F[4, 0]x[F8:E0] are associated with link 3. The function 0 registers are associated with the whole link if it is ganged or sublink 0 if it is unganged; the function 4 register are associated with sublink 1 if the link is unganged. If the node does not support a link, then the corresponding register addresses become reserved. If a link does not initialize properly or is not connected, then the reset state of the buffer count fields is X.

F0x[F0, D0, B0, 90] and F0x[F4, D4, B4, 94] specify the *hard-allocated* link flow-control buffer counts in each virtual channel available to the transmitter at the other end of the link; it also provides the *free buffers* that may be used by any of the virtual channels, as needed, or reallocated by BIOS to the hard-allocated buffer counts. When the link initializes, the default number of buffers hard-allocated to each virtual channel in F0x[F0, D0, B0, 90] differs based on the whether the link initializes to IO or coherent protocol, ganged or unganged, as follows (if LockBc is low):

|                  | <b>FreeData</b> | <b>FreeCmd</b> | <b>RspData</b> | <b>NpReqData</b> | <b>ProbeCmd</b> | <b>RspCmd</b> | <u>PReq</u> | NpReqCmd |
|------------------|-----------------|----------------|----------------|------------------|-----------------|---------------|-------------|----------|
| IO link ganged:  | 4               | 16             | 2              | 2                | 0               | 4             | 8           | 36       |
| Coh link ganged: | 4               | 16             | 4              | 4                | 18              | 18            | 4           | 8        |
| IO link unganged | : 4             | 16             | 1              | 1                | 0               | 2             | 4           | 18       |
| Coh link ungange | d: 4            | 16             | 2              | 2                | 9               | 9             | 2           | 4        |

The cold-reset register state (ganged or unganged) is: IO link=0485\_0292h; coherent link=048A\_9944h.

For all fields except for FreeData and FreeCmd, if the link is ganged, then the number of buffers allocated is 2

times the value of the field. If the link is unganged, then the number of buffers allocated is the value of the field.

For the FreeData and FreeCmd fields, the number of buffers allocated is 2 times the value of the field, whether the link is ganged or unganged. If the link is unganged, then the FreeData and FreeCmd counts are provided in the corresponding register of function 0; these fields in the corresponding register of function 4 are reserved; these pools of buffers are applied to both sublinks as needed.

The hard-allocated buffer counts are transmitted to the device at the other end of the link in buffer release messages after link initialization. The remaining buffers are held in the free list (specified by FreeData and FreeCmd) used to optimize buffer usage. When a transaction is received, if a free-list buffer is available, it is used for storage instead of one of the hard allocated buffers; as a result, a buffer release (for one of the hard allocated buffers used by the incoming request) can be immediately sent back to the device at the other end of the link without waiting for the transaction to be routed beyond the flow-control buffers.

After boot, the allocation may be changed by BIOS. Rules governing these registers are as follows:

- Base channel buffers are specified in F0x[F0, D0, B0, 90]; isochronous buffer counts (if in IFCM) are specified in F0x[F4, D4, B4, 94].
  - New values written to these registers take effect after a warm reset (even if LockBc is set).
- The total number of command buffers allocated in the base and isochronous registers of a link cannot exceed 64.
- The total number of data buffers allocated in the base and isochronous registers of a link cannot exceed 16.
- The total number of hard allocated command buffers (ProbeCmd, RspCmd, PReq, and NpReqCmd) cannot exceed 48.
- If unganged, the total buffer counts of a link are shared between the two sublinks.
- If unganged, the free command and free data buffer pools are shared between the two sublinks of a link and are specified by F0x[F0, D0, B0, 90].
- The isochronous buffer counts (F0x[F4, D4, B4, 94]) default to zero. BIOS must set up non-zero counts (and adjust the base channel counts accordingly) prior to enabling IFCM.
- If the system is a UMA system and F0x84[IsocEn]=1, the following link buffer allocations should be used:

 $\begin{array}{ll} PReq = 3 & NpReqCmd = 11 & F0x94[IsocRspData] = 0 \\ F0x94[IsocNpReqData] = 0 & F0x94[IsocRspCmd] = 0 & F0x94[IsocPReq] = 1 \end{array}$ 

F0x94[IsocNpReqCmd] = 7

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | <b>LockBc:</b> lock buffer count register. Read-write. Cold reset: 0. 1=The buffer count registers, F0x[F0, D0, B0, 90] and F0x[F4, D4, B4, 94] are locked such that warm resets do not place the registers back to their default value. Setting this bit does not prevent the buffer counts from being updated after a warm reset based on the value of the buffer counts before the warm reset. |
| 30:28 | Reserved                                                                                                                                                                                                                                                                                                                                                                                          |
| 27:25 | FreeData: free data buffer count. Read-write.                                                                                                                                                                                                                                                                                                                                                     |
| 24:20 | FreeCmd: free command buffer count. Read-write.                                                                                                                                                                                                                                                                                                                                                   |
| 19:18 | RspData: response data buffer count. Read-write.                                                                                                                                                                                                                                                                                                                                                  |
| 17:16 | NpReqData: non-posted request data buffer count. Read-write.                                                                                                                                                                                                                                                                                                                                      |
| 15:12 | ProbeCmd: probe command buffer count. Read-write.                                                                                                                                                                                                                                                                                                                                                 |
| 11:8  | RspCmd: response command buffer count. Read-write.                                                                                                                                                                                                                                                                                                                                                |

| 7:5 | PReq: posted request command and data buffer count. Read-write. This specifies the number of |
|-----|----------------------------------------------------------------------------------------------|
|     | posted command and posted data buffers allocated.                                            |
| 4:0 | NpReqCmd: non-posted request command buffer count. Read-write.                               |

### F0x[F4, D4, B4, 94] Link Isochronous Channel Buffer Count Registers

Reset: 0000 0000h. F[4, 0]x[98:80] are associated with link 0. F[4, 0]x[B8:A0] are associated with link 1. F[4, 0]x[D8:C0] are associated with link 2. F[4, 0]x[F8:E0] are associated with link 3. The function 0 registers are associated with the whole link if it is ganged or sublink 0 if it is unganged; the function 4 register are associated with sublink 1 if the link is unganged. If the node does not support a link, then the corresponding register addresses become reserved. If a link does not initialize properly or is not connected, then the reset state of the buffer count fields is X. See F0x[F0, D0, B0, 90] for information about the buffer count fields.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                           |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved.                                                                                                                                                                                                                                                                                                                                                                             |
| 28:27 | IsocRspData: isochronous response data buffer count. Read-write.                                                                                                                                                                                                                                                                                                                      |
| 26:25 | IsocNpReqData: isochronous non-posted request data buffer count. Read-write.                                                                                                                                                                                                                                                                                                          |
| 24:22 | IsocRspCmd: isochronous response command buffer count. Read-write.                                                                                                                                                                                                                                                                                                                    |
| 21:19 | <b>IsocPReq: isochronous posted request command and data buffer count</b> . Read-write. This specifies the number of isochronous posted command and posted data buffers allocated.                                                                                                                                                                                                    |
| 18:16 | IsocNpReqCmd: isochronous non-posted request command buffer count. Read-write.                                                                                                                                                                                                                                                                                                        |
| 15:8  | <b>SecBusNum: secondary bus number.</b> Read-write. This specifies the configuration-space bus number of the IO link. When configured as a coherent link, this register has no meaning. This field should match the corresponding [The Configuration Map Registers] F1x[EC:E0][BusNumBase] field of the node (unless F1x[EC:E0][DevCmpEn]=1, in which case this field should be 00h). |
| 7:0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                             |

## F0x[F8, D8, B8, 98] Link Type Registers

Reset: 0000 00??h. F[4, 0]x[98:80] are associated with link 0. F[4, 0]x[B8:A0] are associated with link 1. F[4, 0]x[D8:C0] are associated with link 2. F[4, 0]x[F8:E0] are associated with link 3. The function 0 registers are associated with the whole link if it is ganged or sublink 0 if it is unganged; the function 4 register are associated with sublink 1 if the link is unganged. If the node does not support a link, then the corresponding register addresses become reserved.

| Bits | Description                                                                                                                                                                                                                                     |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | Reserved.                                                                                                                                                                                                                                       |
| 4    | <b>LinkConPend: link connect pending.</b> Read-only. 1=Hardware is currently determining if the link is connected to another device. 0=The link connection has been determined. This bit qualifies the Link-Con bit.                            |
| 3    | Reserved.                                                                                                                                                                                                                                       |
| 2    | NC: non coherent. Read-only. This bit specifies the link type. 0=coherent link. 1=IO link.                                                                                                                                                      |
| 1    | <b>InitComplete:</b> initialization complete. Read-only. 1=Link initialization is complete. This is a duplicate of [The Link Control Registers] F0x[E4, C4, A4, 84][InitComplete]. The NC bit is invalid until link initialization is complete. |
| 0    | <b>LinkCon:</b> link connected. Read-only. 1=The link is connected to another device. 0=The link is not connected. This is not valid until LinkConPend=0.                                                                                       |

### F0x[11C, 118, 114, 110] Link Clumping Enable Registers

Reset: 0000 0000h. F0x[120, 110] is associated with link 0; F0x[124, 114] is associated with link 1; F0x[128, 118] is associated with link 2. F0x[12C, 11C] is associated with link 3. F0x[11C, 118, 114, 110] are associated with the whole link if it is ganged or sublink 0 if it is unganged; F0x[12C, 128, 124, 120] are associated with sublink 1 if the link is unganged. If the node does not support a link, then the corresponding register addresses become reserved.

These registers specify how UnitIDs of upstream non-posted requests may be clumped per the link specification. The processor does not clump requests that it generates in the downstream direction.

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | ClumpEn. Read-write. Each bit of this register corresponds to a link UnitID number. E.g., bit 2 corresponds to UnitID 02h, etc. 1=The specified UnitID is ordered in the same group as the specified UnitID - 1. For example if this register is programmed to 0000_00C0h, then UnitIDs 7h, 6h, and 5h are all ordered as if they are part of the same UnitID. This is used to allow more than 32 tags to be assigned to a single stream for the purposes of ordering. |
| 1:0  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

### F0x[12C, 128, 124, 120] Sublink 1 Clumping Enable Registers

Reset: 0000 0000h. See F0x[11C, 118, 114, 110]. If a link is ganged or not supported, then the corresponding register in this group is reserved.

### F0x[14C:130] Link Retry Registers

| The following retry registers associated with the following links are specified here: |                   |         |                   |  |
|---------------------------------------------------------------------------------------|-------------------|---------|-------------------|--|
| F0x130:                                                                               | link 0, sublink 0 | F0x140: | link 0, sublink 1 |  |
| F0x134:                                                                               | link 1, sublink 0 | F0x144: | link 1, sublink 1 |  |
| F0x138:                                                                               | link 2, sublink 0 | F0x148: | link 2, sublink 1 |  |
| F0x13C:                                                                               | link 3, sublink 0 | F0x14C: | link 3, sublink 1 |  |

If a link is ganged, then the sublink 0 retry register specifies the whole link retry register function and the sublink 1 retry register is reserved. If a link is not supported by the node, then both the sublink 0 and sublink 1 retry registers are reserved. These registers are reserved if F3xE8[LnkRtryCap]=0.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | <b>RetryCount</b> . Read-write. Cold reset: 0. This is a 16-bit counter that is incremented by hardware. The counter is incremented in two ways, (1) the counter increments once for each failed training attempt and (2) the counter increments once for each packet error that causes a retry attempt. If the counter value is FFFFh it increments to 0000h and the RetryCountRollover bit is set. RetryCount is not incremented for retries initiated by other devices, only for errors detected by the node. |
| 15:13 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12    | <b>DataCorruptOut:</b> sent corrupted data. Read; write-1-to-clear. Cold reset: 0. 1=Data sent on the link was marked with Data Error to indicate that it is known to be corrupted.                                                                                                                                                                                                                                                                                                                              |
| 11    | InitFail. Read; write-1-to-clear. Cold reset: 0. 1=Initialization sequence failed on a link reconnect.                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10    | StompedPktDet: stomped packet detected by receiver. Read; write-1-to-clear. Cold reset: 0.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9     | RetryCountRollover. Read; write-1-to-clear. Cold reset: 0. See RetryCount.                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| 8   | <b>RetryErrorDet: retry error detected</b> . Read; write-1-to-clear. Cold reset: 0. 1=A retry was initiated in one of the ways listed in RetryCount.                                                                                                                                                                                                                                                                                                                                                              |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6 | <b>ShortRetryAttempts</b> . Read-write. Reset: 11b. This specifies the number of short retry attempts when operating at a Gen3 link frequency; after exceeding this value, long retries are attempted until the max count specified by [The Link Global Retry Control Register] F0x150[TotalRetryAttempts] is exceeded. The retry attempt counter is not incremented for retries initiated by other devices, only for errors detected by the node. This field is ignored when operating at Gen1 link frequencies. |
| 5:4 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3   | <b>DisRetryDataError: disable link retry on data packet error</b> . Read-write. Reset: 0. 1=The node does not initiate the retry sequence if an error is detected on a data packet; Data packets are acknowledged even if there is a CRC error. This is intended to support debug modes in which errors are detected but allowed to propagate through the crossbar in order to allow logging of error data patterns in trace mode.                                                                                |
| 2   | <b>DisRetryAnyError: disable link retry on any packet error</b> . Read-write. Reset: 0. 1=The node does not initiate the retry sequence if an error is detected; Packets are acknowledged even if there is a CRC error. This is intended to support debug modes in which errors are detected but allowed to propagate through the crossbar in order to allow logging of error data patterns in trace mode.                                                                                                        |
| 1   | <b>ForceRetryError</b> . Read-write; cleared-by-hardware once the error has been injected onto the link. Reset: 0. This bit may be used by diagnostic software to test the error detection and retry logic of the link. 1=Forces a CRC error in one packet from the transmitter. See also [The Link Global Retry Control Register] F0x150[MultRetryErr].                                                                                                                                                          |
| 0   | <b>RetryModeEnable</b> . Read-write; changes take effect on next warm reset. Cold reset: 0 for DC-coupled links and 1 for AC-coupled links. 1=Place the link in error retry mode when reconnecting after the next warm reset.                                                                                                                                                                                                                                                                                     |

# F0x150 Link Global Retry Control Register

Cold reset: 0007 0000h if F3xE8[LnkRtryCap]=1, 0000 0000h if F3xE8[LnkRtryCap]=0. All fields of this register are expected to be programmed the same in all nodes of the system (except ForceErrType and MultRetryErr).

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 18:16 | <b>TotalRetryAttempts</b> . Read-write. Specifies the total number of retry attempts (short and long) allowed on any link before the link is considered to have failed. When operating at Gen3 link frequencies, short retry attempts are limited by [The Link Retry Registers] F0x[14C:130][ShortRetryAttempts]; the remaining are long retry attempts. The link is determined to have failed after TotalRetryAttempts + 1 errors; e.g., if TotalRetryAttempts=7, then the link is determined to have failed as a result of the 8 errors. This register should be programmed to values of 1 or greater. The retry attempt counter for a link is incremented each time F0x[14C:130][RetryCount] for that link is incremented. |
| 15:14 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13    | <b>HtRetryCrcDatInsDynEn: link retry CRC data insertion enable</b> . Read-write. 1=Enables dynamic mode for CRC insertion in data packets on a coherent link. In this mode, the transmitter follows the insertion policy defined by HtRetryCrcDatIns[2:0] for a link which is close to idle; however, it inserts fewer CRC cells as the link becomes busy.                                                                                                                                                                                                                                                                                                                                                                    |

| 12   | HtRetryCrcCmdPackDynEn: link retry CRC command packet dynamic mode enable. Read-                                                                                                                      |  |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|      | write. 1=Enables dynamic mode for CRC command packing on a coherent link. In this mode,                                                                                                               |  |  |
|      | command packing is suspended when a link not busy.                                                                                                                                                    |  |  |
| 11:9 | HtRetryCrcDatIns: link retry CRC data insertion. Read-write. Specifies insertion of additional                                                                                                        |  |  |
|      | CRC cells in a data packet over coherent link. For a data packet defined as a data command header followed by at most 4 data beats (beat 0 through beat 3) of 16 bytes each with a data packet CRC at |  |  |
|      | the end, this bit is defined as follows:                                                                                                                                                              |  |  |
|      | 000b no additional CRC insertion                                                                                                                                                                      |  |  |
|      | 001b CRC insertion after data beat 0                                                                                                                                                                  |  |  |
|      | 010b CRC insertion after cmd header and after data beat 0                                                                                                                                             |  |  |
|      | 011b CRC insertion after cmd header, data beat 0 and data beat 1                                                                                                                                      |  |  |
|      | 100b CRC insertion after cmd header, data beat 0, data beat 1 and data beat 2                                                                                                                         |  |  |
|      | 101b - 111b reserved                                                                                                                                                                                  |  |  |
| 8    | HtRetryCrcCmdPack: link retry CRC command packing. Read-write. 1=Enables command                                                                                                                      |  |  |
|      | packing on coherent links with retry enabled. Command packing allows a coherent link transmitter to                                                                                                   |  |  |
|      | pack multiple commands together with a single CRC.                                                                                                                                                    |  |  |
| 7    | Reserved.                                                                                                                                                                                             |  |  |
| 6:5  | ForceErrType: force error type. Read-write. Specifies the error type generated by                                                                                                                     |  |  |
|      | F0x[14C:130][ForceRetryError], F0x[E4, C4, A4, 84][CrcForceErr], and F3x44[GenCrcErrByte1,                                                                                                            |  |  |
|      | GenCrcErrByte0].                                                                                                                                                                                      |  |  |
|      | 00b Forces per-packet CRC error in any packet type (NOP, command, or data).                                                                                                                           |  |  |
|      | 01b Forces per-packet CRC error on a command packet only (not including NOP).                                                                                                                         |  |  |
|      | 10b Forces per-packet CRC error on a data packet only. If HtRetryCrcDatIns=1, then the error is forced into the first CRC of the packet.                                                              |  |  |
|      | 11b Forces per-packet CRC error on a data packet only. If HtRetryCrcDatIns=1, then the error is                                                                                                       |  |  |
|      | forced into the last CRC of the packet.                                                                                                                                                               |  |  |
| 4    | MultRetryErr: multiple retry force error. Read-write. 1=Inhibits hardware clearing of [The Link                                                                                                       |  |  |
|      | Retry Registers] F0x[14C:130][ForceRetryError], thereby causing multiple link retry errors (at a very                                                                                                 |  |  |
|      | high rate). This can be used to test software associated with reporting of multiple link reconnect fail-                                                                                              |  |  |
|      | ures.                                                                                                                                                                                                 |  |  |
| 3:0  | Reserved.                                                                                                                                                                                             |  |  |

# F0x164 Coherent Link Traffic Distribution Register

Reset: 0000 0000h. See 2.6.4.2.3 [Link Traffic Distribution] on page 53 for details about link traffic distribution.

| Bits  | Description                                 |                                                                                                                                                                                                                                                                                                              |  |
|-------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:24 | Reserved.                                   |                                                                                                                                                                                                                                                                                                              |  |
| 23:16 | fic is distributed. Note that packets which | link. Read-write. Specifies the pool of links over which traf- h are not eligible for distribution (for example sized reads and e routing tables. If the link is ganged, then only the sublink 0 ed. bit 4 - link 0, sublink 1 bit 5 - link 1, sublink 1 bit 6 - link 2, sublink 1 bit 7 - link 3, sublink 1 |  |
| 15:11 | Reserved.                                   |                                                                                                                                                                                                                                                                                                              |  |

| 10:8 | <b>DstNode[2:0]: coherent link distribution destination node</b> . Read-write. For cHTReqDistEn and cHTRspDistEn, DstNode[2:0] specifies the destination node for which coherent link traffic should be distributed. For cHTPrbDistEn, all probes originating from the local node are distributed irrespective of the value of DstNode[2:0]. Packets specified by cHTReqDistEn, cHTRspDistEn, and cHTPrbDistEn that are destined for DstNode are distributed between links specified by DstLnk in approximately a round-robin fashion. |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2    | <b>cHTPrbDistEn:</b> coherent link probe distribution enable. Read-write. Enables coherent link traffic distribution for the probe virtual channel. The probes affected by this bit are limited to those sourced from the local node (as opposed to being forwarded from another node).                                                                                                                                                                                                                                                |
| 1    | <b>cHTRspDistEn: coherent link response distribution enable</b> . Read-write. 1=Enables coherent link traffic distribution for the response virtual channel. The responses affected by this bit are limited to responses to the request types listed for cHTReqDistEn and which are sourced from the local node (as opposed to being forwarded from another node).                                                                                                                                                                     |
| 0    | <b>cHTReqDistEn: coherent link request distribution enable</b> . Read-write. 1=Enable coherent link traffic distribution for the request virtual channel. The requests affected by this bit are limited to cache block transactions which are sourced from the local node (as opposed to being forwarded from another node).                                                                                                                                                                                                           |

## F0x168 Extended Link Transaction Control Register

Reset: 0000 0000h.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 31:11 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 10    | <b>DisNcHtCmdThrottle: disable IO link command throttling</b> . Read-write. 0=The node limits generation of the first DWORD of link-defined commands to no more than one every four DWORDs of link bandwidth. If, for example, a 2-DWORD command is transmitted by the node, and there is no data that follows, then the node sends at least 2 DWORDs of NOPs (possibly including buffer release credits) before generating the next command packet. This bit applies to both Gen1 and Gen3 frequencies and protocols. This bit does not affect coherent links. Some IO devices may require this bit to be clear. 1=The node does not limit the rate at which commands are generated on IO links. |  |  |
| 9:8   | ExtMmioMapAddSel: extended MMIO map address select. Read-write. These bits specify the address bits used in [The Extended MMIO Address Base Registers] F1x114_x2, and therefore the granularity of the map registers. It is encoded as:  00b = 0.5 Mbyte granularity.  10b = 128 Mbyte granularity.  11b = Reserved.  See F1x114_x2 for details.                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 7:2   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 1     | Cpu3En: CPU core 3 enable. Read-write. See F0x68[Cpu1En].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 0     | Cpu2En: CPU core 2 enable. Read-write. See F0x68[Cpu1En].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |

# F0x16C Link Global Extended Control Register

Further information about these bits can be found in the Gen3 link specification. BIOS should program this register to the same value in all nodes of a multi-node system.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:17 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 16    | ImmUpdate: immediate update. Cold reset: 0. Read-write. Many of the link phy registers, accessed through F4x1[98, 90, 88, 80], control electrical parameters that are unsafe to change while the link is operational; so the updates to these registers are normally withheld until the link is disconnected. However, under some (testing and characterization) circumstances, it is preferable to allow these changes to occur immediately, while the link is operational. ImmUpdate provides this option.  0=Writes to most of the link phy registers do not take effect in the link phy until the next LDTSTOP or warm reset disconnect. Reads from a link phy register after a write return the current value not the value pending until the link disconnects and reconnects. 1=Writes to the link phy registers are passed to the phy immediately. Reads always returns the value from the most recent write.                                             |  |  |
| 15:13 | ForceFullT0: force full T0 training time. Read-write. Cold reset: 000b. This specifies the period of time that the link can be disconnected for an LDTSTOP before the full T0 training period is invoked. The time is measured approximately from the assertion of LDTSTOP_L until training 0 is about to start after LDTSTOP deassertion. If less than the specified time has expired, then training 0 specified by T0Time is used. The bits are encoded as follows:  000b = Always use T0Time.  100b = 3.2 milliseconds.  101b = 6.4 milliseconds.  110b = 12.8 milliseconds.  111b = 25.6 milliseconds.                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 12:10 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 9     | <b>RXCalEn: receiver calibration enable</b> . Read-write. Cold reset: 0. 1=Enable receiver offset calibration during all training 1 periods. BIOS should leave this bit in the cold reset state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 8     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 7:6   | InLnSt: inactive lane state. Read-write. Cold reset: 00b. Specifies the state of inactive lanes of ganged links at Gen3 frequencies as follows:  00b= Same as warm reset except CAD is logical 0.  01b= Same as PHY OFF.  10b= Same as operational; CTL and CAD transmit undefined scrambled data. This encoding is only supported with 8- or 16-bit links.  11b= Same as disconnected per LS2En.  Updates to this bit take effect on warm reset and LDTSTOP.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 5:0   | T0Time: training 0 time. Read-write. Cold reset: 3Ah. Specifies the amount of time to spend in training 0 when exiting the disconnected state. See also ForceFullT0, F4x1[9C, 94, 8C, 84]_x[530A, 520A][Ls2ExitTime], and section 2.7.6 [Link LDTSTOP_L Disconnect-Reconnect] on page 58.  If T0Time[5:4]=00b, then the time = T0Time[3:0] * 0.1 usec (ranging from 0.0 to 1.5 usec).  If T0Time[5:4]=01b, then the time = T0Time[3:0] * 0.5 usec (ranging from 0.0 to 7.5 usec).  If T0Time[5:4]=10b, then the time = T0Time[3:0] * 2.0 usec (ranging from 0.0 to 30 usec).  If T0Time[5:4]=11b and T0Time[3:0] ranges from 0h to Ah,  then the time = T0Time[3:0] * 20 usec (ranging from 0.0 to 200 usec).  If T0Time[5:4]=11b and T0Time[3:0] ranges from Bh to Fh, these values are reserved.  BIOS should set T0Time according to the T0 training time requirement for the links' far-side receiver phase recovery time as determined by characterization. |  |  |

# F0x[18C:170] Link Extended Control Registers

These registers provide control for each link. They are mapped to the links as follows:

- F0x170=Link 0, sublink 0. F0x174=Link 1, sublink 0. F0x178=Link 2, sublink 0. F0x17C=Link 3, sublink 0.
- F0x180=Link 0, sublink 1. F0x184=Link 1, sublink 1. F0x188=Link 2, sublink 1. F0x18C=Link 3, sublink 1. Visibility of these sublink 1 registers is as specified through Ganged (bit 0) of the sublink 0 registers.

If a link is ganged, only the register for sublink 0 of that link is visible and it applies to the whole link. Further information about these bits can be found in the Gen3 link specification.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                           |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:14 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                           |  |
| 13:12 | LaneSel: lanes select. Read-write. Cold reset: 00b. This field only exists in the sublink 0 registers; the sublink 1 registers, these bits are reserved. For unganged links, they apply to both sublinks. The field specifies how receive (RX) lanes are translated into transmit (TX) lanes for links that are in IL. The translation varies with link width. Given the RX order specified below, the TX order varies we LaneSel as follows:  Bits 16-bit link RX={CTL1, CAD[15:8], CTL0, CAD[7:0]} RX={CTL0, CAD[7:0]}  00b Same as RX. Same as RX  01b TX={CAD[12:8], CTL0, CAD[7:0], CTL1, CAD[15:13]} TX={CAD[6:0], CTL0, CAD[7:0]}  10b TX={CTL0, CAD[7:0], CTL1, CAD[15:8]} TX={CAD[4:0], CTL0, CAD[7:0]}  11b TX={CAD[4:0], CTL1, CAD[15:8], CTL0, CAD[7:5]} TX={CAD[2:0], CTL0, CAD[7:0]} |                                                                                                                                                                           |  |
|       | Bits 4-bit link RX = {CTL0, CAD[3:0]}  00b Same as RX. 01b TX={CAD[3:0], CTL0} 10b TX={CAD[2:0], CTL0, CAD[3]} 11b TX={CAD[1:0], CTL0, CAD[3:2]} Note: 01b and 11b are not useful at Gen1 frequencies because the CTL lanes line up.  In BIST mode on 16-bit links, LaneSel[1] selects which sublink 0=sublink 0, 1=sublink 1; LaneSel[1:0] also causes the receive p translation for 8-bit or smaller links.                                                                                                                                                                                                                                                                                                                                                                                      | 2-bit link RX = {CTL0, CAD[1:0]} Same as RX. TX={CAD[1:0], CTL0} TX={CAD[0], CTL0, CAD[1]} Reserved the link cannot be trained unless the is received by the BIST engine. |  |
| 11    | <b>ILMEn: internal loopback mode (ILM) enable</b> . Read-write. C F4x1[9C, 94, 8C, 84]_x[DF, CF][XmtRdPtr and RcvRdPtr] must is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                           |  |
| 10    | <b>BistEn: built-in self test (BIST) enable</b> . Read-write. Cold rese enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | t: 0. 1=The link BIST engine is                                                                                                                                           |  |
| 9     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                           |  |
| 8     | <b>LS2En: LDTSTOP mode 2 enable</b> . Read-write. Cold reset: 0. 0 when the link is disconnected. 1=Use LS2 mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | =Use LS1 mode for power reduction                                                                                                                                         |  |
| 7:4   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                           |  |

| 3   | <b>ScrambleEn: scrambling enable</b> . Read-write. Revision B: Cold reset: 0b. 1=Scrambling enable. Updates to this bit take effect on warm reset and LDTSTOP. Software must clear this bit when transitioning from Gen3 to Gen1 protocol.                                                                                                                                                                                                                                                                                                                                                  |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:1 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0   | <b>Ganged</b> . Read-write; read-only 1 if the bit corresponding to the link in F3xE8[UnGangEn] is 0. 0=The link is unganged; this register is visible for both sublinks. 1=The link is ganged; only the sublink 0 register is visible. This value is initialized after a cold reset, based on the ganging state determined by hardware (see section 2.7.1.1 [Ganging And Unganging] on page 55). Writes to this bit take effect on the next warm reset; reads reflect the last value written (rather than the current state of the link). This bit only exists in the sublink 0 registers. |

### F0x1A0 Link Initialization Status Register

| Bits  | Descri                                                                                                                                                                                         | ption                                                                                                                                                                                                                      |     |                                |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------------------|
| 31    |                                                                                                                                                                                                | <b>InitStatusValid:</b> initialization status valid. Read-only. 1=Indicates that the rest of the information in this register is valid for all links; each link is either not connected or the initialization is complete. |     |                                |
| 30:16 | Reserv                                                                                                                                                                                         | ved.                                                                                                                                                                                                                       |     |                                |
| 15:0  | <b>NC and InitComplete</b> . Read-only. These bits provide duplicate versions of status bits F0x[F8, D8, B8, 98][NC and InitComplete] and F4x[F8, D8, B8, 98][NC and InitComplete] as follows: |                                                                                                                                                                                                                            |     |                                |
|       | Bit                                                                                                                                                                                            | Description                                                                                                                                                                                                                | Bit | Description                    |
|       | 0                                                                                                                                                                                              | link 0 sublink 0 InitComplete.                                                                                                                                                                                             | 8   | link 0 sublink 1 InitComplete. |
|       | 1                                                                                                                                                                                              | link 0 sublink 0 NC.                                                                                                                                                                                                       | 9   | link 0 sublink 1 NC.           |
|       | 2                                                                                                                                                                                              | link 1 sublink 0 InitComplete.                                                                                                                                                                                             | 10  | link 1 sublink 1 InitComplete. |
|       | 3                                                                                                                                                                                              | link 1 sublink 0 NC.                                                                                                                                                                                                       | 11  | link 1 sublink 1 NC.           |
|       | 4                                                                                                                                                                                              | link 2 sublink 0 InitComplete.                                                                                                                                                                                             | 12  | link 2 sublink 1 InitComplete. |
|       | 5                                                                                                                                                                                              | link 2 sublink 0 NC.                                                                                                                                                                                                       | 13  | link 2 sublink 1 NC.           |
|       | 6                                                                                                                                                                                              | link 3 sublink 0 InitComplete.                                                                                                                                                                                             | 14  | link 3 sublink 1 InitComplete. |
|       | 7                                                                                                                                                                                              | link 3 sublink 0 NC.                                                                                                                                                                                                       | 15  | link 3 sublink 1 NC.           |

## 3.4 Function 1 Address Map Registers

See section 3.1 [Register Descriptions and Mnemonics] on page 135 for a description of the register naming convention. See section 2.11 [Configuration Space] on page 112 for details about how to access this space.

# F1x00 Device/Vendor ID Register

| Reset: 1201 1022h. |                                 |  |
|--------------------|---------------------------------|--|
| Bits               | Description                     |  |
| 31:16              | DeviceID: device ID. Read-only. |  |
| 15:0               | VendorID: vendor ID. Read-only. |  |

## F1x08 Class Code/Revision ID Register

| Reset: 0600 0000h. |                                                                                                |  |
|--------------------|------------------------------------------------------------------------------------------------|--|
| Bits               | Description                                                                                    |  |
| 31:8               | ClassCode. Read-only. Provides the host bridge class code as defined in the PCI specification. |  |
| 7:0                | <b>RevID:</b> revision ID. Read-only. Processor revision. 00h=A0.                              |  |

#### F1x0C Header Type Register

| Reset: 0080 0000h. |                                                                                                                                                                          |  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits               | Description                                                                                                                                                              |  |
|                    | <b>HeaderTypeReg.</b> Read-only. These bits are fixed at their default values. The header type field indicates that there are multiple functions present in this device. |  |
|                    | indicates that there are multiple functions present in this device.                                                                                                      |  |

### F1x[1, 0][7C:40] DRAM Base/Limit Registers

These registers specify the destination node of DRAM address ranges. The following 8 sets of registers are specified:

| Base Address   | <u>Limit Address</u> | Base Address   | <u>Limit Address</u> |
|----------------|----------------------|----------------|----------------------|
| F1x040, F1x140 | F1x044, F1x144       | F1x060, F1x160 | F1x064, F1x164       |
| F1x048, F1x148 | F1x04C, F1x14C       | F1x068, F1x168 | F1x06C, F1x16C       |
| F1x050, F1x150 | F1x054, F1x154       | F1x070, F1x170 | F1x074, F1x174       |
| F1x058, F1x158 | F1x05C, F1x15C       | F1x078, F1x178 | F1x07C, F1x17C       |

F1x0XX registers provide the low address bits and F1x1XX registers provide the high address bits. Transaction addresses that are within the specified base/limit range are routed to the DstNode. See also section [The Northbridge Routing] 2.6.4.

#### DRAM mapping rules:

- Transaction addresses are within the defined range if: {DramBase[47:24], 00\_0000h} <= address[47:0] <= {DramLimit[47:24], FF\_FFFh}.
- DRAM regions must not overlap each other.
- Accesses to addresses that map to both DRAM, as specified by F1x[1, 0][7C:40] and F1x1[7C:40], and MMIO, as specified by F1x[BC:80], are routed to MMIO only.
- Programming of the DRAM address maps must be consistent with the Memory-Type Range Registers (MTRRs) and the top of memory registers, MSRC001\_001A and MSRC001\_001D. CPU accesses only hit within the DRAM address maps if the corresponding MTRR is of type DRAM. Accesses from IO links are routed based on [The DRAM Base/Limit Registers] F1x[1, 0][7C:40], only.
- The appropriate RE or WE bit(s) must be set.
- See also section 2.6.4.1.1 [DRAM and MMIO Memory Space] on page 51.

**Hoisting**. When memory hoisting is enabled in a node (via F1xF0[DramHoleValid]), F1x[1, 0][7C:40][DramLimit] should be set up to account for the memory hoisted above the hole. I.e., F1x[1, 0][7C:40]DramLimit should be set to F1x[1, 0][7C:40][DramBase] plus the size of the amount of memory owned by the node plus the hole size (4G minus F1xF0[DramHoleBase]). See section 2.8.9 [Memory Hoisting] on page 104 for more information about memory hoisting.

**Node interleave.** DRAM may be mapped as continuous regions for each node or it may be interleaved between nodes. See section 2.8.8.2 [Node Interleaving] on page 103 for details.

#### F1x[78, 70, 68, 60, 58, 50, 48, 40] DRAM Base Address Registers

| Bits  | Description                                                                                                          |
|-------|----------------------------------------------------------------------------------------------------------------------|
|       | <b>DramBase[39:24]: DRAM base address register bits[39:24]</b> . Read-write. Reset: X, except in F1x40 reset: 0000h. |
| 15:11 | Reserved                                                                                                             |

| 10:8 | IntlvEn[2:0]: interleave enable. Read-write. Reset: X, except in F1x40 reset: 0h. This field enables |
|------|------------------------------------------------------------------------------------------------------|
|      | interleaving on a 4-Kbyte boundary between memory on different nodes. The bits are encoded as        |
|      | follows:                                                                                             |
|      | 000b = No interleave                                                                                 |
|      | 001b = Interleave on A[12] (2 nodes)                                                                 |
|      | 011b = Interleave on A[12] and A[13] (4 nodes)                                                       |
|      | 111b = Interleave on A[12], A[13], and A[14] (8 nodes)                                               |
|      | All other values are reserved. The value of this field is required to match F1x124[DramIntlvEn].     |
| 7:2  | Reserved.                                                                                            |
| 1    | WE: write enable. Read-write. Reset: 0. 1=Writes to this address range are enabled.                  |
| 0    | <b>RE: read enable</b> . Read-write. Reset: 0. 1=Reads to this address range are enabled.            |

### F1x[178, 170, 168, 160, 158, 150, 148, 140] DRAM Base Address High Registers

| Ī | Bits | Description                                                                    |
|---|------|--------------------------------------------------------------------------------|
|   | 31:8 | Reserved.                                                                      |
|   | 7:0  | DramBase[47:40]: DRAM base address register bits[47:40]. Read-write. Reset: 0. |

### F1x[7C, 74, 6C, 64, 5C, 54, 4C, 44] DRAM Limit Address Registers

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                               |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | <b>DramLimit[39:24]: DRAM limit address register bits[39:24]</b> . Read-write. Reset: X, except in F1x44 reset: FFFFh.                                                                                                                                                                                                                                                    |
| 15:11 | Reserved.                                                                                                                                                                                                                                                                                                                                                                 |
| 10:8  | <b>IntlvSel:</b> interleave select. Read-write. Reset: X, except in F1x44 reset: 000b. This field specifies the values of address bits A[14:12] to use with the Interleave Enable field (IntlvEn[2:0]) to determine which 4-Kbyte blocks are routed to this region. IntlvSel[0] corresponds to A[12]; IntlvSel[1] corresponds to A[13]; IntlvSel[2] corresponds to A[14]. |
| 7:3   | Reserved.                                                                                                                                                                                                                                                                                                                                                                 |
| 2:0   | <b>DstNode: destination Node ID</b> . Read-write. Reset: X, except in F1x44 reset: 0h. This field specifies the node that a packet is routed to if it is within the address range.                                                                                                                                                                                        |

## F1x[17C, 174, 16C, 164, 15C, 154, 14C, 144] DRAM Limit Address High Registers

| Bits | Description                                                                      |
|------|----------------------------------------------------------------------------------|
| 31:8 | Reserved.                                                                        |
| 7:0  | DramLimit[47:40]: DRAM limit address register bits[47:40]. Read-write. Reset: 0. |

### F1x[BC:80] Memory Mapped IO Base/Limit Registers

These registers specify the mapping from memory addresses to the corresponding node and IO link for MMIO transactions. Address ranges are specified by 8 sets of base/limit registers. The first set is F1x80 and F1x84, the second set is F1x88 and F1x8C, and so forth. Transaction addresses that are within the specified base/limit range are routed to the node specified by DstNode and the link specified by DstLink. See also section [The Northbridge Routing] 2.6.4.

#### MMIO mapping rules:

• Transaction addresses are within the defined range if: {00h, MMIOBase[39:16], 0000h} <= address[47:0] <= {00h, MMIOLimit[39:16], FFFFh}.

- MMIO regions must not overlap each other.
- Accesses to addresses that map to both DRAM, as specified by F1x[1, 0][7C:40], and MMIO, as specified by F1x[BC:80], are routed to MMIO only.
- Programming of the MMIO address maps must be consistent with the Memory-Type Range Registers (MTRRs) and the top of memory registers, MSRC001\_001A and MSRC001\_001D. CPU accesses only hit within the MMIO address maps if the corresponding MTRR is of type IO. Accesses from IO links are routed based on [The Memory Mapped IO Base/Limit Registers] F1x[BC:80], only.
- The appropriate RE or WE bit(s) must be set.
- Scenarios in which the address space of multiple MMIO ranges target the same IO device is supported.
- See also section 2.6.4.1.1 [DRAM and MMIO Memory Space] on page 51.

## F1x[B8, B0, A8, A0, 98, 90, 88, 80] MMIO Base Address Registers

|      | • • • • • •                                                                                                                                                                                                                                                                                 |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits | Description                                                                                                                                                                                                                                                                                 |
| 31:8 | MMIOBase[39:16]: MMIO base address register bits[39:16]. Read-write. Reset: X.                                                                                                                                                                                                              |
| 7:4  | Reserved.                                                                                                                                                                                                                                                                                   |
| 3    | <b>Lock</b> . Read-write. Reset: X. 1=[The Memory Mapped IO Base/Limit Registers] F1x[BC:80], are read-only (including this bit). WE or RE in this register must be set in order for this to take effect.                                                                                   |
| 2    | <b>CpuDis: CPU Disable</b> . Read-write. Reset: X. 1=The MMIO range is disabled for CPU accesses; IO accesses still observe the MMIO range. If the MMIO range matches a DRAM range, this can be used to protect that DRAM space from IO devices by directing them to MMIO rather than DRAM. |
| 1    | <b>WE: write enable</b> . Read-write. Reset: 0. 1=Writes to this address range are enabled.                                                                                                                                                                                                 |
| 0    | <b>RE: read enable</b> . Read-write. Reset: 0. 1=Reads to this address range are enabled.                                                                                                                                                                                                   |

## F1x[BC, B4, AC, A4, 9C, 94, 8C, 84] MMIO Limit Address Registers

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | MMIOLimit[39:16]: MMIO limit address register bits[39:16]. Read-write. Reset: X.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7    | NP: non-posted. Read-write. Reset: X. 1=CPU write requests to this MMIO range are passed through the non-posted channel. This may be used to force writes to be non-posted for MMIO regions which map to the legacy ISA/LPC bus, or in conjunction with [The Link Transaction Control Register] F0x68[DsNpReqLmt] in order to allow downstream CPU requests to be counted and thereby limited to a specified number. This latter use of the NP bit may be used to avoid loop deadlock scenarios in systems that implement a region in an IO device that reflects downstream accesses back upstream. See the <i>HyperTransport</i> <sup>TM</sup> <i>IO Link Specification</i> summary of deadlock scenarios for more information. 0=CPU writes to this MMIO range use the posted channel. This bit does not affect requests that come from IO links (the virtual channel of the request is specified by the IO request). |
|      | Note: if two MMIO ranges target the same IO device and the NP bit is set differently in both ranges, unexpected transaction ordering effects are possible. In particular, using PCI- and IO-link-defined producer-consumer semantics, if a producer (e.g., the processor) writes data using a non-posted MMIO range followed by a flag to a posted MMIO range, then it is possible for the device to see the flag updated before the data is updated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6    | <b>DstSubLink:</b> destination sublink. Read-write. Reset: X. When a link is unganged, this bit specifies the destination sublink of the link specified by F1x[BC:80][DstLink]. 0=The destination link is sublink 0. 1=The destination link is sublink 1. If the link is ganged, then this bit must be low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| 4 | 5:4 | <b>DstLink: destination link ID</b> . Read-write. Reset: X. For transactions within the this MMIO range, |
|---|-----|----------------------------------------------------------------------------------------------------------|
|   |     | this field specifies the destination IO link number of the destination node.                             |
|   |     | 00b = Link 0 	 10b = Link 2                                                                              |
|   |     | 01b = Link 1 	 11b = Link 3                                                                              |
|   | 3   | Reserved.                                                                                                |
|   | 2:0 | <b>DstNode: destination node ID bits</b> . Read-write. Reset: X. For transactions within the this MMIO   |
|   |     | range, this field specifies the destination node ID.                                                     |

### F1x[DC:C0] IO-Space Base/Limit Registers

These registers specify the mapping from IO addresses to the corresponding node and IO link for transactions resulting from x86-defined IN and OUT instructions. IO address ranges are specified by 4 sets of base/limit registers. The first set is F1xC0 and F1xC4, the second set is F1xC8 and F1xCC, and so forth. Transaction addresses that are within the specified base/limit range are routed to the node specified by DstNode and the link specified by DstLink. See also section [The Northbridge Routing] 2.6.4.

### IO mapping rules:

- IO-space transaction addresses are within the defined range if: {IOBase[24:12], 000h} <= address <= {IOLimit[24:12], FFFh} and as specified by the IE bit; or if the address is in the range specified by the VE bits.
- IO regions must not overlap each other.
- The appropriate RE or WE bit(s) must be set.
- See also section 2.6.4.1.2 [IO Space] on page 52.

### F1x[D8, D0, C8, C0] IO-Space Base Address Registers

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 24:12 | IOBase[24:12]: IO base address register bits[24:12]. Read-write. Reset: X.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11:6  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5     | <b>IE: ISA enable</b> . Read-write. Reset: X. 1=The IO-space address window is limited to the first 256 bytes of each 1K byte block specified; this only applies to the first 64K bytes of IO space. 0=The PCI IO window is not limited in this way.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4     | <b>VE: VGA enable</b> . Read-write. Reset: X. 1=Include IO-space transactions targeting the VGA-compatible address space within the IO-space window of this base/limit pair. These include IO accesses in which address bits[9:0] range from 3B0h to 3BBh or 3C0h to 3DFh (address bits[15:10] are not decoded); this only applies to the first 64K of IO space; i.e., address bits[24:16] must be low). 0=IO-space transactions targeting VGA-compatible address ranges are not added to the IO-space window. This bit should only ever be set in one register. Note: The MMIO range associated with the VGA enable bit in the PCI specification is NOT included in the VE bit definition; to map this range to an IO link, see [The VGA Enable Register] F1xF4. Note, when F1xF4[VE] is set, the state of this bit is ignored. |
| 3:2   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1     | WE: write enable. Read-write. Reset: 0. 1=Writes to this IO-space address range are enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0     | <b>RE: read enable</b> . Read-write. Reset: 0. 1=Reads to this IO-space address range are enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

## F1x[DC, D4, CC, C4] IO-Space Limit Address Registers

| Bits  | Description                                                                                                                                                                                                                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | Reserved.                                                                                                                                                                                                                                                                                                   |
| 24:12 | IOLimit[24:12]: IO limit address register bits[24:12]. Read-write. Reset: X.                                                                                                                                                                                                                                |
| 11:7  | Reserved.                                                                                                                                                                                                                                                                                                   |
| 6     | <b>DstSubLink:</b> destination sublink. Read-write. Reset: X. When a link is unganged, this bit specifies the destination sublink of the link specified by F1x[DC:C0][DstLink]. 0=The destination link is sublink 0. 1=The destination link is sublink 1. If the link is ganged, then this bit must be low. |
| 5:4   | <b>DstLink: destination link ID</b> . Read-write. Reset: X. For transactions within the this IO-space range, this field specifies the destination IO link number of the destination node.  00b = Link 0 10b = Link 2 01b = Link 1 11b = Link 3                                                              |
| 3     | Reserved.                                                                                                                                                                                                                                                                                                   |
| 2:0   | <b>DstNode: destination node ID bits</b> . Read-write. Reset: X. For transactions within the this IO-space range, this field specifies the destination node ID.                                                                                                                                             |

### F1x[EC:E0] Configuration Map Registers

These registers specify the mapping from configuration address to the corresponding node and IO link. Configuration address ranges are specified by 4 of base/limit registers. The first is F1xE0, the second is F1xE4, and so forth. Transaction addresses that are within the specified base/limit range are routed to the node specified by DstNode and the link specified by DstLink. See also section [The Northbridge Routing] 2.6.4.

### Configuration space mapping rules:

• Configuration addresses (to "BusNo" and "Device" as specified by [The IO-Space Configuration Address Register] IOCF8 in the case of IO accesses or [The Configuration Space] 2.11 in the case of MMIO accesses) are within the defined range if:

```
( {BusNumBase[7:0]} <= BusNo <= {BusNumLimit[7:0]} ) & (DevCmpEn==0); or ( {BusNumBase[4:0]} <= Device <= {BusNumLimit[4:0]} ) & (DevCmpEn==1) & (BusNo == 00h).
```

- Configuration regions must not overlap each other.
- The appropriate RE or WE bit(s) must be set.
- See also section 2.6.4.1.3 [Configuration Space] on page 52.

| Bits  | Description                                                                                                                                                                                                                                                                                                 |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:24 | BusNumLimit[7:0]: bus number limit bits[7:0]. Read-write. Reset: X.                                                                                                                                                                                                                                         |  |
| 23:16 | BusNumBase[7:0]: bus number base bits[7:0]. Read-write. Reset: X.                                                                                                                                                                                                                                           |  |
| 15:11 | 1 Reserved.                                                                                                                                                                                                                                                                                                 |  |
| 10    | <b>DstSubLink: destination sublink.</b> Read-write. Reset: X. When a link is unganged, this bit specifies the destination sublink of the link specified by F1x[EC:E0][DstLink]. 0=The destination link is sublink 0. 1=The destination link is sublink 1. If the link is ganged, then this bit must be low. |  |
| 9:8   | <b>DstLink: destination link ID</b> . Read-write. Reset: X. For transactions within the this configuration-space range, this field specifies the destination IO link number of the destination node. $00b = Link 0$ $01b = Link 1$ $10b = Link 2$ $11b = Link 3$                                            |  |

| 7   | Reserved.                                                                                                                                                                                                                                                           |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | <b>DstNode: destination node ID bits</b> . Read-write. Reset: X. For transactions within the this configuration-space range, this field specifies the destination node ID.                                                                                          |
| 3   | Reserved.                                                                                                                                                                                                                                                           |
| 2   | <b>DevCmpEn:</b> device number compare mode enable. Read-write. Reset: X. 1=A device number range rather than a bus number range is used to specify the configuration-space window (see above). This is used to enable multiple IO links to be configured as Bus 0. |
| 1   | <b>WE: write enable</b> . Read-write. Reset: 0. 1=Writes to this configuration-space address range are enabled.                                                                                                                                                     |
| 0   | <b>RE: read enable</b> . Read-write. Reset: 0. 1=Reads to this configuration-space address range are enabled.                                                                                                                                                       |

# F1xF0 DRAM Hole Address Register

Reset: 0000 0000h.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | <b>DramHoleBase[31:24]</b> . DRAM hole base address. Read-write. This specifies the base address of the IO hole, below the 4G address level, that is used in memory hoisting. Normally, DramHoleBase >= MSRC001_001A[TOM[31:24]]. See section 2.8.9 [Memory Hoisting] on page 104 for additional programming information.                                                                         |
| 23:16 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                         |
| 15:7  | <b>DramHoleOffset[31:23]. DRAM hole offset address</b> . Read-write. When memory hosting is enabled, this value is subtracted from the physical address of certain transactions before being passed to the DCT. See section 2.8.9 [Memory Hoisting] on page 104 for additional programming information.                                                                                           |
| 6:2   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                         |
| 1     | <b>DramMemHoistValid</b> . Read-write. 1=Memory hoisting is enabled in one or more nodes of the coherent fabric. This bit should be set in all nodes of the coherent fabric if memory hoisting is employed by any of them.                                                                                                                                                                        |
| 0     | <b>DramHoleValid</b> . Read-write. 1=Memory hoisting is enabled in the node. 0=Memory hoisting is not enabled. This bit should be set in the node(s) that own the DRAM address space that is hoisted above the 4GB address level. If node interleaving is employed, then this should be set in all nodes. See section 2.8.9 [Memory Hoisting] on page 104 for additional programming information. |

# F1xF4 VGA Enable Register

Reset: 0000 0000h. All these bits are read-write unless Lock is set.

| Bits  | Description                                                                                         |  |
|-------|-----------------------------------------------------------------------------------------------------|--|
| 31:15 | Reserved.                                                                                           |  |
| 14    | <b>DstSubLink: destination sublink.</b> Read-write. When a link is unganged, this bit specifies the |  |
|       | destination sublink of the link specified by F1xF4[DstLink]. 0=The destination link is sublink 0.   |  |
|       | 1=The destination link is sublink 1. If the link is ganged, then this bit must be low.              |  |

| 13:12 | <b>DstLink: destination link ID</b> . Read-write. For transactions within the F1xF4[VE]-defined ranges,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|       | this field specifies the destination IO link number of the destination node.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|       | 00b = Link 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|       | 01b = Link 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|       | 10b = Link 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|       | 11b = Link 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 11:7  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 6:4   | <b>DstNode[2:0]: destination node ID</b> . Read-write. For transactions within the F1xF4[VE]-defined range, this field specifies the destination node ID.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 3     | <b>Lock</b> . Read-write. Reset: 0. 1=All the bits in this register (F1xF4) are read-only (including this bit).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 2     | <b>CpuDis: CPU Disable</b> . Read-write. 1=The F1xF4[VE]-defined MMIO range is disabled for CPU accesses; i.e., CPU accesses to this range are treated as if the VE=0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 1     | <b>NP: non-posted</b> . Read-write. 1=CPU write requests to the F1xF4[VE]-defined MMIO range are passed through the non-posted channel. 0=CPU writes may be posted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 0     | <b>VE:</b> VGA enable. Read-write. 1=Transactions targeting the VGA-compatible address space are routed and controlled as specified by this register. The VGA-compatible address space is: (1) the MMIO range A_0000h through B_FFFFh; (2) IO-space accesses in which address bits[9:0] range from 3B0h to 3BBh or 3C0h to 3DFh (address bits[15:10] are not decoded; this only applies to the first 64K of IO space; i.e., address bits[24:16] must be low). 0=Transactions targeting the VGA-compatible address space are not affected by the state of this register. Note, when this bit is set, the state of F1x[DC:C0][VE] is ignored. |  |  |

### F1x110 Extended Address Map Control Register

This register provides the index to several extended address map control registers. In order to access these registers, (1) AddrMapType and Index are written into this register; (2) read-write access to the register is accomplished through [The Extended Address Map Data Port] F1x114. The extended address map registers are disabled when [The Link Transaction Control Register] F0x68[CHtExtAddrEn] = 0b; when disabled the extended address maps are not checked for routing packets. The extended map address register must not be accessed if F0x68[CHtExtAddrEn] = 1b.

Before reading F1x114\_x2 or F1x114\_x3 software must initialize the registers or NB Array MCA errors may occur. BIOS should initialize index 0h of F1x114\_x2 and F1x114\_x3 to prevent reads from F1x114 from generating NB Array MCA errors.

| Bits  | Description                                                                                                                                                                                                                                       |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31    | Reserved.                                                                                                                                                                                                                                         |  |
| 30:28 | AddrMapType. Read-write. Specifies the type of address map being accessed as follows:  00xb = Reserved  010b = [The Extended MMIO Address Base Registers] F1x114_x2  011b = [The Extended MMIO Address Mask Registers] F1x114_x3  1xxb = Reserved |  |
| 27:4  | Reserved.                                                                                                                                                                                                                                         |  |
| 3:0   | Index. Read-write. This function varies based on the AddrMapType register accessed.                                                                                                                                                               |  |

### F1x114 Extended Address Map Data Port

See F1x110 for details about this port.

### F1x114\_x2 Extended MMIO Address Base Registers

See F1x110 for information about accessing this set of registers. The extended MMIO address map is a 16 entry table with fully associative lookup. Each entry is accessed through F1x114\_x2 and F1x114\_x3, with F1x110[Index] specifying the entry number. An incoming transaction of address Addr[47:0] is determined to be within the range specified by an entry if the following is true, as a function of F0x168[ExtMmioMa-pAddSel]:

#### F0x168[ExtMmioMapAddSel]:Equation

```
00b: (Addr[39:19] | MmioMapMask[20:0] == MmioMapBase[20:0] | MmioMapMask[20:0]) & (Addr[47:40] == 00h) 01b: (Addr[44:23] | MmioMapMask[20:0] == MmioMapBase[20:0] | MmioMapMask[20:0]) & (Addr[47:44] == 0h) 10b: (Addr[47:27] | MmioMapMask[20:0] == MmioMapBase[20:0] | MmioMapMask[20:0]) 11b: Reserved.
```

Accesses within the range specified by an entry are routed to the node specified by MmioDstNode.

It is the responsibility of software to ensure each address hits only 1 entry in the MMIO map. Hits to multiple entries result in undefined behavior. Note the precedence of defined memory ranges specified by section 2.6.4.1.1 [DRAM and MMIO Memory Space] on page 51.

Note that the MMIO base and mask entries are written into the address map together by the hardware only when the mask is written by software. As a result, the base (F1x114\_x2) must be written by software before the mask (F1x114\_x3). On a read, the mask must be read before the base and the hardware read of the map registers occurs when the mask is read by software. Also, writes to the data/mask registers are stored differently than they are written, such that the value read back may be different than what is written as follows:

| Write base bit | Write mask bit | Read base bit | Read mask bit | <u>Notes</u>            |
|----------------|----------------|---------------|---------------|-------------------------|
| 0              | 0              | 0             | 1             | Base bit is 0, unmasked |
| 1              | 0              | 1             | 0             | Base bit is 1, unmasked |
| 0 or 1         | 1              | 1             | 1             | Bit is masked           |

All CPU write requests that are routed through these registers are routed in the posted channel. IO link write requests that are routed through these registers use channel indicated in the source request.

| Bits  | Description                                                                                                                                                                                                                                                      |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:29 | Reserved.                                                                                                                                                                                                                                                        |  |
| 28:8  | MmioMapBase[20:0]. Read-write. Reset: X.                                                                                                                                                                                                                         |  |
| 7     | Reserved.                                                                                                                                                                                                                                                        |  |
| 6     | MmioDstThisNode. Read-write. Reset: X. 1=The destination is the local node. See MmioDstNode.                                                                                                                                                                     |  |
| 5:3   | Reserved.                                                                                                                                                                                                                                                        |  |
| 2:0   | <b>MmioDstNode</b> . Read-write. Reset: X. Specifies the destination node or link of the MMIO access. If MmioDstThisNode=1, MmioDstNode[1:0] contains the destination link number and MmioDstNode[2] contains the destination sublink (if the link is unganged). |  |

### F1x114\_x3 Extended MMIO Address Mask Registers

#### See F1x114 x2 for details.

| Bits  | Description                                                             |
|-------|-------------------------------------------------------------------------|
| 31:29 | Reserved.                                                               |
| 28:8  | MmioMapMask[20:0]. Read-write. Reset: X. 1=Address bit is a don't care. |
| 7:1   | Reserved.                                                               |
| 0     | MmioMapEn. Read-write. Reset: 0. 1=This entry is enabled.               |

### F1x120 DRAM Base System Address Register

F1x120 and F1x124 are required to specify the base and limit system address range of the DRAM connected to the local node. DRAM accesses to the local node with physical address Addr[47:0] that are within the following range are directed to the DCTs:

{DramBaseAddr[47:27], 000\_0000h} <= Addr[47:0] <= {DramLimitAddr[47:27], 7FF\_FFFh}; DRAM accesses to the local node that are outside of this range are master aborted. This range is also used to specify the range of DRAM covered by the scrubber (see F3x58 and F3x5C).

DRAM may be mapped as continuous regions for each node or it may be interleaved between nodes. If node interleaving is not invoked, as specified by DramIntlvEn, then the address of the DRAM transaction is normalized before passing it to the DCTs by subtracting DramBaseAddr.

If node interleaving is invoked, then DramBaseAddr should be zero in all the nodes and DramLimitAddr should be the top of memory in all nodes. Based on the value of DramIntlvEn, the normalized address to the DCTs is modified to remove the affected address bits between A[17:12]; e.g., if 8-node interleave is invoked, then DramIntlvEn is set to 111b and the normalized address to the DCTs removes A[14:12] to become {A[47:15], A[11:0]}. See section 2.8.8.2 [Node Interleaving] on page 103 for more details.

| Bits  | Description                                                                                                                                                                                                                                                                                        |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:24 | 24 Reserved.                                                                                                                                                                                                                                                                                       |  |
|       | <b>DramIntlvSel: interleave select</b> . Read-write. Reset: 0. This field specifies the values of address bits A[14:12] that are routed to the local node when node interleaving is enabled. IntlvSel[0] corresponds to A[12]; IntlvSel[1] corresponds to A[13]; IntlvSel[2] corresponds to A[14]. |  |
| 20:0  | DramBaseAddr[47:27]. Read-write. Reset: 0.                                                                                                                                                                                                                                                         |  |

### F1x124 DRAM Limit System Address Register

## See F1x120.

| Bits  | Description                                                                                            |  |
|-------|--------------------------------------------------------------------------------------------------------|--|
| 31:21 | Reserved.                                                                                              |  |
| 23:21 | <b>DramIntlvEn[2:0].</b> Read-write. Reset: 0. This field specifies interleaving on a 4-Kbyte boundary |  |
|       | between DRAM on different nodes. The bits are encoded as follows:                                      |  |
|       | 000b = No interleave                                                                                   |  |
|       | 001b = Interleave on A[12] (2 nodes)                                                                   |  |
|       | 011b = Interleave on A[12] and A[13] (4 nodes)                                                         |  |
|       | 111b = Interleave on A[12], A[13], and A[14] (8 nodes)                                                 |  |
|       | All other values are reserved. The value of this field is required to match F1x[1, 0][7C:40][IntlvEn]. |  |
| 20:0  | DramLimitAddr[47:27]. Read-write. Reset: 1F_FFFFh.                                                     |  |

#### F1x1[7C:40] DRAM Base/Limit Address High Registers

These registers provide upper DRAM base/limit address bits. See F1x[1, 0][7C:40] for details.

### 3.5 Function 2 DRAM Controller Registers

See section 3.1 [Register Descriptions and Mnemonics] on page 135 for a description of the register naming convention. See section 2.11 [Configuration Space] on page 112 for details about how to access this space.

### F2x00 Device/Vendor ID Register

| Reset: 1202 1022h. |                                 |  |
|--------------------|---------------------------------|--|
| Bits               | Description                     |  |
| 31:16              | DeviceID: device ID. Read-only. |  |
| 15:0               | VendorID: vendor ID. Read-only. |  |

#### F2x08 Class Code/Revision ID Register

| Reset: 0600 0000h. |                                                                                                |  |
|--------------------|------------------------------------------------------------------------------------------------|--|
| Bits               | Description                                                                                    |  |
| 31:8               | ClassCode. Read-only. Provides the host bridge class code as defined in the PCI specification. |  |
| 7:0                | RevID: revision ID. Read-only.                                                                 |  |

### F2x0C Header Type Register

| Reset: 0080 0000h. |                                                                                                                                                                          |  |  |  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits               | Description                                                                                                                                                              |  |  |  |
|                    | <b>HeaderTypeReg.</b> Read-only. These bits are fixed at their default values. The header type field indicates that there are multiple functions present in this device. |  |  |  |

### F2x[1, 0][5C:40] DRAM CS Base Address Registers

Reset: 0000 0000h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

These registers along with [The DRAM CS Mask Registers] F2x[1, 0][6C:60], translate DRAM request addresses (to a DRAM controller) into DRAM chip selects. Supported DIMM sizes are specified in [The DRAM Bank Address Mapping Register] F2x[1, 0]80. For more information on the DRAM controllers, see section 2.8 [DRAM Controllers (DCTs)] on page 60.

The processor logically supports the following number of DIMMs in the following packages:

| Package          | Number of DIMMs per channel |                   |            | el       |
|------------------|-----------------------------|-------------------|------------|----------|
|                  | Registered                  | 4-Rank registered | Unbuffered | SO-DIMMs |
| Fr2(1207)        | 4                           | 2                 | 0          | 0        |
| G(1207)          | 4                           | 2                 | 0          | 0        |
| AM2r2 and<br>AM3 | 0                           | 0                 | 2          | 1        |

For each chip select, there is a DRAM CS Base Address register. For every two chip selects there is a DRAM CS Mask Register. These are associated with logical DIMM numbers, CKE, and ODT signals as follows:

Table 44: Logical DIMM, Chip Select, CKE, ODT, and Register Mapping

| Base Address<br>Registers | Mask<br>Register | Log<br>DIN |    | Chip Select            | M[B, A]_<br>CKE[x] | ODT                  |
|---------------------------|------------------|------------|----|------------------------|--------------------|----------------------|
|                           |                  | N          | R4 |                        |                    |                      |
| F2x[1, 0]40               | F2x[1, 0]60      | 0          | 0  | M[B, A]0_CS_L[0]       | 0                  | M[B, A]0_ODT[0]      |
| F2x[1, 0]44               |                  |            |    | M[B, A]0_CS_L[1]       | 1                  | $M[B, A]0\_ODT[0]^3$ |
|                           |                  |            |    |                        |                    | $M[B, A]1\_ODT[0]^4$ |
| F2x[1, 0]48               | F2x[1, 0]64      | 1          | 1  | $M[B, A]1\_CS\_L[0]^3$ | 0                  | $M[B, A]1\_ODT[0]^3$ |
|                           |                  |            |    |                        |                    | $M[B, A]0\_ODT[0]^4$ |
| F2x[1, 0]4C               |                  |            |    | $M[B, A]1\_CS\_L[1]^3$ | 1                  | $M[B, A]1\_ODT[0]^3$ |
| F2x[1, 0]50               | F2x[1, 0]68      | $2^2$      | 0  | M[B, A]2_CS_L[0]       | 0                  | M[B, A]2_ODT[0]      |
| F2x[1, 0]54               |                  |            |    | M[B, A]2_CS_L[1]       | 1                  | M[B, A]2_ODT[0]      |
| F2x[1, 0]58               | F2x[1, 0]6C      | $3^2$      | 1  | M[B, A]3_CS_L[0]       | 0                  | M[B, A]3_ODT[0]      |
| F2x[1, 0]5C               |                  |            |    | M[B, A]3_CS_L[1]       | 1                  | M[B, A]3_ODT[0]      |

### Notes:

- 1. N=Normal. R4=Four-rank registered DIMM only (F2x[1, 0]94[FourRankRDimm]=1).
- 2. Logical DIMM numbers 2 and 3 are not supported in the AM2r2 and AM3 packages.
- 3. Fr2(1207), AM2r2, and AM3 packages.
- 4. SO-DIMM using an AM2r2 or AM3 package.

The DRAM controller operates on the normalized physical address of the DRAM request. The normalized physical address includes all of the address bits that are supported by a DRAM controller. See also section 2.6.1 [Northbridge (NB) Architecture] on page 50.

Each base address register specifies the starting normalized address of the block of memory associated with the chip select. Each mask register specifies the additional address bits that are consumed by the block of memory associated with the chip selects. If both chip selects of a logical DIMM are used, they must be the same size; in this case, a single mask register covers the address space consumed by both chip selects.

Lower-order address bits are provided in the base address and mask registers, as well. These allow memory to be interleaved between chip selects, such that contiguous physical addresses map to the same DRAM page of multiple chip selects. See section 2.8.8.1 [Chip Select Interleaving] on page 101 for more information. The hardware supports the use of lower-order address bits to interleave chip selects if (1) each chip select of the

memory system spans the same amount of memory and (2) the number of chip selects of the memory system is a power of two.

System BIOS is required to assign the largest DIMM chip-select range to the lowest normalized address of the DRAM controller. As addresses increase, the chip-select size is required to remain constant or decrease. This is necessary to keep DIMM chip-select banks on aligned address boundaries, regardless as to the amount of address space covered by each chip select.

For each normalized address for requests that enters a DRAM controller, a ChipSelect[i] is asserted if:

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 28:19 | BaseAddr[36:27]: normalized physical base address bits [36:27]. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 18:14 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13:5  | BaseAddr[21:13]: normalized physical base address bits [21:13]. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3     | OnDimmMirror: on-DIMM mirroring (ODM) enabled. Read-write. 1=Address and bank bits are swapped for this chip select in order to account for swapped routing on the DIMM during DRAM initialization. This is expected to be set appropriately for the odd numbered rank of each unbuffered DIMM when F2x[1, 0]90[UnbuffDimm]=1 and F2x[1, 0]94[Ddr3Mode]=1; it is not expected to be set when connected to SO-DIMM or micro-DIMMs. The bits that are swapped when this is enabled are:  • M[B, A]_BANK[0] and M[B, A]_BANK[1].  • M[B, A]_ADD[3] and M[B, A]_ADD[4].  • M[B, A]_ADD[5] and M[B, A]_ADD[6].  • M[B, A]_ADD[7] and M[B, A]_ADD[8]. |
| 2     | <b>TestFail: memory test failed.</b> Read-write. This bit is set by BIOS to indicate that the rank is present but the memory is bad. The CSEnable and Spare bits must not be set if this bit is set. This bit must be set prior to DRAM initialization.                                                                                                                                                                                                                                                                                                                                                                                         |
| 1     | <b>Spare: spare rank</b> . Read-write. This bit identifies the chip select associated with the spare rank. See section 2.8.10 [On-Line Spare] on page 106.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0     | CSEnable: chip select enable. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### F2x[1, 0][6C:60] DRAM CS Mask Registers

Reset: 0000 0000h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers. See F2x[1, 0][5C:40] for information about this register.

| Bits  | Description                                                                 |
|-------|-----------------------------------------------------------------------------|
| 31:29 | Reserved.                                                                   |
| 28:19 | AddrMask[36:27]: normalized physical address mask bits [36:27]. Read-write. |
| 18:14 | Reserved.                                                                   |

| 13:5 | AddrMask[21:13]: normalized physical address mask bits [21:13]. Read-write. |
|------|-----------------------------------------------------------------------------|
| 4:0  | Reserved.                                                                   |

# F2x[1, 0]78 DRAM Control Register

Reset: 0000 0006h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | <b>MaxRdLatency: maximum read latency</b> . Read-write. This field should be programmed by the system BIOS to specify the maximum round-trip latency in the system from the processor to the DRAM devices and back. The DRAM controller uses this to help determine when incoming DRAM read data can be safely transferred to the NCLK domain. The time is specified in NB clocks and includes the asynchronous and synchronous latencies. See section 2.8.7.8.4 [Calculating MaxRdLatency] on page 98 for information on how to program this field. |
| 21:20 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 19    | <b>EarlyArbEn: early arbitration enable</b> . Read-write. 1=The DCT optimizes the arbitration phases to improve performance on back-to-back DRAM reads under certain conditions. BIOS should set this bit whenever the NCLK to MEMCLK ratio is between 4.5:1 and 3:1 inclusive. 0=The DCT arbitrates normally.                                                                                                                                                                                                                                       |
| 18    | <b>DqsRcvEnTrain: DQS</b> receiver enable training mode. Read-write. 1=Enable DQS receiver enable training mode. 0 = Normal DQS receiver enable operation.                                                                                                                                                                                                                                                                                                                                                                                           |
| 17    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 16    | AltVidC3MemClkTriEn: alternate voltage ID C3 memory clock tristate enable. Read-write. 1=The MEMCLK signals are tristated while LDTSTOP_L is asserted if F3x[84:80][AltVidEn]=1 for the associated low-power state.                                                                                                                                                                                                                                                                                                                                  |
| 15:14 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 13:12 | <b>Trdrd[3:2]: read to read timing</b> . Read-write. This field along with F2x[1, 0]8C[Trdrd[1:0]] combine to specify a 4-bit value, Trdrd[3:0], when F2x[1, 0]94[Ddr3Mode]=1. See F2x[1, 0]8C[Trdrd[1:0]].                                                                                                                                                                                                                                                                                                                                          |
| 11:10 | <b>Twrwr[3:2]: write to write timing</b> . Read-write. This field along with F2x[1, 0]8C[Twrwr[1:0]] combine to specify a 4-bit value, Twrwr[3:0], when F2x[1, 0]94[Ddr3Mode]=1. See F2x[1, 0]8C[Twrwr[1:0]].                                                                                                                                                                                                                                                                                                                                        |
| 9:8   | <b>Twrrd[3:2]: write to read DIMM termination turnaround</b> . Read-write. This field along with F2x[1, 0]8C[Twrrd[1:0]] combine to specify a 4-bit value, Twrrd[3:0], when F2x[1, 0]94[Ddr3Mode]=1. See F2x[1, 0]8C[Twrrd[1:0]].                                                                                                                                                                                                                                                                                                                    |

| 7:4 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                    |  |  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|--|--|
| 3:0 | <b>RdPtrInit: read pointer initial value</b> . Read-write. There is a synchronization FIFO between the NB clock domain and memory clock domain. Each increment of this field positions the read pointer one half clock cycle closer to the write pointer thereby reducing the latency through the FIFO. This field should be written prior to DRAM initialization. It is recommended that these bits remain in the default |                                                    |  |  |
|     | state. Bits                                                                                                                                                                                                                                                                                                                                                                                                                | Read to Write Pointer Separation                   |  |  |
|     | 0000b - 0010b                                                                                                                                                                                                                                                                                                                                                                                                              | Reserved                                           |  |  |
|     | 0011b                                                                                                                                                                                                                                                                                                                                                                                                                      | 2.5 MEMCLKs (For DDR3, this encoding is reserved.) |  |  |
|     | 0100b                                                                                                                                                                                                                                                                                                                                                                                                                      | 2 MEMCLKs                                          |  |  |
|     | 0101b                                                                                                                                                                                                                                                                                                                                                                                                                      | 1.5 MEMCLKs                                        |  |  |
|     | 0110b                                                                                                                                                                                                                                                                                                                                                                                                                      | Reserved                                           |  |  |
|     | 0111b - 1111b                                                                                                                                                                                                                                                                                                                                                                                                              | Reserved                                           |  |  |

## F2x[1, 0]7C DRAM Initialization Register

Reset: 0000 0000h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

BIOS can directly control the DRAM initialization sequence using this register. To do so, BIOS sets EnDramInit to start DRAM initialization. BIOS should then complete the initialization sequence specified in the appropriate JEDEC specification. For registered DIMMs, BIOS should follow the recommendations for reset usage in the JEDEC RDIMM specification during the initialization sequence. After completing the sequence, BIOS clears EnDramInit to complete DRAM initialization. BIOS should not assert LDTSTOP\_L while EnDramInit is set. Note: setting more than one of the command bits in this register (SendControlWord, SendMrsCmd, SendAutoRefresh, and SendPchgAll) at a time results in undefined behavior.

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                            |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | <b>EnDramInit:</b> enable DRAM initialization. Read-write. 1=Place the DRAM controller in the BIOS-controlled DRAM initialization mode. The DCT asserts memory reset and deasserts CKE when this bit is set. BIOS must wait until F2x[1, 0]98[DctAccessDone] = 1 before programming AssertCke=1 and DeassertMemRstX=1. BIOS must clear this bit after DRAM initialization is complete. |
| 30   | <b>SendControlWord:</b> send control word. Read; write-1-only; cleared-by-hardware. 1= The DCT sends a control word to a chip select pair defined in $F2x[1, 0]A8[CtrlWordCS]$ . This bit is cleared by hardware after the command completes. This bit is valid only when $F2x[1, 0]94[Ddr3Mode] = 1$ and $F2x[1, 0]90[UnbuffDimm] = 0$ .                                              |
| 29   | <b>SendZQCmd: send ZQ command</b> . Read; write-1-only; cleared-by-hardware. 1=The DCT sends the ZQ calibration command. This bit is cleared by the hardware after the command completes. This bit is valid only when $F2x[1, 0]94[Ddr3Mode] = 1$ .                                                                                                                                    |
| 28   | <b>AssertCke:</b> assert CKE. Read-write. Setting this bit causes the DCT to assert the CKE pins. This bit cannot be used to deassert the CKE pins.                                                                                                                                                                                                                                    |
| 27   | <b>DeassertMemRstX: deassert memory reset</b> . Read-write. Setting this bit causes the DCT to deassert the memory reset. This bit cannot be used to assert the memory reset pin.                                                                                                                                                                                                      |
| 26   | <b>SendMrsCmd:</b> send MRS/EMRS command. Read; write-1-only; cleared-by-hardware. 1=The DCT sends the MRS or EMRS commands defined by the MrsAddress and MrsBank fields of this register. This bit is cleared by hardware after the command completes.                                                                                                                                |
| 25   | <b>SendAutoRefresh: send auto refresh command</b> . Read; write-1-only; cleared-by-hardware. 1=The DCT sends an auto refresh command. This bit is cleared by hardware after the command completes.                                                                                                                                                                                     |

| 24    | SendPchgAll: send precharge all command. Read; write-1-only; cleared-by-hardware. 1=The DCT                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | sends a precharge-all command. This bit is cleared by hardware after the command completes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 23    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 22:20 | MrsChipSel: MRS/EMRS command chip select. Read-write. This field specifies which DRAM chip select is used for MRS/EMRS commands. For DDR2 and DDR3 unbuffered DIMMs, this field is valid only when EnDramInit = 0; otherwise, MRS/EMRS commands are sent to all chip selects. For DDR3 registered DIMMs, this field specifies the chip select used for MR commands for software initialization only; i.e., when EnDramInit = 1.  Bits Definition  000b MRS/EMRS command is sent to CS0  001b MRS/EMRS command is sent to CS1  111b MRS/EMRS command is sent to CS7 |
| 19    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 18:16 | MrsBank: bank address for MRS/EMRS commands. Read-write. This field specifies the data driven on the DRAM bank pins for MRS and EMRS commands.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:0  | <b>MrsAddress: address for MRS/EMRS commands</b> . Read-write. This field specifies the data driven on the DRAM address pins 15-0 for MRS and EMRS commands.                                                                                                                                                                                                                                                                                                                                                                                                       |

### F2x[1, 0]80 DRAM Bank Address Mapping Register

Reset: 0000 0000h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

These fields specify DIMM configuration information. Dimm0AddrMap applies to each physical DIMM of logical DIMM 0 (where logical DIMM numbers are specified by [The DRAM CS Base Address Registers] F2x[1, 0][5C:40]), and so forth. These fields are required to be programmed per the following table, based on the DRAM device size and width information of the DIMM. Table 45, for DDR2, Table 46, for DDR3, shows the bit numbers for each position when the DCTs are operating in 64-bit mode (unganged); for 128-bit mode (ganged), address bit 3 delineates between the two channels and the address bit numbers in the table must be incremented by one.

| Bits  | Description                                   |
|-------|-----------------------------------------------|
| 31:16 | Reserved.                                     |
| 15:12 | Dimm3AddrMap: DIMM 3 address map. Read-write. |
| 11:8  | Dimm2AddrMap: DIMM 2 address map. Read-write. |
| 7:4   | Dimm1AddrMap: DIMM 1 address map. Read-write. |
| 3:0   | Dimm0AddrMap: DIMM 0 address map. Read-write. |

### Table 45: DDR2 DRAM address mapping

|       |         | Device size, |   | Bank Address |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|---------|--------------|---|--------------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bits  | CS Size | width        | 2 | 1            | 0  |     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0000b | 128 MB  | 256Mb, x16   | X | 13           | 12 | Row | X  | X  | X  | 17 | 16 | 15 | 14 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         |              |   |              |    | Col | X  | X  | X  | X  | X  | AP | X  | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 0001b | 256MB   | 256Mb, x8    | X | 14           | 13 | Row | X  | X  | X  | 17 | 16 | 15 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         | 512Mb, x16   |   |              |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |

Table 45: DDR2 DRAM address mapping

|       |         | Device size, | Bank Address |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|---------|--------------|--------------|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bits  | CS Size | width        | 2            | 1  | 0  |     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0010b | 512MB   | 512Mb, x8    | X            | 14 | 13 | Row | X  | X  | 17 | 16 | 15 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         |              |              |    |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 0011b | 512MB   | 256Mb, x4    | X            | 15 | 14 | Row | X  | X  | X  | 17 | 16 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         |              |              |    |    | Col | X  | X  | X  | X  | 13 | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 0100b | 512MB   | 1Gb, x16     | 15           | 14 | 13 | Row | X  | X  | X  | 17 | 16 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         |              |              |    |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 0101b | 1GB     | 1G, x8       | 15           | 14 | 13 | Row | X  | X  | 17 | 16 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         | 2G, x16      |              |    |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 0110b | 1GB     | 512Mb, x4    | X            | 15 | 14 | Row | X  | X  | 17 | 16 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         |              |              |    |    | Col | X  | X  | X  | X  | 13 | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 0111b | 2GB     | 2Gb, x8      | 15           | 14 | 13 | Row | X  | 17 | 16 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         | 4Gb, x16     |              |    |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 1000b | 2GB     | 1Gb, x4      | 16           | 15 | 14 | Row | X  | X  | 17 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         |              |              |    |    | Col | X  | X  | X  | X  | 13 | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 1001b | 4GB     | 2Gb, x4      | 16           | 15 | 14 | Row | X  | 17 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         |              |              |    |    | Col | X  | X  | X  | X  | 13 | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 1010b | 4GB     | 4Gb, x8      | 15           | 14 | 13 | Row | 17 | 16 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         |              |              |    |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 1011b | 8GB     | 4Gb, x4      | 16           | 15 | 14 | Row | 17 | 32 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         |              |              |    |    | Col | X  | X  | X  | X  | 13 | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |

Table 46: DDR3 DRAM address mapping

|       |         |              |    |      |    |     |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    | $\overline{}$ |
|-------|---------|--------------|----|------|----|-----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|---------------|
|       |         | Device size, |    | Bank |    |     |    |    |    |    |    |    | Ad | ldress | 3  |    |    |    |    |    |    |               |
| Bits  | CS Size | width        | 2  | 1    | 0  |     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| 0000b |         | Reserved     |    |      |    | Row |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |               |
|       |         |              |    |      |    | Col |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |               |
| 0001b | 256MB   | 512Mb, x16   | 15 | 14   | 13 | Row | X  | X  | X  | X  | 17 | 16 | 27 | 26     | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18            |
|       |         |              |    |      |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3             |
| 0010b | 512MB   | 512Mb, x8    | 15 | 14   | 13 | Row | X  | X  | X  | 17 | 16 | 28 | 27 | 26     | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18            |
|       |         | 1Gb, x16     |    |      |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3             |
| 0011b |         | Reserved     |    |      |    | Row |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |               |
|       |         |              |    |      |    | Col |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |               |
| 0100b |         | Reserved     |    |      |    | Row |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |               |
|       |         |              |    |      |    | Col |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |               |
| 0101b | 1GB     | 1Gb, x8      | 15 | 14   | 13 | Row | X  | X  | 17 | 16 | 29 | 28 | 27 | 26     | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18            |
|       |         | 2Gb, x16     |    |      |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3             |
| 0110b | 1GB     | 512Mb, x4    | 16 | 15   | 14 | Row | X  | X  | X  | 17 | 29 | 28 | 27 | 26     | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18            |
|       |         |              |    |      |    | Col | X  | X  | X  | X  | 13 | AP | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3             |
| 0111b | 2GB     | 2Gb, x8      | 15 | 14   | 13 | Row | X  | 17 | 16 | 30 | 29 | 28 | 27 | 26     | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18            |
|       |         |              |    |      |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3             |
| 1000b | 2GB     | 1Gb, x4      | 16 | 15   | 14 | Row | Х  | X  | 17 | 30 | 29 | 28 | 27 | 26     | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18            |
|       |         |              |    |      |    | Col | X  | X  | X  | X  | 13 | AP | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3             |
| 1001b | 4GB     | 2Gb, x4      | 16 | 15   | 14 | Row | X  | 17 | 31 | 30 | 29 | 28 | 27 | 26     | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18            |
|       |         |              |    |      |    | Col | X  | X  | X  | X  | 13 | AP | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3             |

| Table 46: DDR3 DRAM address mapp | ing |
|----------------------------------|-----|
|----------------------------------|-----|

|       |         | Device size, |    | Bank Address |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|---------|--------------|----|--------------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bits  | CS Size | width        | 2  | 1            | 0  |     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 1010b | 4GB     | 4Gb, x8      | 15 | 14           | 13 | Row | 17 | 16 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         | 8Gb, x16     |    |              |    | Col | X  | X  | X  | X  | X  | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |
| 1011b | 8GB     | 4Gb, x4      | 16 | 15           | 14 | Row | 17 | 32 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 |
|       |         | 8Gb, x8      |    |              |    | Col | X  | X  | X  | X  | 13 | AP | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  |

### F2x[1, 0]84 DRAM MRS Register

Reset: 0000 0004h. All fields of this register are programmed into the DRAM device mode registers, MR[3, 2, 1, 0], for each DDR3 DRAM device during the DRAM initialization process. For DDR2-1066, only the Twr field is applicable. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 26    | MprEn: multi purpose register enable. Read-write. 0=The multi purpose register is disabled. 1=The DDR3-defined multi purpose register enabled; data from subsequent read transactions come from the multi purpose register.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25:24 | MprLoc: multi purpose register address location. Read-write. If MprEn=0, this field is ignored. 00b=Load the DDR3-defined pattern into multi purpose register. All other encoding are reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 23    | PchgPDModeSel: precharge power down mode select. Read-write. 0=DDR3-defined slow exit mode; the DCT issues the first valid read, read with auto-precharge, or synchronous ODT command a minimum of 24ns (DDR3-defined tXPDLL) after precharge power down exit. 1=DDR3-defined fast exit mode; the DCT issues the first valid command a minimum of 7.5ns for DDR3-800 and DDR3-1066 DRAMs or 6ns for DDR3-1333 and DDR3-1600 DRAMs (DDR3-defined tXP) after precharge power down exit. This bit is valid only when F2x[1, 0]94[Ddr3Mode] = 1. BIOS should set this bit when there is one 2 rank SO-DIMM on a populated channel; otherwise, this bit is always 0. |
| 22:20 | Tcwl: CAS write latency. Read-write. This specifies the number of clock cycles from internal write command to first write data in.  000b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 19    | <b>SRT:</b> self refresh temperature range. Read-write. Specifies the SRT range for the DRAM devices. 0=Normal operating temperature range. 1=Extended operating temperature range. If ASR=1 then SRT must be 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 18    | <b>ASR:</b> auto self refresh. Read-write. Specifies the ASR mode for the DRAM devices. 1=DDR3 SDRAM automatically provides self refresh entry and power management functions for all supported operating temperature values. 0=ASR is disabled and SRT is used.                                                                                                                                                                                                                                                                                                                                                                                                |
| 17:14 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13    | <b>Qoff: output disable</b> . Read-write. Specifies the QOFF value for the DRAM devices. 0=Output buffers enabled. 1=Output buffers disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|     | <b>DramTermDyn: DRAM dynamic termination.</b> Read-write. This specifies the programming of the |                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|-----|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|     |                                                                                                 | dynamic termination value for writes who                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     |                                                                                                 | DDR3 DRAM initialization ( $F2x[1, 0]90[$                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     | _                                                                                               | here are 2 DIMMs on a channel. This field                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                     |                                                                                 | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|     | Bits                                                                                            | DDR3 definition                                                                                                                                                                                                                                                                                                                                                   | i is valid only                                                                                                                                                     | y wiic                                                                          | 3112x[1,0]94[Dut3Wode] = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|     | 00b                                                                                             | Dynamic termination for writes disable                                                                                                                                                                                                                                                                                                                            | . d                                                                                                                                                                 |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     |                                                                                                 | *                                                                                                                                                                                                                                                                                                                                                                 | eu                                                                                                                                                                  |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     | 01b                                                                                             | RZQ/4                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     | 10b                                                                                             | RZQ/2 (Recommended for 2 DIMMs)                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     | 11b                                                                                             | Reserved                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| 9:7 | DramT                                                                                           | erm: DRAM nominal termination. Rea                                                                                                                                                                                                                                                                                                                                | d-write This                                                                                                                                                        | spec                                                                            | ifies the programming of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| J   |                                                                                                 | nominal termination value when the MR                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                     | _                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     |                                                                                                 | DRAM initialization (F2x[1, 0]90[InitDra                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     |                                                                                                 | dr3Mode = 1. For DDR2 termination value                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     |                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                   | _                                                                                                                                                                   | _                                                                               | <del>-</del>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|     | Bits                                                                                            | DDR3 definition                                                                                                                                                                                                                                                                                                                                                   | <u>Bit</u>                                                                                                                                                          |                                                                                 | DDR3 definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     | 000b                                                                                            | On die termination disabled                                                                                                                                                                                                                                                                                                                                       | 10                                                                                                                                                                  |                                                                                 | RZQ/12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|     | 001b                                                                                            | RZQ/4                                                                                                                                                                                                                                                                                                                                                             | 10                                                                                                                                                                  |                                                                                 | RZQ/8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|     | 010b                                                                                            | RZQ/2                                                                                                                                                                                                                                                                                                                                                             | 110                                                                                                                                                                 |                                                                                 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|     | 011b                                                                                            | RZQ/6                                                                                                                                                                                                                                                                                                                                                             | 111                                                                                                                                                                 | lb                                                                              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 6.4 | T                                                                                               | wite management Dood south This areaifing                                                                                                                                                                                                                                                                                                                         | 41                                                                                                                                                                  | - 4:                                                                            | - francisch - loot data muita mutil tha                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 6:4 |                                                                                                 | rite recovery. Read-write. This specifies                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     |                                                                                                 | ect bank precharge; this is the WR field in                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                     |                                                                                 | 2 . 2 . 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|     |                                                                                                 | values. This field specifies the encodings f                                                                                                                                                                                                                                                                                                                      | or DDR2-10                                                                                                                                                          | 66 W                                                                            | hen  F2x[1, 0]94[Ddr3Mode] = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|     |                                                                                                 | en F2x[1, 0]94[MemClkFreq]=100b.                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                     |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     | <u>Bits</u>                                                                                     | DDR2-1066 definition                                                                                                                                                                                                                                                                                                                                              | Bits                                                                                                                                                                |                                                                                 | R3 definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|     | 000b                                                                                            | Reserved                                                                                                                                                                                                                                                                                                                                                          | 000b                                                                                                                                                                |                                                                                 | erved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|     | 001b                                                                                            | 5 MEMCLK cycles                                                                                                                                                                                                                                                                                                                                                   | 001b                                                                                                                                                                |                                                                                 | EMCLK cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|     | 010b                                                                                            |                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                     |                                                                                 | EN CCL IZ 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|     | 0 - 0 -                                                                                         | 6 MEMCLK cycles                                                                                                                                                                                                                                                                                                                                                   | 010b                                                                                                                                                                | 6 M                                                                             | EMCLK cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|     | 011b                                                                                            | 6 MEMCLK cycles Reserved                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                     |                                                                                 | EMCLK cycles EMCLK cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|     |                                                                                                 | <del>*</del>                                                                                                                                                                                                                                                                                                                                                      | 010b                                                                                                                                                                | 7 M                                                                             | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|     | 011b                                                                                            | Reserved                                                                                                                                                                                                                                                                                                                                                          | 010b<br>011b                                                                                                                                                        | 7 M<br>8 M                                                                      | EMCLK cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|     | 011b<br>100b                                                                                    | Reserved<br>8 MEMCLK cycles                                                                                                                                                                                                                                                                                                                                       | 010b<br>011b<br>100b                                                                                                                                                | 7 M<br>8 M<br>10 N                                                              | EMCLK cycles<br>EMCLK cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|     | 011b<br>100b<br>101b                                                                            | Reserved<br>8 MEMCLK cycles<br>Reserved                                                                                                                                                                                                                                                                                                                           | 010b<br>011b<br>100b<br>101b                                                                                                                                        | 7 M<br>8 M<br>10 N<br>12 N                                                      | EMCLK cycles<br>EMCLK cycles<br>MEMCLK cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| 3:2 | 011b<br>100b<br>101b<br>110b<br>111b<br><b>DrvIm</b>                                            | Reserved 8 MEMCLK cycles Reserved Reserved Reserved Poctrl: drive impedance control. Read-w                                                                                                                                                                                                                                                                       | 010b<br>011b<br>100b<br>101b<br>110b<br>111b<br>vrite. This fie                                                                                                     | 7 M<br>8 M<br>10 M<br>12 M<br>Res                                               | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles erved ecifies impedance of the DRAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 3:2 | 011b<br>100b<br>101b<br>110b<br>111b<br><b>DrvIm</b>                                            | Reserved 8 MEMCLK cycles Reserved Reserved Reserved  PCtrl: drive impedance control. Read-walriver. This field is valid only when F2x[1]                                                                                                                                                                                                                          | 010b<br>011b<br>100b<br>101b<br>110b<br>111b<br>vrite. This fie                                                                                                     | 7 M<br>8 M<br>10 M<br>12 M<br>Res                                               | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles erved ecifies impedance of the DRAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 3:2 | 011b<br>100b<br>101b<br>110b<br>111b<br><b>DrvIm</b>                                            | Reserved 8 MEMCLK cycles Reserved Reserved Reserved Poctrl: drive impedance control. Read-w                                                                                                                                                                                                                                                                       | 010b<br>011b<br>100b<br>101b<br>110b<br>111b<br>vrite. This fie                                                                                                     | 7 M<br>8 M<br>10 M<br>12 M<br>Res                                               | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles erved ecifies impedance of the DRAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 3:2 | 011b<br>100b<br>101b<br>110b<br>111b<br><b>DrvIm</b><br>output o                                | Reserved 8 MEMCLK cycles Reserved Reserved Reserved  PCtrl: drive impedance control. Read-walriver. This field is valid only when F2x[1]                                                                                                                                                                                                                          | 010b<br>011b<br>100b<br>101b<br>110b<br>111b<br>vrite. This fie                                                                                                     | 7 M<br>8 M<br>10 M<br>12 M<br>Res<br>Ild spe<br>Mode                            | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles erved ecifies impedance of the DRAM  ] = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| 3:2 | 011b<br>100b<br>101b<br>110b<br>111b<br><b>DrvIm</b><br>output of <u>Bits</u>                   | Reserved 8 MEMCLK cycles Reserved Reserved Reserved pCtrl: drive impedance control. Read-w driver. This field is valid only when F2x[1 DDR3 definition                                                                                                                                                                                                            | 010b<br>011b<br>100b<br>101b<br>110b<br>111b<br>vrite. This fie<br>1, 0]94[Ddr3]                                                                                    | 7 M<br>8 M<br>10 M<br>12 M<br>Res<br>Id spo<br>Mode                             | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles MEMCLK cycles erved ecifies impedance of the DRAM ] = 1.  q=240 ohms)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| 3:2 | 011b<br>100b<br>101b<br>110b<br>111b<br><b>DrvIm</b><br>output of<br><u>Bits</u><br>00b         | Reserved 8 MEMCLK cycles Reserved Reserved Reserved  PCtrl: drive impedance control. Read-wdriver. This field is valid only when F2x[1 DDR3 definition 40 ohm driver; Ron40 = Rzq/6 (40 ohm                                                                                                                                                                       | 010b<br>011b<br>100b<br>101b<br>110b<br>111b<br>vrite. This fie<br>1, 0]94[Ddr3]                                                                                    | 7 M<br>8 M<br>10 M<br>12 M<br>Res<br>Id spe<br>Mode                             | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles MEMCLK cycles erved ecifies impedance of the DRAM ] = 1.  q=240 ohms) q=240 ohms)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 3:2 | 011b 100b 101b 110b 111b  DrvImp output of Bits 00b 01b                                         | Reserved 8 MEMCLK cycles Reserved Reserved Reserved  PCtrl: drive impedance control. Read-walriver. This field is valid only when F2x[1 DDR3 definition 40 ohm driver; Ron40 = Rzq/6 (40 ohm 34 ohm driver; Ron34 = Rzq/7 (34 ohm                                                                                                                                 | 010b<br>011b<br>100b<br>101b<br>110b<br>111b<br>vrite. This fie<br>1, 0]94[Ddr3]                                                                                    | 7 M<br>8 M<br>10 M<br>12 M<br>Res<br>Id spe<br>Mode                             | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles MEMCLK cycles erved ecifies impedance of the DRAM ] = 1.  q=240 ohms) q=240 ohms)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 3:2 | 011b 100b 101b 110b 1111b  DrvImp output of Bits 00b 01b 10b 11b  BurstC                        | Reserved 8 MEMCLK cycles Reserved Reserved Reserved  PCtrl: drive impedance control. Read-webriver. This field is valid only when F2x[1 DDR3 definition 40 ohm driver; Ron40 = Rzq/6 (40 ohm 34 ohm driver; Ron34 = Rzq/7 (34 ohm Reserved for 30 ohm driver; Ron30 = FReserved  trl: burst length control. Read-write. Sp                                        | 010b 011b 100b 101b 110b 1110b 1111b  vrite. This fie 1, 0]94[Ddr3] n with nomin n with nomin Rzq/8 (30 ohr                                                         | 7 M<br>8 M<br>10 M<br>12 M<br>Res<br>Id spe<br>Mode<br>al Rz<br>al Rz<br>m wit  | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles Memcle cycles Memc |  |  |  |
|     | 011b 100b 101b 110b 1111b  DrvImp output of Bits 00b 01b 10b 11b  BurstC                        | Reserved 8 MEMCLK cycles Reserved Reserved Reserved PCtrl: drive impedance control. Read-walriver. This field is valid only when F2x[1 DDR3 definition 40 ohm driver; Ron40 = Rzq/6 (40 ohm 34 ohm driver; Ron34 = Rzq/7 (34 ohm Reserved for 30 ohm driver; Ron30 = Reserved                                                                                     | 010b 011b 100b 101b 110b 1110b 1111b  vrite. This fie 1, 0]94[Ddr3] n with nomin n with nomin Rzq/8 (30 ohr                                                         | 7 M<br>8 M<br>10 M<br>12 M<br>Res<br>Id spe<br>Mode<br>al Rz<br>al Rz<br>m wit  | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles Memcle cycles Memc |  |  |  |
|     | 011b 100b 101b 110b 111b  DrvImp output of Bits 00b 01b 10b 11b  BurstC to one r                | Reserved 8 MEMCLK cycles Reserved Reserved Reserved  PCtrl: drive impedance control. Read-webriver. This field is valid only when F2x[1 DDR3 definition 40 ohm driver; Ron40 = Rzq/6 (40 ohm 34 ohm driver; Ron34 = Rzq/7 (34 ohm Reserved for 30 ohm driver; Ron30 = FReserved  trl: burst length control. Read-write. Sp                                        | 010b 011b 100b 101b 110b 1110b 1111b vrite. This fie 1, 0]94[Ddr3] n with nomin n with nomin Rzq/8 (30 ohr becifies the nuts with F2x[1                             | 7 M<br>8 M<br>10 M<br>12 M<br>Res<br>Id spo<br>Mode<br>al Rz<br>al Rz<br>m wit  | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles erved ecifies impedance of the DRAM  ] = 1.  q=240 ohms) q=240 ohms) h nominal Rzq=240 ohms)  r of sequential beats of DQ related D[Width128] as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|     | 011b 100b 101b 110b 111b  DrvImp output of Bits 00b 01b 10b 11b  BurstC to one r • If Wid       | Reserved 8 MEMCLK cycles Reserved Reserved Reserved PCtrl: drive impedance control. Read-welriver. This field is valid only when F2x[1 DDR3 definition 40 ohm driver; Ron40 = Rzq/6 (40 ohm 34 ohm driver; Ron34 = Rzq/7 (34 ohm Reserved for 30 ohm driver; Ron30 = Reserved  trl: burst length control. Read-write. Spead or write command. This field interact | 010b<br>011b<br>100b<br>101b<br>110b<br>111b<br>vrite. This fie<br>1, 0]94[Ddr3]<br>a with nomin<br>Rzq/8 (30 ohr<br>becifies the nuts with F2x[1<br>1 to 00b (8-be | 7 M<br>8 M<br>10 M<br>12 M<br>Res<br>Id spe<br>Mode<br>al Rz<br>al Rz<br>an wit | EMCLK cycles EMCLK cycles MEMCLK cycles MEMCLK cycles erved ecifies impedance of the DRAM  ] = 1.  q=240 ohms) q=240 ohms) h nominal Rzq=240 ohms)  r of sequential beats of DQ related D[Width128] as follows: rst length; 64-byte access).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |

# F2x[1, 0]88 DRAM Timing Low Register

Reset: FF00 0000h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming

information about DCT configuration registers.

| Bits  | Descrip     | otion                    |                                       |            |                                                |
|-------|-------------|--------------------------|---------------------------------------|------------|------------------------------------------------|
| 31:24 | MemC        | lkDis: MEMCLK            | disable. Read-write. 1=D              | isable     | e the MEMCLK. The bits MemClkDis[7:0]          |
|       | are map     | pped to packages as      | follows:                              |            |                                                |
|       | <u>Bit</u>  | Fr2(1207) pin name       | e AM2r2 pin name                      | AN         | 13 pin name                                    |
|       |             | N/A                      | $M[B,A]1\_CLK\_H/L[1]$                |            | B,A]_CLK_H/L[0]                                |
|       |             | N/A                      | $M[B,A]0\_CLK\_H/L[1]$                | _          | B,A]_CLK_H/L[1]                                |
|       |             | $M[B,A]3\_CLK$           | N/A                                   | _          | B,A]_CLK_H/L[2]                                |
|       |             | $M[B,A]2\_CLK$           | N/A                                   |            | B,A]_CLK_H/L[3]                                |
|       |             | M[B,A]1_CLK              | M[B,A]1_CLK_H/L[0]                    | _          | B,A]_CLK_H/L[4]                                |
|       |             | M[B,A]0_CLK              | M[B,A]0_CLK_H/L[0]                    |            | B,A]_CLK_H/L[5]                                |
|       |             | N/A                      | M[B,A]1_CLK_H/L[2]                    |            |                                                |
|       | 7           | N/A                      | $M[B,A]0\_CLK\_H/L[2]$                | ΜĮ         | B,A]_CLK_H/L[7]                                |
|       | Note: F     | 2x88 controls the c      | hannel A memory clock r               | oins a     | nd F2x188 controls the channel B memory        |
|       | clock p     |                          |                                       |            |                                                |
| 23:22 | Trrd: r     | ow to row delay (o       | or RAS to RAS delay). R               | ead-v      | vrite. This specifies the minimum time         |
|       | between     | n activate command       | ls to different chip-select           | banks      | . The definition of this field varies with the |
|       | -           | /pe (F2x[1, 0]94[Dd)     | dr3Mode) and when $F2x$ [             | [1, 0]     | 94[MemClkFreq]=100b to support DDR2-           |
|       | 1066.       |                          |                                       |            |                                                |
|       | <u>Bits</u> | DDR2 definition          | · · · · · · · · · · · · · · · · · · · | <u>its</u> | DDR2-1066/DDR3 definition                      |
|       | 00b         | 2 clocks                 |                                       | 0b         | 4 clocks                                       |
|       | 01b         | 3 clocks                 |                                       | 1b         | 5 clocks                                       |
|       | 10b         | 4 clocks                 |                                       | 0b         | 6 clocks                                       |
|       | 11b         | 5 clocks                 |                                       | 1b         | 7 clocks                                       |
| 21:20 |             | _                        | _                                     |            | minimum time from the last data write until    |
|       |             |                          |                                       |            | , $0]94[Ddr3Mode]=0$ and when $F2x[1,$         |
|       |             | _                        |                                       |            | and bit 20 becomes part of the Trc field       |
|       |             |                          | d DDR3 see F2x[1, 0]84['              | Iwrj.      |                                                |
|       | Bits<br>00b | DDR2 definition 3 clocks |                                       |            |                                                |
|       | 00b<br>01b  | 4 clocks                 |                                       |            |                                                |
|       | 10b         | 5 clocks                 |                                       |            |                                                |
|       | 11b         | 6 clocks                 |                                       |            |                                                |
| 19:16 |             |                          | l-write. This specifies the           | minir      | num time from and activate command to          |
| DDR2  |             |                          |                                       |            | I to the same chip-select bank. This size and  |
|       |             |                          |                                       |            | ]94[Ddr3Mode]) and when F2x[1,                 |
| 20:16 |             |                          | to support DDR2-1066.                 | L ) "      | 2/ 1/2                                         |
| DDR2  | Bits        | DDR2 definition          |                                       | <u>its</u> | DDR2-1066/DDR3 definition                      |
| 1066/ | 0h          | 11 clocks                |                                       | 0h         | 11 clocks                                      |
| DDR3  | 1h          | 12 clocks                | 0                                     | 1h         | 12 clocks                                      |
|       | <br>Fh      | <br>26 clocks            |                                       | Fh         | <br>42 clocks                                  |
|       | 1.11        | 20 CIOCKS                | 1.                                    | L 11       | 72 CIUCNS                                      |

|       | 1                                                                                                                                                                                                     |                                             |             |                                              |  |  |  |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-------------|----------------------------------------------|--|--|--|--|--|
| 15:12 | Tras: row active strobe. Read-write. This specifies the minimum time from an activate command to a precharge command, both to the same chip-select bank. The definition of this field varies with the |                                             |             |                                              |  |  |  |  |  |
|       |                                                                                                                                                                                                       |                                             |             |                                              |  |  |  |  |  |
|       |                                                                                                                                                                                                       | pe ( $F2x[1, 0]94[Ddr3Mode]$ ) and when F   | [2x[1, 0]]  | 94[MemClkFreq]=100b to support DDR2-         |  |  |  |  |  |
|       | 1066.                                                                                                                                                                                                 |                                             |             |                                              |  |  |  |  |  |
|       | <u>Bits</u>                                                                                                                                                                                           | DDR2 definition                             | <u>Bits</u> | DDR2-1066/DDR3 definition                    |  |  |  |  |  |
|       | 0h                                                                                                                                                                                                    | Reserved                                    | 0h          | 15 clocks                                    |  |  |  |  |  |
|       | 1h                                                                                                                                                                                                    | Reserved                                    | 1h          | 16 clocks                                    |  |  |  |  |  |
|       | 2h                                                                                                                                                                                                    | 5 clocks                                    | 2h          | 17 clocks                                    |  |  |  |  |  |
|       | 3h                                                                                                                                                                                                    | 6 clocks                                    | 3h          | 18 clocks                                    |  |  |  |  |  |
|       |                                                                                                                                                                                                       |                                             | •••         |                                              |  |  |  |  |  |
|       | Fh                                                                                                                                                                                                    | 18 clocks                                   | Fh          | 30 clocks                                    |  |  |  |  |  |
| 11:10 | Trtp: re                                                                                                                                                                                              | ead to precharge time. Read-write. Read     | CAS to      | Precharge. This time is expected to be       |  |  |  |  |  |
|       | approxii                                                                                                                                                                                              | mately 7.5ns. It measures the earliest time | e a page    | can be closed after having been read.        |  |  |  |  |  |
|       | Satisfyir                                                                                                                                                                                             | ng this parameter ensures read data is not  | lost due    | to a premature precharge. This size and      |  |  |  |  |  |
|       | definitio                                                                                                                                                                                             | on of this field varies with the DDR type,  | F2x[1, 0]   | )]94[Ddr3Mode].                              |  |  |  |  |  |
|       | <u>Bits</u>                                                                                                                                                                                           | DDR2 definition                             | <u>Bits</u> | DDR3 definition                              |  |  |  |  |  |
|       | 0xb                                                                                                                                                                                                   | 2 clocks for burst length of 32 bytes       | 00b         | 4 clocks for burst length of 32 or 64 bytes  |  |  |  |  |  |
|       |                                                                                                                                                                                                       | 4 clocks for burst length of 64 bytes       | 01b         | 5 clocks for burst length of 32 or 64 bytes  |  |  |  |  |  |
|       | 1xb                                                                                                                                                                                                   | 3 clocks for burst length of 32 bytes       | 10b         | 6 clocks for burst length of 32 or 64 bytes  |  |  |  |  |  |
|       |                                                                                                                                                                                                       | 5 clocks for burst length of 64 bytes       | 11b         | 7 clocks for burst length of 32 or 64 bytes  |  |  |  |  |  |
| 9:7   | Trp: ro                                                                                                                                                                                               | w precharge time. Read-write. This spec     | ifies the   | minimum time from a precharge command        |  |  |  |  |  |
|       | to an act                                                                                                                                                                                             | tivate command or auto-refresh command      | d, both to  | o the same bank. This size and definition of |  |  |  |  |  |
|       | this field                                                                                                                                                                                            | d varies with the DDR type $(F2x[1, 0]94[$  | Ddr3Mo      | ode]) and when F2x[1,                        |  |  |  |  |  |
|       | 0]94[Me                                                                                                                                                                                               | emClkFreq]=100b to support DDR2-1066        | 5.          |                                              |  |  |  |  |  |
|       | <u>Bits</u>                                                                                                                                                                                           | DDR2 definition                             | <u>Bits</u> | DDR2-1066/DDR3 definition                    |  |  |  |  |  |
|       | 00xb                                                                                                                                                                                                  | 3 clocks                                    | 000b        | 5 clocks                                     |  |  |  |  |  |
|       | 01xb                                                                                                                                                                                                  | 4 clocks                                    | 001b        | 6 clocks                                     |  |  |  |  |  |
|       | 10xb                                                                                                                                                                                                  | 5 clocks                                    |             |                                              |  |  |  |  |  |
|       | 11xb                                                                                                                                                                                                  | 6 clocks                                    | 110b        | 11 clocks                                    |  |  |  |  |  |
|       |                                                                                                                                                                                                       |                                             | 111b        | 12 clocks                                    |  |  |  |  |  |
|       | 1                                                                                                                                                                                                     |                                             |             |                                              |  |  |  |  |  |

|   | 6:4 | Trcd: RAS                                 | to CAS delay. Read-write. T                  | This specifies the t                          | ime from an activate command to a            |   |
|---|-----|-------------------------------------------|----------------------------------------------|-----------------------------------------------|----------------------------------------------|---|
|   |     | read/write                                | command, both to the same ba                 | ank. This size and                            | definition of this field varies with the DDF | Ł |
|   |     | type (F2x[1                               | , 0]94[Ddr3Mode]) and when                   | n F2x[1, 0]94[Mer                             | mClkFreq]=100b to support DDR2-1066.         |   |
|   |     | Bits D                                    | DR2 definition                               | <u>Bits</u>                                   | DDR2-1066/DDR3 definition                    |   |
|   |     | x00b 3                                    | clocks                                       | 000b                                          | 5 clocks                                     |   |
|   |     | x01b 4                                    | clocks                                       | 001b                                          | 6 clocks                                     |   |
|   |     | x10b 5                                    | clocks                                       |                                               |                                              |   |
|   |     | x11b 6                                    | clocks                                       | 110b                                          | 11 clocks                                    |   |
|   |     |                                           |                                              | 111b                                          | 12 clocks                                    |   |
| Ī | 3:0 | Tcl: CAS l                                | atency. Read-write. This spec                | cifies the time from                          | n the CAS assertion for a read cycle until   |   |
|   |     | data return                               | (from the perspective of the I               | DRAM devices). F                              | For DDR2, write CAS latency is always        |   |
|   |     | read CAS 1                                | atency minus 1. The DCT adj                  | usts these latencie                           | s appropriately for registered DIMMs. The    | e |
|   |     | definition of                             | of this field varies with the DI             | OR type $(F2x[1, 0]$                          | 94[Ddr3Mode]).                               |   |
|   |     | D:40                                      |                                              |                                               |                                              |   |
|   |     | <u>Bits</u>                               | DDR2 definition                              | <u>Bits</u>                                   | DDR3 definition                              |   |
|   |     | 0000b                                     | DDR2 definition<br>Reserved                  | <u>Bits</u><br>0000b                          | DDR3 definition 4 clocks                     |   |
|   |     |                                           |                                              |                                               | ·                                            |   |
|   |     | 0000b                                     | Reserved                                     | 0000b                                         | 4 clocks                                     |   |
|   |     | 0000b<br>0001b                            | Reserved<br>Reserved                         | 0000b<br>0001b                                | 4 clocks<br>5 clocks                         |   |
|   |     | 0000b<br>0001b<br>0010b                   | Reserved<br>Reserved<br>3 clocks             | 0000b<br>0001b<br>0010b                       | 4 clocks<br>5 clocks                         |   |
|   |     | 0000b<br>0001b<br>0010b<br>0011b          | Reserved Reserved 3 clocks 4 clocks          | 0000b<br>0001b<br>0010b                       | 4 clocks 5 clocks 6 clocks                   |   |
|   |     | 0000b<br>0001b<br>0010b<br>0011b<br>0100b | Reserved Reserved 3 clocks 4 clocks 5 clocks | 0000b<br>0001b<br>0010b<br><br>0111b<br>1000b | 4 clocks 5 clocks 6 clocks 11 clocks         |   |

# F2x[1, 0]8C DRAM Timing High Register

Reset: 0000 0000h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

| Bits  | Description                                                                                                                                                  |                                                              |                                                       |  |  |  |  |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------|--|--|--|--|--|--|--|
| 31:29 | Trfc3: auto-                                                                                                                                                 | refresh row cycle time for logi                              | cal DIMM 3. Read-write. See Trfc0.                    |  |  |  |  |  |  |  |
| 28:26 | Trfc2: auto-                                                                                                                                                 | refresh row cycle time for logi                              | cal DIMM 2. Read-write. See Trfc0.                    |  |  |  |  |  |  |  |
| 25:23 | Trfc1: auto-                                                                                                                                                 | refresh row cycle time for logi                              | cal DIMM 1. Read-write. See Trfc0.                    |  |  |  |  |  |  |  |
| 22:20 | time from an DIMM numbrecommende                                                                                                                             | auto-refresh command to an actors are specified by [The DRAM | DDR3 definition Reserved 90 ns (all speeds, 512 Mbit) |  |  |  |  |  |  |  |
|       | 110b-111b                                                                                                                                                    | Reserved                                                     | Reserved                                              |  |  |  |  |  |  |  |
| 19    | Reserved.                                                                                                                                                    |                                                              |                                                       |  |  |  |  |  |  |  |
| 18    | <b>DisAutoRefresh: disable automatic refresh</b> . Read-write. 1=Automatic refresh is disabled. This is sometimes useful during electrical characterization. |                                                              |                                                       |  |  |  |  |  |  |  |

| 17:1 | 6 Tref: r                                                                                             | <b>Tref:</b> refresh rate. Read-write. This specifies the average time between refresh requests to all DRAM |             |           |                                  |
|------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-------------|-----------|----------------------------------|
|      | devices                                                                                               | devices.                                                                                                    |             |           |                                  |
|      | <u>Bits</u>                                                                                           | <u>Definition</u>                                                                                           |             |           |                                  |
|      | 00b                                                                                                   | Undefined behavior.                                                                                         |             |           |                                  |
|      | 01b                                                                                                   | Reserved                                                                                                    |             |           |                                  |
|      | 10b                                                                                                   | Every 7.8 microseconds                                                                                      |             |           |                                  |
|      | 11b                                                                                                   | Every 3.9 microseconds                                                                                      |             |           |                                  |
| 15:1 |                                                                                                       | Trdrd[1:0]: read to read timing. Read-write. Trdrd specifies the minimum number of cycles from              |             |           |                                  |
|      |                                                                                                       | the last clock of virtual CAS of a first read-burst operation to the clock in which CAS is asserted for a   |             |           |                                  |
|      |                                                                                                       | following read-burst operation that is to a different chip select than the first read-burst operation. If   |             |           | •                                |
|      |                                                                                                       | consecutive reads involve an ODT change, time must be inserted between the reads to account for (1)         |             |           |                                  |
|      |                                                                                                       | ound timing and (2) termination timing. Th                                                                  |             | _         |                                  |
|      | _                                                                                                     | ify a 4-bit value, $Trdrd[3:0]$ , when $F2x[1, 0]$                                                          | 0]94[Dd     | r3Mode]   | <b>=1.</b>                       |
|      | <u>Bits</u>                                                                                           | DDR2 definition                                                                                             | <u>Bits</u> |           | <u>definition</u>                |
|      | 00b                                                                                                   | 2 clocks                                                                                                    |             | 2 clock   |                                  |
|      | 01b                                                                                                   | 3 clocks                                                                                                    | 0001b       | 3 clock   | S                                |
|      | 10b                                                                                                   | 4 clocks                                                                                                    |             |           |                                  |
|      | 11b                                                                                                   | 5 clocks                                                                                                    |             | 10 cloc   |                                  |
|      |                                                                                                       |                                                                                                             |             |           | Reserved                         |
|      |                                                                                                       | tion [The Trdrd (Read to Read Timing)] 2                                                                    | .8.7.4.1    | for infor | mation on how to program this    |
|      | field.                                                                                                |                                                                                                             |             |           |                                  |
| 13:1 | 2 <b>Twrwr[1:0]: write to write timing</b> . Read-write. Twrwr specifies the minimum number of cycles |                                                                                                             |             |           |                                  |
|      | from the last clock of virtual CAS of the first write-burst operation to the clock in which CAS is    |                                                                                                             |             |           |                                  |
|      | asserted for a following write-burst operation that changes the enabled terminator. If consecutive    |                                                                                                             |             |           |                                  |
|      | writes involve an ODT change, then time must be inserted between them to account for termination      |                                                                                                             |             |           |                                  |
|      | timing on DDR devices. This field along with F2x[1, 0]78[Twrwr[3:2]] combine to specify a 4-bit       |                                                                                                             |             |           |                                  |
|      | value, $Twrwr[3:0]$ , when $F2x[1, 0]94[Ddr3Mode]=1$ .                                                |                                                                                                             |             |           |                                  |
|      | <u>Bits</u>                                                                                           | DDR2 definition                                                                                             | <u>Bits</u> |           | DDR3 definition                  |
|      | 00b                                                                                                   | 1 clock                                                                                                     |             | - 0001b   | Reserved                         |
|      | 01b                                                                                                   | 2 clocks                                                                                                    | 0010b       |           | 3 clocks                         |
|      | 10b                                                                                                   | 3 clocks                                                                                                    |             |           |                                  |
|      | 11b                                                                                                   | 4 clocks                                                                                                    | 1001b       |           | 10 clocks                        |
|      |                                                                                                       |                                                                                                             |             |           | Reserved                         |
|      |                                                                                                       | ction [The Twrwr (Write to Write Timing)                                                                    | ] 2.8.7.4   | .2 for in | formation on how to program this |
|      | field.                                                                                                |                                                                                                             |             |           |                                  |

| 11:1 | 10 <b>Twrrd[1:0]: write to read DIMM termination turnaround</b> . Read-write. This specifies the                  |
|------|-------------------------------------------------------------------------------------------------------------------|
|      | minimum number of cycles from the last clock of virtual CAS of the first write operation to the clock             |
|      | in which CAS is asserted for a following read operation involving a memory ODT change on a                        |
|      | channel with multiple DIMMs. Time may need to be inserted between these operations to avoid the                   |
|      | possibility that there is an overlap of the on die termination timing of the DIMMs. <sup>2</sup> This field along |
|      | with F2x[1, 0]78[Twrrd[3:2]] combine to specify a 4-bit value, Twrrd[3:0], when F2x[1,                            |
|      | 0]94[Ddr3Mode]=1.                                                                                                 |

| <u>Bits</u> | DDR2 definition | <u>Bits</u>   | DDR3 definition |
|-------------|-----------------|---------------|-----------------|
| 00b         | 1 clock         | 0000b         | Reserved        |
| 01b         | 2 clocks        | 0001b         | Reserved        |
| 10b         | 3 clocks        | 0010b         | 2 clocks        |
| 11b         | 4 clocks        | •••           |                 |
|             |                 | 1010b         | 10 clocks       |
|             |                 | 1011b - 1111b | Reserved        |

#### Notes:

1. For multiple DDR3 DIMMs on a channel, all write operations that are followed by a read require an ODT change and thus the DCT always applies Twrrd.

See section [The Twrrd (Write to Read DIMM Termination Turn-around)] 2.8.7.4.3 for information on how to program this field.

9:8 **Twtr: internal DRAM write to read command delay.** Read-write. This specifies the minimum number of cycles from a write operation to a read operation, both to the same chip-select. This is measured from the rising clock edge following last non-masked data strobe of the write to the rising clock edge of the next read command. The definition of this field varies with the DDR type, F2x[1, 0]94[Ddr3Mode] and when F2x[1, 0]94[MemClkFreq]=100b to support DDR2-1066.

| <b>Bits</b> | DDR2 definition | Bits | DDR2-1066 definition/DDR3 definition |
|-------------|-----------------|------|--------------------------------------|
| 00b         | Reserved        | 00b  | 4 clocks                             |
| 01b         | 1 clocks        | 01b  | 5 clocks                             |
| 10b         | 2 clocks        | 10b  | 6 clocks                             |
| 11b         | 3 clocks        | 11b  | 7 clocks                             |

7:4 **TrwtTO: read to write turnaround for data, DQS contention**. Read-write. This specifies the minimum number of cycles from the last clock of virtual CAS of a first read operation to the clock in which CAS is asserted for a following write operation. Time may need to be inserted to ensure there is no bus contention on bidirectional pins.

| <u>Bits</u> | DDR2 definition  | <u>Bits</u> | DDR3 definition |
|-------------|------------------|-------------|-----------------|
| 0000b       | Reserved         | 0000b       | Reserved        |
| 0001b       | 3 clocks         | 0001b       | 3 clocks        |
| 0010b       | 4 clocks         | 0010b       | 4 clocks        |
|             |                  |             |                 |
| 0111b       | 9 clocks         | 1111b       | 17 clocks       |
| 1000b       | - 1111b Reserved |             |                 |

See section [The TrwtTO (Read-to-Write Turnaround for Data, DQS Contention)] 2.8.7.4.4 for information on how to program this field.

| 3:0 | TrwtWB: read to write turnaround for opportunistic write bursting. Read-write. This specifies             |             |                 |
|-----|-----------------------------------------------------------------------------------------------------------|-------------|-----------------|
|     | the minimum number of cycles from the last virtual CAS of a first read operation to the CAS of a          |             |                 |
|     | following write operation. The purpose of this field is to hold off write operations until several cycles |             |                 |
|     | have elapsed without a read cycle; this may result in performance benefits.                               |             |                 |
|     | Bits DDR2 definition                                                                                      | <u>Bits</u> | DDR3 definition |
|     | 0000b 3 clocks                                                                                            | 0000b       | 3 clocks        |
|     | 0001b 4 clocks                                                                                            | 0001b       | 4 clocks        |
|     |                                                                                                           | •••         |                 |
|     | 0111b 10 clocks                                                                                           | 1111b       | 18 clocks       |
|     | 1000b - 1111b Reserved                                                                                    |             |                 |
|     | See section [The TrwtWB (Read-to-Write Turnaround for Opportunistic Write Bursting)] 2.8.7.4.5            |             |                 |
|     | for information on how to program this field.                                                             |             |                 |

# F2x[1, 0]90 DRAM Configuration Low Register

Reset: 0000 0000h, except bit 16 (see below). See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:24 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 23    | <b>ForceAutoPchg: force auto precharging</b> . Read-write. 1=Force auto-precharge cycles with every read or write command. This may be preferred in situations where power savings is favored over performance.                                                                                                                                                                                                                                                                                                                  |  |  |
| 22:21 | IdleCycLowLimit: idle cycle low limit. Read-write. This specifies the number of MEMCLK cycles a page is allowed to be open before it may be closed by the dynamic page close logic. This field is ignored if F2x[1, 0]90[DynPageCloseEn] = 0.  Bits Definition 00b 16 clocks 01b 32 clocks 10b 64 clocks 11b 96 clocks                                                                                                                                                                                                           |  |  |
| 20    | <b>DynPageCloseEn: dynamic page close enable</b> . Read-write. 1=The DRAM controller dynamically determines when to close open pages based on the history of that particular page and F2x[1, 0]90[IdleCycLowLimit]. 0=Any open pages not auto-precharged by the DRAM controller are automatically closed after 128 clocks of inactivity.                                                                                                                                                                                         |  |  |
| 19    | <b>DimmEccEn: DIMM ECC enable</b> . Read-write. 1=ECC checking is capable of being enabled for all DIMMs on the DRAM controller (through F3x44[DramEccEn]). This bit should not be set unless all populated DIMMs support ECC check bits. 0=ECC checking is disabled on the DRAM controller.                                                                                                                                                                                                                                     |  |  |
| 18    | <b>PendRefPayback: pending refresh payback</b> . Read-write. 1=The DRAM controller executes all pending refresh commands before entering the self refresh state. 0=The controller enters the self refresh state regardless of the number of pending refreshes.                                                                                                                                                                                                                                                                   |  |  |
| 17    | EnterSelfRef: enter self refresh command. Read, write-1-only. 1=The DRAM controller places the DRAMs into self refresh mode. The DRAM interface is tristated 1 MEMCLK after the self refresh command is issued to the DRAMs. Once entered, the DRAM interface must remain in self refresh mode for a minimum of 5 MEMCLKs. This bit is read as a 1 while the enter-self-refresh command is executing; it is read as 0 at all other times. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use this bit. |  |  |

| 16    | <b>UnbuffDimm: unbuffered DIMM</b> . Read-write or read-only, depending on the product. Reset: value varies based on product. 1=The DRAM controller is connected to unbuffered DIMMs. 0=The DRAM controller is connected to registered DIMMs. •                                                                                                                                                                                                                                                       |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15:12 | <b>X4Dimm: x4</b> ( <b>by 4</b> ) <b>DIMMs</b> . Read-write. Each of these bits specifies whether the corresponding logical DIMM (as defined by [The DRAM CS Base Address Registers] F2x[1, 0][5C:40]) is a x4 DIMM or not. The DRAM controller requires this information to make decisions about DIMM signaling. Bit[12] corresponds to logical DIMM 0, bit[13] corresponds to logical DIMM 1, etc. 1=x4 DIMM present. 0=x4 DIMM not present.                                                        |  |
| 11    | Width128: width of DRAM interface in 128-bit mode. Read-write. 1=The DRAM controller interface is 2 DIMMs wide. 0=The DRAM controller interface is 1 DIMM wide.                                                                                                                                                                                                                                                                                                                                       |  |
| 10    | <b>BurstLength32: DRAM burst length set for 32 bytes</b> . Read-write. This specifies the burst length of DRAM accesses and, as a result, the number of data bytes exchanged in each access. 1=32-byte mode. 0=64-byte mode. 32-byte mode may be preferred in platforms that include graphics controllers that generate a lot of 32-byte system memory accesses. 32-byte mode is not supported when the DRAM interface is 128 bits wide; so this bit interacts with F2x[1, 0]90[Width128] as follows: |  |
|       | BurstLength32 Width128 Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|       | 0 8-beat burst length; 64-byte accesses<br>0 1 4-beat burst length; 64-byte accesses                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|       | 1 0 4-beat burst length; 32-byte accesses                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|       | 1 Illegal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|       | BurstLength32 is undefined when F2x[1, 0]94[Ddr3Mode]=1.                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 9     | <b>SelfRefRateEn: faster self refresh rate enable</b> . Read-write. 1=Enables high temperature (two times normal) self refresh rate. This bit is reflected in the EMRS(2) command to the DRAM devices. This bit is undefined when F2x[1, 0]94[Ddr3Mode]=1.                                                                                                                                                                                                                                            |  |
| 8     | <b>ParEn: parity enable</b> . Read-write. 1=Enables address parity computation output, PAR, and enables the parity error input, ERR. This bit is valid only when UnbuffDimm=0.                                                                                                                                                                                                                                                                                                                        |  |
| 7     | <b>DramDrvWeak: DRAM drivers weak mode</b> . Read-write. This specifies the programming of the DRAM data drive strength mode when the EMRS command is issued during DRAM initialization (F2x[1, 0]90[InitDram]). 1=Weak drive strength mode. 0=Normal drive strength mode. This bit is undefined when F2x[1, 0]94[Ddr3Mode]=1.                                                                                                                                                                        |  |
| 6     | <b>DisDqsBar: disable low differential DQS pin</b> . Read write. This specifies the programming of the DRAM low-DQS (of the differential pairs) signal enable when the EMRS command is issued during DDR2 DRAM initialization (F2x[1, 0]90[InitDram]). 1=Disable low DQS pins. 0=Enable low DQS pins. This bit is undefined when F2x[1, 0]94[Ddr3Mode]=1.                                                                                                                                             |  |
| 5:4   | DramTerm: DRAM termination. Read-write. This specifies the programming of the DRAM termination value (Rtt) when the EMRS command is issued during DDR2 DRAM initialization (F2x[1, 0]90[InitDram]). This field is undefined when F2x[1, 0]94[Ddr3Mode]=1. For DDR3 termination values, see F2x[1, 0]84[DramTerm].  Bits DDR2 definition  Ob On die termination disabled.  O1b 75 ohms.  10b 150 ohms.  11b 50 ohms.                                                                                   |  |

| 3:2 | PllLockTime: registered DIMM PLL lock time. Read-write. This specifies registered DIMM PLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|     | lock time as follows when F2x[1, 0]94[Ddr3Mode]=0:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|     | Bits Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|     | 00b 15us                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|     | 01b 6us                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|     | 1xb Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 1   | <b>ExitSelfRef:</b> exit self refresh (after suspend to RAM or for DRAM training) command. Read, write-1-only. Writing a 1 to this bit causes the DRAM controller to bring the DRAMs out of self refresh mode. This command should be executed by BIOS when returning from the suspend to RAM state, after the DRAM controller configuration registers are properly initialized, or when self refresh is used during DRAM training. See section 2.8.7.8.2 [DDR2 DRAM Training] on page 90. This bit is read as 1 while the exit-self-refresh command is executing; it is read as 0 at all other times. Note: this bit should not be set if the DCT is disabled.                                                                                             |  |  |
| 0   | <b>InitDram: initialize DRAM</b> . Read, write-1-only. Writing a 1 to this bit causes the DRAM controller to execute the DRAM initialization sequence described by the JEDEC specification. This command should be executed by BIOS when booting from an unpowered state (ACPI S4, S5 or G3; not S3, suspend to RAM), after the DRAM controller configuration registers are properly initialized. This bit is read as a 1 while the DRAM initialization sequence is executing; it is read as 0 at all other times. When this bit is written to a 1, the new value of the other fields in this register that are updated concurrently are used in the initialization sequence. See section 2.8.7.5 [DRAM Device Initialization] on page 78 for more details. |  |  |

# F2x[1, 0]94 DRAM Configuration High Register

Reset: 0008 0200h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

| Bits  | Description                                                                                     |                                |             |                                  |
|-------|-------------------------------------------------------------------------------------------------|--------------------------------|-------------|----------------------------------|
| 31:28 | FourActWindow[3:0]: four bank activate window. Read-write. FourActWindow specifies the          |                                |             |                                  |
|       | rolling tFAW wind                                                                               | ow during which no more than 4 | banks in an | 8-bank device are activated, per |
|       | JEDEC DDR2 and                                                                                  | DDR3 specifications. The meani | ng of Four  | ActWindow varies with F2x[1,     |
|       | 0]94[Ddr3Mode],                                                                                 | and when F2x[1, 0]94[MemClkF1  | eq]=100b t  | to support DDR2-1066 as follows: |
|       | <u>Bits</u>                                                                                     | DDR2 window size               | <u>Bits</u> | DDR2-1066/DDR3 window size       |
|       | 0000b                                                                                           | No tFAW window restriction.    | 0000b       | No tFAW window restriction.      |
|       | 0001b                                                                                           | 8 MEMCLK cycles.               | 0001b       | 16 MEMCLK cycles.                |
|       | 0010b                                                                                           | 9 MEMCLK cycles.               | 0010b       | 18 MEMCLK cycles.                |
|       | •••                                                                                             |                                |             |                                  |
|       | 1101b                                                                                           | 20 MEMCLK cycles.              | 1001b       | 32 MEMCLK cycles.                |
|       | 1110b - 1111b                                                                                   | Reserved                       | 1010b -     | 1111b Reserved                   |
|       | See section 2.8.7.4.6 [FourActWindow (Four Bank Activate Window or tFAW)] on page 72 for infor- |                                |             |                                  |
|       | mation on how to j                                                                              | program this field.            |             |                                  |

| 27:24 | DcqBypassMax: DRAM controller queue bypass maximum. Read-write. The DRAM controller                                                                                                                |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|       | arbiter normally allows transactions to pass other transactions in order to optimize DRAM bandwidth. This field specifies the maximum number of times that the oldest memory-access request in the |  |  |
|       | DRAM controller queue may be bypassed before the arbiter decision is overridden and the oldest                                                                                                     |  |  |
|       | memory-access request is serviced instead. For optimal performance, it is recommended that this field                                                                                              |  |  |
|       | be programmed to Fh.                                                                                                                                                                               |  |  |
|       | Bits Definition                                                                                                                                                                                    |  |  |
|       | Oh No bypass; the oldest request is never bypassed.                                                                                                                                                |  |  |
|       | 1h The oldest request may be bypassed no more than 1 time.                                                                                                                                         |  |  |
|       | Fh The oldest request may be bypassed no more than 15 times.                                                                                                                                       |  |  |
| 23    | <b>ProcOdtDis: processor on-die termination disable</b> . Read-write. 1=The processor-side on-die                                                                                                  |  |  |
|       | termination is disabled. 0=Processor-side on-die termination enabled. See F2x[1, 0]9C_x00[ProcOdt] for ODT definitions.                                                                            |  |  |
| 22    | BankSwizzleMode: bank swizzle mode. Read-write. 1=Remaps the DRAM device bank address                                                                                                              |  |  |
|       | bits as a function of normalized physical address bits. Each of the bank address bits, as specified in                                                                                             |  |  |
|       | Table 45 of F2x[1, 0]80, are remapped as follows:                                                                                                                                                  |  |  |
|       | Define X as a bank address bit (e.g., X=15 if the bank bit is specified to be address bit 15).                                                                                                     |  |  |
|       | X' = X, if the DCT is in 64-bit unganged mode, or $X+1$ in 128-bit ganged mode.                                                                                                                    |  |  |
|       | Define S(n) as the state of address bit n (0 or 1) and B as the remapped bank address bit. Then,                                                                                                   |  |  |
|       | $B = S(X') ^ S(X' + 2) ^ S(X' + 4)$ ; for a 4-bank DRAM.                                                                                                                                           |  |  |
|       | $B = S(X') ^ S(X' + 3) ^ S(X' + 6)$ ; for an 8-bank DRAM.                                                                                                                                          |  |  |
|       | For example, encoding 02h of Table 45 would be remapped from bank[1:0]={A14, A13} to the                                                                                                           |  |  |
|       | following for a 64-bit DCT: Bank[1:0] = {A14 ^ A16 ^ A18, A13 ^ A15 ^ A17}.                                                                                                                        |  |  |
|       | For example, if $[18:13]=110001b$ , then Bank $[1:0] = \{0 \land 0 \land 1, 1 \land 0 \land 1\} = \{1, 0\}$ .                                                                                      |  |  |
|       | BIOS should set this bit to 1b.                                                                                                                                                                    |  |  |
| 21    | FreqChgInProg: frequency change in progress. Read-only. 1=A MEMCLK frequency change is in                                                                                                          |  |  |
| 21    | progress. The DDR phy asserts this bit when it is in the process of locking the PLL. BIOS should not                                                                                               |  |  |
|       | program the phy registers while this bit is set. 0=DRAM-interface commands can be sent to the phy.                                                                                                 |  |  |
| 20    | SlowAccessMode: slow access mode (a.k.a. 2T mode). Read-write. 1=One additional MEMCLK of                                                                                                          |  |  |
|       | setup time is provided on all DRAM address and control signals (not including CS, CKE, and ODT);                                                                                                   |  |  |
|       | i.e., these signals are driven for two MEMCLK cycles rather than one. 0=DRAM address and control                                                                                                   |  |  |
|       | signals are driven for one MEMCLK cycle. 2T mode may be needed in order to meet electrical requirements of certain DIMM speed and loading configurations.                                          |  |  |
| 19    |                                                                                                                                                                                                    |  |  |
| 19    | <b>DcqArbBypassEn: DRAM controller arbiter bypass enable</b> . Revision A: Reserved. Revision B: Read-write. 0=DCQ entries are always passed through the arbiter. 1=Bypass the arbitration logic   |  |  |
|       | when there is only one entry in the DRAM controller queue entry.                                                                                                                                   |  |  |
| 18    | FourRankRDimm: four rank registered DIMM connected. Read-write. 1=Four-rank registered                                                                                                             |  |  |
|       | DIMMs are connected to the channel. In this mode, only two DIMMs per channel are supported. See                                                                                                    |  |  |
|       | F2x[1, 0][5C:40] for configuration information in this mode.                                                                                                                                       |  |  |
| 17    | Reserved.                                                                                                                                                                                          |  |  |

| 16    | PowerDownMode: power down mode. Read-write. This specifies how a DIMM or group of DIMMs enters power down mode, when enabled by F2x[1, 0]94[PowerDownEn]. A DIMM enters power down mode when the DCT deasserts the CKE pin to that DIMM. The command and address signals tristate one MEMCLK after CKE deasserts. There are two CKE pins per DRAM channel. For each channel:  Bit Description  Ob Channel CKE control mode. The DRAM channel is placed in power down mode when all                                                       |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|       | chip selects associated with the channel are idle. Both CKE pins for the channel operate in lock step, in terms of placing the channel DIMMs in power down mode.  - CKE0 is connected to CS0, CS1, CS4, CS5 (the even DIMMs);  - CKE1 is connected to CS2, CS3, CS6, CS7 (the odd DIMMs).                                                                                                                                                                                                                                                |  |  |
|       | <ul> <li>Chip select CKE control mode. A chip select or pair of chip selects is placed in power down mode when no transactions are pending for the chip select(s).</li> <li>CKE0 is associated with CS0 in 2-rank systems.</li> <li>CKE1 is associated with CS1 in 2-rank systems.</li> </ul>                                                                                                                                                                                                                                            |  |  |
| 15    | <b>PowerDownEn: power down mode enable</b> . Read-write. 1=Power down mode is enabled. When in power down mode, if all pages of the DRAMs associated with a CKE pin are closed, then these parts are placed in power down mode. Only pre-charge power down mode is supported, not active power down mode.                                                                                                                                                                                                                                |  |  |
| 14    | <b>DisDramInterface: disable the DRAM interface</b> . Read-write. 1=The DRAM controller is disabled and the DRAM interface is placed into a low power state. This bit must be set if there are no DIMMs connected to the DCT.                                                                                                                                                                                                                                                                                                            |  |  |
| 13    | <b>DisSimulRdWr: disable simultaneous read and write</b> . Read-write. 1=Disable the possibility of simultaneous reads from one DCT and writes to the other DCT. If data-integrity issues result from the additional electrical noise present when simultaneous read and write activity occurs, then this bit may be set at the cost of some amount of performance. This bit should always be low if the DCTs are ganged (F2x110[DctGangEn]). The value of this bit should be programmed the same for both DCTs.                         |  |  |
| 12    | <b>RDqsEn: read DQS enable</b> . Read-write. This is applied to the DRAM device's DDR2-defined EMRS(1) or DDR3-defined MR1 registers during DRAM initialization (see section 2.8.7.5 [DRAM Device Initialization] on page 78). This bit should only be set for x8 registered DIMMs when x4 and x8 registered DIMMs are mixed on a channel. Setting this bit results in undefined behavior when F2x[1, 0]94[Ddr3Mode]=1. 1=The DIMM DM pins are used as read DQS pins and data masking is disabled. 0=DM pins function as data mask pins. |  |  |
| 11:10 | <b>ZqcsInterval: ZQ calibration short interval</b> . Read-write. This field specifies the programmable interval for the controller to send out the DRAM ZQ calibration short command. ZqcsInterval is defined only when F2x[1, 0]94[Ddr3Mode] = 1. <u>Bits</u> <u>Definition</u> 00b ZQ calibration short command is disabled 01b 64 ms 10b 128 ms 11b 256 ms                                                                                                                                                                            |  |  |

| 9   | DCT1 is d 0]9C_x[2H RevEnGro (as defined DqsRevEr 7] and Dqs accesses to 0]9C_x[10 used to ma                                                                                                                                                                                                                                                                                                                                                                                         | isabled. In this mode, [The I B:10] value in DqsRcvEnGrossDelay[1, 2, 3, 4, 5, 6, 7] and by [The DRAM CS Base An FineDelay[0] is programmed sRcvEnFineDelayCheck. Who registers F2x[1, 0]9C_x[10]66:105, 06:05], F2x[1, 0]9C | rmal DCT functionality. 1=Legacy BIOS mode is enabled and DRAM DQS Receiver Enable Timing Control Registers] F2x[1, rossDelay[0] is programmed into the register fields of Dqs-nd DqsRcvEnGrossDelayCheck for each corresponding DIMM Address Registers] F2x[1, 0][5C:40]). The value in the field ed into the register fields of DqsRcvEnFineDelay[1, 2, 3, 4, 5, 6, 7hile this bit is set, MemClkFreq is fixed at 200 MHz and 02:101, 02:01], F2x[1, 0]9C_x[103, 03], F2x[1, _x[107, 07], and F2x[1, 0]9C_x[45:30] are blocked. This bit is with the NPT Family 0Fh memory controller. Family 10h BIOS ing F2x[1, 0]9C_x[2B:10]. |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | Ddr3Mod                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | le. Read-write. This bit must                                                                                                                                                                                                | t be set by BIOS based on the types of DIMMs connected to the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DDR2 mode. I=DDR3 mode                                                                                                                                                                                                       | e. Both DCTs must be programmed to the same DIMM type.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7:4 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3   | MemClkFreqVal: memory clock frequency valid. Read-write. System BIOS should set this bit after setting up F2x[1, 0]94[MemClkFreq] to the proper value. This indicates to the DRAM controller that it may start driving MEMCLK at the proper frequency. BIOS should poll FreqChgInProg to determine when the DRAM-interface clocks are stable. Note: this bit should not be set if the DCT is disabled. BIOS must change each DCT's operating frequency in order. See section 2.8.7.5. |                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2:0 | <b>MemClkFreq: memory clock frequency</b> . Read-write. This field specifies the frequency of the DRAM interface (MEMCLK). The definiton varies with the DDR type, F2x[1, 0]94[Ddr3Mode].                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     | Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | DDR2 Definition                                                                                                                                                                                                              | DDR3 Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     | 000b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 200 MHz                                                                                                                                                                                                                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     | 001b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 266 MHz                                                                                                                                                                                                                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     | 010b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 333 MHz                                                                                                                                                                                                                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     | 011b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 400 MHz                                                                                                                                                                                                                      | 400 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     | 100b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 533 MHz                                                                                                                                                                                                                      | 533 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     | 101b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reserved                                                                                                                                                                                                                     | 667 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     | 110b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reserved                                                                                                                                                                                                                     | 800 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     | 111b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reserved                                                                                                                                                                                                                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

## F2x[1, 0]98 DRAM Controller Additional Data Offset Register

Reset: 8000 0000h. The DCTs each include an array of registers called  $F2x[1, 0]9C_x[107:00]$ , which are defined following F2x[1, 0]9C. These are used primarily to control DRAM-interface electrical parameters. [The DRAM Controller Additional Data Offset Register] F2x[1, 0]98 and [The DRAM Controller Additional Data Port] F2x[1, 0]9C are used to access  $F2x[1, 0]9C_x[107:00]$ . The register number (i.e., the number that follows "\_x" in the register mnemonic) is specified by F2x[1, 0]98[DctOffset]. Access to these registers is accomplished as follows:

#### • Reads:

- Write the register number to F2x[1, 0]98[DctOffset] with F2x[1, 0]98[DctAccessWrite]=0.
- Poll F2x[1, 0]98[DctAccessDone] until it is high.
- Read the register contents from F2x[1, 0]9C.

#### • Writes:

- Write all 32 bits to the register data to F2x[1, 0]9C (individual byte writes are not supported).
- Write the register number to F2x[1, 0]98[DctOffset] with F2x[1, 0]98[DctAccessWrite]=1.
- Poll F2x[1, 0]98[DctAccessDone] until it is high to ensure that the contents of the write have been

delivered to the phy.

See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers. Note, however, that F2x198, F2x098, F2x19C\_x[107:00], and F2x09C\_x[107:00], may all be programmed to different values even if the DCTs are in ganged mode.

| Bits | Description                                                                                                                                                                   |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <b>DctAccessDone: DRAM controller access done</b> . Read-only. 1=The access to one of the F2x[1, 0]9C_x[107:00] registers is complete. 0=The access is still in progress.     |
|      | <b>DctAccessWrite: DRAM controller read/write select</b> . Read-write. 0=Read one of the F2x[1, 0]9C_x[107:00] registers. 1=Write one of the F2x[1, 0]9C_x[107:00] registers. |
| 29:0 | DctOffset: DRAM controller offset. Read-write.                                                                                                                                |

## F2x[1, 0]9C DRAM Controller Additional Data Port

See F2x[1, 0]98 for details about this port.

## F2x[1, 0]9C\_x00 DRAM Output Driver Compensation Control Register

Reset: see field definitions. See F2x[1, 0]98 for register access information. See section 2.8.7.4.8 [DRAM Address Timing and Output Driver Compensation Control] on page 74 for information on how to program this register.

| Bits  | Description                                                                                                                                                                                                                                                                  |  |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:30 | Reserved.                                                                                                                                                                                                                                                                    |  |  |  |
| 29:28 | <b>ProcOdt: processor on-die termination</b> . Read-write. Cold reset: 00b. This field specifies the resistance of the on-die termination resistors. The definiton varies with the DDR type, F2x[1, 0]94[Ddr3Mode]. This field is valid only when F2x[1, 0]94[ProcOdtDis]=0. |  |  |  |
|       | Bits DDR2 Definition Bits DDR3 Definition                                                                                                                                                                                                                                    |  |  |  |
|       | 00b 300 ohms +/- 20% 00b 240 ohms +/- 10%                                                                                                                                                                                                                                    |  |  |  |
|       | 01b 150 ohms +/- 20% 01b 120 ohms +/- 10%                                                                                                                                                                                                                                    |  |  |  |
|       | 10b 75 ohms +/- 20% 10b 60 ohms +/- 10%                                                                                                                                                                                                                                      |  |  |  |
|       | 11b Reserved 11b Reserved                                                                                                                                                                                                                                                    |  |  |  |
| 27:22 | Reserved.                                                                                                                                                                                                                                                                    |  |  |  |
| 21:20 | DqsDrvStren: DQS drive strength. Read-write. Cold reset: 11b. This field specifies the drive                                                                                                                                                                                 |  |  |  |
|       | strength of the DQS pins.                                                                                                                                                                                                                                                    |  |  |  |
|       | 00b 0.75x 10b 1.25x                                                                                                                                                                                                                                                          |  |  |  |
|       | 01b 1.0x 11b 1.5x                                                                                                                                                                                                                                                            |  |  |  |
|       | Note: the DM[8:0] and DQS[17:9] functions share pins on the DIMM connector. The function selec-                                                                                                                                                                              |  |  |  |
|       | tion is applied based on whether the DIMM is populated with by-4 (x4) DRAM devices, in which                                                                                                                                                                                 |  |  |  |
|       | case the DQS[17:9] function is applied, or not (x8 or x16 DRAM devices), in which case the DM[8:0]                                                                                                                                                                           |  |  |  |
|       | function is applied. However, the DM function is associated with the data pin group and should there-                                                                                                                                                                        |  |  |  |
|       | fore be controlled DataDrvStren. While the processor supports concurrent population of x4 and non-                                                                                                                                                                           |  |  |  |
|       | x4 DIMMs, the determination as to which field controls the drive strength of these pins is applied stat-                                                                                                                                                                     |  |  |  |
|       | ically based on these rules:                                                                                                                                                                                                                                                 |  |  |  |
|       | • If all DIMMs of an unganged channel are populated with non-x4 devices, DataDrvStren is applied.                                                                                                                                                                            |  |  |  |
|       | • If the channels are ganged and populated with all non-x4 devices, DataDrvStren is applied.                                                                                                                                                                                 |  |  |  |
|       | • If any DIMMs of an unganged channel are populated with x4 devices, DqsDrvStren is applied.                                                                                                                                                                                 |  |  |  |
|       | • If the channels are ganged and populated with any x4 devices, DqsDrvStren is applied.                                                                                                                                                                                      |  |  |  |

| 19:18 | Reserved.                                                                                                                                                                                                                                                           |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16 | DataDrvStren: data drive strength. Read-write. Cold reset: 11b. This field specifies the drive strength of the DRAM data pins.  00b 0.75x. 10b 1.25x  01b 1.0x 11b 1.5x  See the note in DqsDrvStren regarding how this field may be applied to DM signals as well. |
| 15:14 | Reserved.                                                                                                                                                                                                                                                           |
| 13:12 | ClkDrvStren: MEMCLK drive strength. Read-write. Cold reset: 11b. This field specifies the drive strength of the MEMCLK pins.  00b 0.75x. 10b 1.25x  01b 1.0x 11b 1.5x                                                                                               |
| 11:10 | Reserved.                                                                                                                                                                                                                                                           |
| 9:8   | AddrCmdDrvStren: address/command drive strength. Read-write. Cold reset: 11b. This field specifies the drive strength of the address, RAS, CAS, WE, bank and parity pins.  00b 1.0x. 10b 1.5x 01b 1.25x 11b 2.0x                                                    |
| 7:6   | Reserved.                                                                                                                                                                                                                                                           |
| 5:4   | CsOdtDrvStren: CS/ODT drive strength. Read-write. Cold reset: 11b. This field specifies the drive strength of the CS and ODT pins.  00b 1.0x. 10b 1.5x 01b 1.25x 11b 2.0x                                                                                           |
| 3:2   | Reserved.                                                                                                                                                                                                                                                           |
| 1:0   | CkeDrvStren: CKE drive strength. Read-write. Cold reset: 11b. This field specifies the drive strength of the CKE pins.  00b 1.0x. 10b 1.5x  01b 1.25x 11b 2.0x                                                                                                      |

#### F2x[1, 0]9C\_x[102:101, 02:01] DRAM Write Data Timing [High:Low] Registers

See F2x[1, 0]98 for register access information.

These registers control the timing of write data with respect to DQS. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use these registers. See Table 31 for DIMM to DRAM write ECC timing register mapping.

Fine timing (WrDatFineDlyByte):

Delay = WrDatFineDlyByte \* 1/64 of a MEMCLK, ranging from 0/64 to 31/64 MEMCLKs.

Gross timing (WrDatGrossDlyByte):

000b No delay
001b 0.5 MEMCLK delay
010b 1.0 MEMCLK delay
011b 1.5 MEMCLK delay
1xxb Reserved on revision B processors.

The total delay is the sum of these two fields, ranging from 0 to 1 and 63/64 MEMCLKs.

| Bits  | Description                                                                            |
|-------|----------------------------------------------------------------------------------------|
| 31:29 | WrDatGrossDlyByte[7, 3]: write data gross delay byte[7, 3]. Reset: 0. Read-write.      |
| 28:24 | WrDatFineDlyByte[7, 3]: write data fine delay byte[7, 3]. Cold reset: 0Fh. Read-write. |
| 23:21 | WrDatGrossDlyByte[6, 2]: write data gross delay byte[6, 2]. Reset: 0. Read-write.      |
| 20:16 | WrDatFineDlyByte[6, 2]: write data fine delay byte[6, 2]. Cold reset: 0Fh. Read-write. |
| 15:13 | WrDatGrossDlyByte[5, 1]: write data gross delay byte[5, 1]. Reset: 0. Read-write.      |
| 12:8  | WrDatFineDlyByte[5, 1]: write data fine delay byte[5, 1]. Cold reset: 0Fh. Read-write. |
| 7:5   | WrDatGrossDlyByte[4, 0]: write data gross delay byte[4, 0]. Reset: 0. Read-write.      |
| 4:0   | WrDatFineDlyByte[4, 0]: write data fine delay byte[4, 0]. Cold reset: 0Fh. Read-write. |

### F2x[1, 0]9C\_x[103, 03] DRAM Write ECC Timing Register

See F2x[1, 0]98 for register access information. These registers specify the delay that is added to the ECC write data bits with respect to DQS. The total delay is the sum of the fields, ranging from 0 to 1 and 31/64 MEMCLKs. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use this register. See Table 31 for DIMM to DRAM write ECC timing register mapping.

| Bits | Description                                                                                   |  |  |
|------|-----------------------------------------------------------------------------------------------|--|--|
| 31:8 | Reserved.                                                                                     |  |  |
| 7:5  | WrChkGrossDly: write data ECC gross delay. Reset: 0. Read-write. This is encoded as follows:  |  |  |
|      | 000b No delay                                                                                 |  |  |
|      | 001b 0.5 MEMCLK delay                                                                         |  |  |
|      | 010b 1.0 MEMCLK delay                                                                         |  |  |
|      | 011b 1.5 MEMCLK delay                                                                         |  |  |
|      | 1xxb Reserved on revision B processors.                                                       |  |  |
| 4:0  | WrChkFineDly: write data ECC fine delay. Cold reset: 0Fh. Read-write. This is encoded as fol- |  |  |
|      | lows:                                                                                         |  |  |
|      | Delay = WrChkFineDly * 1/64 of a MEMCLK, ranging from 0/64 to 31/64 MEMCLKs.                  |  |  |

#### F2x[1, 0]9C x04 DRAM Address/Command Timing Control Register

Cold reset: 0000 0000h. See F2x[1, 0]98 for register access information. This register controls the timing of the address, command, chip select, ODT and clock enable pins with respect to MEMCLK. See the figure below. This register is used to adjust both the setup and hold time at the DIMM. It is recommended that the address and commands are launched 3/4 of a cycle ahead of the rising edge of MEMCLK. See section 2.8.7.4.8 [DRAM Address Timing and Output Driver Compensation Control] on page 74 for information on how to program this register.



Figure 11: Address/Command Timing at the Processor Pins

2T timing is controlled by F2x[1, 0]94[SlowAccessMode]. Note: if the DCT channels are ganged (see F2x110[DctGangEn]), then this register must be programmed before setting F2x[1, 0]94[MemClkFreqVal]=1. Note: if a setup time (course delay) field is changed and F2x[1, 0]94[MemClkFreqVal]=1, then software must toggle MemClkFreqVal for the delay to take effect.

| Bits  | Description                                                                                                                                                                                                                                                         |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:22 | Reserved.                                                                                                                                                                                                                                                           |  |
| 21    | AddrCmdSetup: address/command setup time. Read-write. This bit selects the default setup time for the address and command pins versus MEMCLK.  0b 1/2 MEMCLK (1 1/2 MEMCLK for 2T timing)  1b 1 MEMCLK (2 MEMCLKs for 2T timing)                                    |  |
| 20:16 | AddrCmdFineDelay: address/command fine delay. Read-write. This field specifies the time that the address and command pins are delayed from the default setup time.  0_0000b No delay 0_0001b 1/64 MEMCLK delay 0_0010b 2/64 MEMCLK delay 1_1111b 31/64 MEMCLK delay |  |
| 15:14 | Reserved.                                                                                                                                                                                                                                                           |  |
| 13    | CsOdtSetup: CS/ODT setup time. Read-write. This bit selects the default setup time for the CS and ODT pins versus MEMCLK.  0b 1/2 MEMCLK  1b 1 MEMCLK                                                                                                               |  |

| 12:8 | CsOdtFineDelay: CS/ODT fine delay. Read-write. This field specifies the time that the CS and                                              |  |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|      | ODT pins are delayed from the default setup time.                                                                                         |  |  |
|      | 0_0000b No delay                                                                                                                          |  |  |
|      | 0_0001b 1/64 MEMCLK delay                                                                                                                 |  |  |
|      | 0_0010b 2/64 MEMCLK delay                                                                                                                 |  |  |
|      |                                                                                                                                           |  |  |
|      | 1_1111b 31/64 MEMCLK delay                                                                                                                |  |  |
| 7:6  | Reserved.                                                                                                                                 |  |  |
| 5    | CkeSetup: CKE setup time. Read-write. This bit selects the default setup time for the CKE pins versus MEMCLK.  0b 1/2 MEMCLK  1b 1 MEMCLK |  |  |
| 4:0  | CkeFineDelay: CKE fine delay. Read-write. This field specifies the time that the CKE pins are                                             |  |  |
|      | delayed from the default setup time.                                                                                                      |  |  |
|      | 0_0000b No delay                                                                                                                          |  |  |
|      | 0_0001b 1/64 MEMCLK delay                                                                                                                 |  |  |
|      | 0_0010b 2/64 MEMCLK delay                                                                                                                 |  |  |
|      |                                                                                                                                           |  |  |
|      | 1_1111b 31/64 MEMCLK delay                                                                                                                |  |  |

### F2x[1, 0]9C\_x[106:105, 06:05] DRAM Read DQS Timing Control [High:Low] Registers

Cold reset: 1F1F 1F1Fh. See F2x[1, 0]98 for register access information.

| <b>DctOffset</b> | Register                                                  |
|------------------|-----------------------------------------------------------|
| 0000_0005h       | DRAM Read DQS Timing Control Low DIMM 0: (bytes 0,1,2,3)  |
| 0000_0006h       | DRAM Read DQS Timing Control High DIMM 0: (bytes 4,5,6,7) |
| 0000_0007h       | DRAM Read DQS ECC Timing Control DIMM 0                   |
| 0000_0105h       | DRAM Read DQS Timing Control Low DIMM 1: (bytes 0,1,2,3)  |
| 0000_0106h       | DRAM Read DQS Timing Control High DIMM 1: (bytes 4,5,6,7) |
| 0000_0107h       | DRAM Read DQS ECC Timing Control DIMM 1                   |

These registers control the timing of read (input) DQS signals with respect to data. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use these registers. See Table 31 for DIMM to DRAM read DQS timing register mapping. F2[1, 0]9C\_x[305, 205, 105, 05] are the DRAM Read DQS Timing Control Low Registers; they control DQS for bytes[3:0] of data. F2[1, 0]9C\_x[306, 206, 106, 06] are the DRAM Read DQS Timing Control High Registers; they control DQS for bytes[7:4] of data. The delay resolution is dependant upon the operating MEMCLK frequency. See F2x[1, 0]94[MemClkFreq]. Each of the fields in these registers specify how much DQS is delayed with respect to data as follows:

- For memory clock frequencies less than 400 MHz, delay = RdDqsTimeByte \* 1/128 MEMCLKs, ranging from 0 to 63/128 MEMCLKs.
- For memory clock frequencies of 400 MHz or greater, delay = (RdDqsTimeByte & 03Eh) \* 1/128 MEM-CLKs, ranging from 0 to 62/128 MEMCLKs (the LSB of RdDqsTimeByte is ignored).

| Bits  | Description                                                           |
|-------|-----------------------------------------------------------------------|
| 31:30 | Reserved.                                                             |
| 29:24 | RdDqsTimeByte[7, 3]: read DQS byte [7, 3] timing control. Read-write. |
| 23:22 | Reserved.                                                             |
| 21:16 | RdDqsTimeByte[6, 2]: read DQS byte [6, 2] timing control. Read-write. |

| 15:14 | Reserved.                                                             |
|-------|-----------------------------------------------------------------------|
| 13:8  | RdDqsTimeByte[5, 1]: read DQS byte [5, 1] timing control. Read-write. |
| 7:6   | Reserved.                                                             |
| 5:0   | RdDqsTimeByte[4, 0]: read DQS byte [4, 0] timing control. Read-write. |

## F2x[1, 0]9C\_x[107, 07] DRAM Read DQS ECC Timing Control Register

Cold reset: 0000 001Fh. See F2x[1, 0]98 for register access information. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use this register. See Table 31 for DIMM to DRAM read DQS ECC timing register mapping.

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5:0  | <ul> <li>RdDqsTimeCheck: read DQS ECC byte timing control. Read-write. This field specifies the delay that is added to the DQS signal associated with the ECC bits with respect to the data. The delay resolution is dependant upon the operating MEMCLK frequency, F2x[1, 0]94[MemClkFreq], as follows:</li> <li>For memory clock frequencies less than 400 MHz, delay = RdDqsTimeCheck * 1/128 MEMCLKs, ranging from 0 to 63/128 MEMCLKs.</li> <li>For memory clock frequencies of 400 MHz or greater, delay = (RdDqsTimeCheck &amp; 03Eh) * 1/128 MEMCLKs, ranging from 0 to 62/128 MEMCLKs (the LSB of RdDqsTimeCheck is ignored).</li> </ul> |

# F2x[1, 0]9C\_x08 DRAM Phy Control Register

Cold reset: 0208 0000h. See F2x[1, 0]98 for register access information. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use this register.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 30    | <b>DisAutoComp: disable automatic compensation</b> . Read-write. 1=Disable the compensation control state machine. 0=The phy automatic compensation engine is enabled.                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 29:14 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 13    | <b>DqsRcvTrEn: DQS receiver training enable</b> . Read-write. 1=Initiate hardware assisted read DQS receiver training. 0=Stop read DQS receiver training. The Phy stops the phase recovery engine during DQS receiver training. This allows the BIOS to reliably read the DQS receiver training data.                                                                                                                                                                                                                                                              |  |  |
| 12    | <b>WrLvOdtEn: write levelization ODT enabled</b> . Read-write. 1=ODT enabled during write levelization training. 0=No ODT is used for write levelization training.                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 11:8  | WrLvOdt[3:0]: write levelization ODT. Read-write. This field specifies the state of the ODT pins that are driven out when WrLvOdtEn is set. For each bit, 1=ODT is enabled; 0=ODT is disabled. Note: tri-state enable for ODT is turned off by the phy while WrLvOdtEn is set.    Bit   Fr2(1207) pin name   AM2r2 pin name   AM3 pin name     0   M[B, A]0_ODT[0]   M[B, A]0_ODT[0]   M[B, A]0_ODT[0]     1   M[B, A]1_ODT[0]   M[B, A]1_ODT[0]   M[B, A]1_ODT[0]     2   M[B, A]2_ODT[0]   N/A   M[B, A]0_ODT[1]     3   M[B, A]3_ODT[0]   N/A   M[B, A]1_ODT[1] |  |  |
| 7:6   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |

| 5:4 | <b>TrDimmSel: training DIMM select</b> . Read-write. This specifies which DIMM is to be trained. 00b=DIMM 0. 01b=DIMM 1. 10b=DIMM 2. 11b=DIMM 3. DIMM numbers are specified by [The DRAM CS Base Address Registers] F2x[1, 0][5C:40]. For DDR3, bit[5] is reserved.                                                                                       |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | <b>PhyFenceTrEn:</b> phy fence training enable. Write-only. 1=Initiate phy based fence training. 0=Stop the phy based fence training engine.                                                                                                                                                                                                              |
| 2   | <b>TrNibbleSel: training nibble select</b> . Read-write. This specifies nibbles of each DIMM data and ECC byte trained during write levelization training. 0=Lower nibbles. 1=Upper nibbles.                                                                                                                                                              |
| 1   | <b>WrtLvTrMode: write levelization training mode</b> . Read-write. 1=Write levelization training is done by the BIOS. 0=Write training is done by the hardware.                                                                                                                                                                                           |
| 0   | <b>WrtLvTrEn:</b> write levelization training enable. Read-write. 1=Initiate write levelization (tDQSS margining) training. 0=Stop write levelization training. Revision C and earlier revisions: The Phy stops the phase recovery engine during write levelization training. This allows the BIOS to reliably read the write levelization training data. |

# F2x9C\_x09 DRAM Phy Driver Calibration Register

Cold reset: xxxx xxxxh. See F2x[1, 0]98 for register access information. This register and F2x9C\_x0A are used by BIOS to program the phy's pre-driver calibration codes based on non-linear driver calibration codes read from this register. See section 2.8.7.2 for more information on how to program these registers.

Note: BIOS must not write to this register.

| Bits  | Description                                                      |
|-------|------------------------------------------------------------------|
| 31:30 | Reserved.                                                        |
| 29:25 | D3Cmp2DrvPCal: D3CMP 2 driver PMOS calibration code. Read-write. |
| 24:20 | D3Cmp2DrvNCal: D3CMP 2 driver NMOS calibration code. Read-write. |
| 19:15 | D3Cmp1DrvPCal: D3CMP 1 driver PMOS calibration code. Read-write. |
| 14:10 | D3Cmp1DrvNCal: D3CMP 1 driver NMOS calibration code. Read-write. |
| 9:5   | D3Cmp0DrvPCal: D3CMP 0 driver PMOS calibration code. Read-write. |
| 4:0   | D3Cmp0DrvNCal: D3CMP 0 driver NMOS calibration code. Read-write. |

# F2x9C\_x0A DRAM Phy Predriver Calibration Register

Cold reset: 0631 8C63h. See F2x[1, 0]98 for register access information. See section 2.8.7.2 for information on how to program this register.

| Bits  | Description        |                                                                                                                                                                                                               |
|-------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved.          |                                                                                                                                                                                                               |
| 27:25 | value programmed i | CMP 2 PMOS predriver calibration code. Read-write. The calibration code nto this field corresponds to the normalized drive strength value programmed in ataDrvStren] as specified below.  Calibration Code 7h |
|       | 01b<br>10b<br>11b  | 7h<br>5h<br>3h                                                                                                                                                                                                |

| 24:23 | Reserved.                                                                                                                                                                                                                                      |                                                                                                                                                                                                       |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 22:20 | D3Cmp2NCal: D3CMP 2 NMOS predriver calibration code. Read-write. The calibration code                                                                                                                                                          |                                                                                                                                                                                                       |  |
|       |                                                                                                                                                                                                                                                | into this field corresponds to the normalized drive strength value programmed in                                                                                                                      |  |
|       | F2x[1, 0]9C_x00[I                                                                                                                                                                                                                              | DataDrvStren] as specified below.                                                                                                                                                                     |  |
|       | <u>DataDrvStren</u>                                                                                                                                                                                                                            | Calibration Code                                                                                                                                                                                      |  |
|       | 00b                                                                                                                                                                                                                                            | 7h                                                                                                                                                                                                    |  |
|       | 01b                                                                                                                                                                                                                                            | 7h                                                                                                                                                                                                    |  |
|       | 10b                                                                                                                                                                                                                                            | 3h                                                                                                                                                                                                    |  |
| 10.10 | 11b                                                                                                                                                                                                                                            | 2h                                                                                                                                                                                                    |  |
| 19:18 | Reserved.                                                                                                                                                                                                                                      |                                                                                                                                                                                                       |  |
| 17:15 | value programmed                                                                                                                                                                                                                               | <b>3CMP 1 PMOS predriver calibration code.</b> Read-write. The calibration code into this field corresponds to the normalized drive strength value programmed in AddrCmdDrvStren] as specified below. |  |
|       | AddrCmdDrvStre                                                                                                                                                                                                                                 | en Calibration Code                                                                                                                                                                                   |  |
|       | 00b                                                                                                                                                                                                                                            |                                                                                                                                                                                                       |  |
|       | 01b                                                                                                                                                                                                                                            | 5h                                                                                                                                                                                                    |  |
|       | 10b                                                                                                                                                                                                                                            | 3h                                                                                                                                                                                                    |  |
|       | 11b                                                                                                                                                                                                                                            | 2h                                                                                                                                                                                                    |  |
| 14:13 | Reserved.                                                                                                                                                                                                                                      |                                                                                                                                                                                                       |  |
| 12:10 | 12:10 <b>D3Cmp1NCal: D3CMP 1 NMOS predriver calibration code</b> . Read-write. The calvalue programmed into this field corresponds to the normalized drive strength value F2x[1, 0]9C_x00[AddrCmdDrvStren] as specified below.                 |                                                                                                                                                                                                       |  |
|       | AddrCmdDrvStre                                                                                                                                                                                                                                 | en Calibration Code                                                                                                                                                                                   |  |
|       | 00b                                                                                                                                                                                                                                            | 7h                                                                                                                                                                                                    |  |
|       | 01b                                                                                                                                                                                                                                            | 3h                                                                                                                                                                                                    |  |
|       | 10b                                                                                                                                                                                                                                            | 2h                                                                                                                                                                                                    |  |
|       | 11b                                                                                                                                                                                                                                            | 2h                                                                                                                                                                                                    |  |
| 9:8   | Reserved.                                                                                                                                                                                                                                      |                                                                                                                                                                                                       |  |
| 7:5   | <b>D3Cmp0PCal: D3CMP 0 PMOS predriver calibration code</b> . Read-write. The calibration code value programmed into this field corresponds to the normalized drive strength value programmer F2x[1, 0]9C_x00[DataDrvStren] as specified below. |                                                                                                                                                                                                       |  |
|       | F2x[1, 0]9C_x00[I                                                                                                                                                                                                                              | DataDivStrenj as specified below.                                                                                                                                                                     |  |
|       |                                                                                                                                                                                                                                                | - ·                                                                                                                                                                                                   |  |
|       | <u>DataDrvStren</u>                                                                                                                                                                                                                            | Calibration Code                                                                                                                                                                                      |  |
|       | DataDrvStren<br>00b                                                                                                                                                                                                                            | Calibration Code 7h                                                                                                                                                                                   |  |
|       | <u>DataDrvStren</u>                                                                                                                                                                                                                            | Calibration Code                                                                                                                                                                                      |  |

| 4:3 | Reserved.                    |                                                                                                                                                                                             |
|-----|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | value programmed             | 3CMP 0 NMOS predriver calibration code. Read-write. The calibration code into this field corresponds to the normalized drive strength value programmed in DataDrvStren] as specified below. |
|     | DataDrvStren 00b 01b 10b 11b | Calibration Code 7h 7h 3h 2h                                                                                                                                                                |

## F2x[1, 0]9C\_x0C DRAM Phy Miscellaneous Register

Cold reset: 0013 0000h. See F2x[1, 0]98 for register access information. This register provides access to the DDR phy to control signal tri-state functionality. Based on the system configuration, BIOS may tri-state signals with associated chip selects that are unpopulated in an effort to conserve power. This register also provides access to the DDR phy fence logic used to adjust the phase relationship between the data fifo and the data going to the pad. See section 2.8.7.6 [Phy Fence programming] on page 84 for information on how to program this register.

| Bits  | Description                                                                                                                                                                                                                                                                           |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:21 | Reserved.                                                                                                                                                                                                                                                                             |  |
| 20:16 | <b>PhyFence: phy fence</b> .Read-write. This field specifies the fence delay value between the phy data fifo, and the DDR pads. Fence delay = PhyFence * 1/64 of a MEMCLK, ranging from 0/64 to 31/64 MEMCLKs.                                                                        |  |
| 15:14 | Reserved.                                                                                                                                                                                                                                                                             |  |
| 13:12 | CKETri[1:0]: CKE tri-state. Read-write. 0=The CKE signals are not tri-stated unless directed to by the DCT. 1=Tri-state unconnected CKE signals from the processor. The bits CKETri[1:0] are mapped to packages as follows:  Bit Package pin name  0 M[B, A]_CKE[0]  1 M[B, A]_CKE[1] |  |
|       | Note: F2x9C_x0C controls the channel A memory CKE pins and F2x19C_x0C controls the channel B memory CKE pins.                                                                                                                                                                         |  |

|   | 11:8 |            |                                    |                           | signals are not tri-stated unless directed to by processor. The bits ODTTri[3:0] are mapped |
|---|------|------------|------------------------------------|---------------------------|---------------------------------------------------------------------------------------------|
|   |      |            | kages as follows:                  | ed ODT signals from the   | e processor. The bits ODT III[3.0] are mapped                                               |
|   |      | Bit        | Fr2(1207) pin name                 | AM2r2 pin name            | AM3 pin name                                                                                |
|   |      | 0          | M[B, A]0_ODT[0]                    | M[B, A]0_ODT[0]           | M[B, A]0_ODT[0]                                                                             |
|   |      | 1          |                                    |                           |                                                                                             |
|   |      | 2          | M[B, A]1_ODT[0]                    | M[B, A]1_ODT[0]<br>N/A    | M[B, A]1_ODT[0]<br>M[B, A]0_ODT[1]                                                          |
|   |      | 3          | M[B, A]2_ODT[0]<br>M[B, A]3_ODT[0] | N/A<br>N/A                | M[B, A]1_ODT[1]                                                                             |
|   |      | 3          | M[b, A]3_ODT[0]                    | N/A                       | M[B, A]I_ODI[I]                                                                             |
|   |      | Note:      | F2x9C x0C controls the             | channel A memory OD7      | Γ pins and F2x19C_x0C controls the channel                                                  |
|   |      |            | nory ODT pins.                     | Ž                         | _                                                                                           |
|   | 7:0  | ChipS      | SelTri[7:0]: chip select ti        | ri-state. Read-write. 0=T | he chip select signals are not tri-stated unless                                            |
| • |      | _          | <del>=</del>                       |                           | lects when motherboard termination is                                                       |
|   |      |            |                                    |                           | ss parity capability, BIOS must not tri-state                                               |
|   |      | the chi    | ip select pin correspondin         | g to the second chip sele | ct of the DIMM . The bits ChipSelTri[7:0] are                                               |
| • |      | mappe      | ed to packages as follows          | •                         |                                                                                             |
|   |      | <u>Bit</u> | Fr2(1207) pin name                 | AM2r2 pin name            | AM3 pin name                                                                                |
| • |      | 0          | $M[B, A]0\_CS\_H/L[0]$             | M[B, A]0_CS_H/L[0]        | M[B, A]0_CS_H/L[0]                                                                          |
|   |      | 1          | $M[B, A]0\_CS\_H/L[1]$             | M[B, A]0_CS_H/L[1]        | M[B, A]0_CS_H/L[1]                                                                          |
|   |      | 2          | $M[B, A]1\_CS\_H/L[0]$             | M[B, A]1_CS_H/L[0]        | M[B, A]0_CS_H/L[2]                                                                          |
|   |      | 3          | $M[B, A]1\_CS\_H/L[1]$             | $M[B, A]1\_CS\_H/L[1]$    | M[B, A]0_CS_H/L[3]                                                                          |
|   |      | 4          | $M[B, A]2\_CS\_H/L[0]$             | N/A                       | N/A                                                                                         |
|   |      | 5          | $M[B, A]2\_CS\_H/L[1]$             | N/A                       | N/A                                                                                         |
|   |      | 6          | $M[B, A]3\_CS\_H/L[0]$             | N/A                       | N/A                                                                                         |
|   |      | 7          | M[B, A]3_CS_H/L[1]                 | N/A                       | N/A                                                                                         |
|   |      |            |                                    |                           | select pins and F2x19C_x0C controls the                                                     |
|   |      | channe     | el B memory chip select            | pins.                     |                                                                                             |

#### F2x[1, 0]9C\_x[2B:10] DRAM DQS Receiver Enable Timing Control Registers

See F2x[1, 0]98 for register access information.

These registers are organized as eight groups of registers, two groups for each DIMM on a channel. DIMM numbers are specified by [The DRAM CS Base Address Registers] F2x[1, 0][5C:40]. The definition of F2x[1, 0]98[DctOffset] registers  $0000\_0010h$  through  $0000\_001Bh$  varies with F2x[1, 0]94[LegacyBiosMode]. To ensure unique values are written to each DQS receiver enable timing control register, BIOS must program these registers in consecutive order; i.e., program DIMM 0 register values first followed by the DIMM 1 values, etc.

Danistan

DatOffaat

| <u>DctOffset</u> | Register                                                         |
|------------------|------------------------------------------------------------------|
| 0000_0010h       | DRAM DQS Receiver Enable Timing Control Low DIMM 0: (bytes 0,1)  |
| 0000_0011h       | DRAM DQS Receiver Enable Timing Control High DIMM 0: (bytes 2,3) |
| 0000_0012h       | DRAM DQS Receiver Enable Timing Control ECC DIMM 0               |
| 0000_0013h       | DRAM DQS Receiver Enable Timing Control Low DIMM 1: (bytes 0,1)  |
| 0000_0014h       | DRAM DQS Receiver Enable Timing Control High DIMM 1: (bytes 2,3) |
| 0000_0015h       | DRAM DQS Receiver Enable Timing Control ECC DIMM 1               |
| 0000_0016h       | DRAM DQS Receiver Enable Timing Control Low DIMM 2: (bytes 0,1)  |
| 0000_0017h       | DRAM DQS Receiver Enable Timing Control High DIMM 2: (bytes 2,3) |
| 0000_0018h       | DRAM DQS Receiver Enable Timing Control ECC DIMM 2               |
| 0000_0019h       | DRAM DQS Receiver Enable Timing Control Low DIMM 3: (bytes 0,1)  |
| 0000_001Ah       | DRAM DQS Receiver Enable Timing Control High DIMM 3: (bytes 2,3) |
| 0000_001Bh       | DRAM DQS Receiver Enable Timing Control ECC DIMM 3               |
| 0000_0020h       | DRAM DQS Receiver Enable Timing Control Low DIMM 0: (bytes 4,5)  |
| 0000_0021h       | DRAM DQS Receiver Enable Timing Control High DIMM 0: (bytes 6,7) |
| 0000_0022h       | Reserved                                                         |
| 0000_0023h       | DRAM DQS Receiver Enable Timing Control Low DIMM 1: (bytes 4,5)  |
| 0000_0024h       | DRAM DQS Receiver Enable Timing Control High DIMM 1: (bytes 6,7) |
| 0000_0025h       | Reserved                                                         |
| 0000_0026h       | DRAM DQS Receiver Enable Timing Control Low DIMM 2: (bytes 4,5)  |
| 0000_0027h       | DRAM DQS Receiver Enable Timing Control High DIMM 2: (bytes 6,7) |
| 0000_0028h       | Reserved                                                         |
| 0000_0029h       | DRAM DQS Receiver Enable Timing Control Low DIMM 3: (bytes 4,5)  |
| 0000_002Ah       | DRAM DQS Receiver Enable Timing Control High DIMM 3: (bytes 6,7) |
| 0000_002Bh       | Reserved                                                         |
|                  |                                                                  |

Each of these registers control the timing of the receiver enable from the start of the read preamble with respect to MEMCLK. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use these registers. Individual controls for each byte of data and ECC data are provided. Each control includes a gross timing field and a fine timing field, the sum of which is the total delay. They are defined as follows:

Fine timing (for DqsRcvEnFineDelay and DqsRcvEnFineDelayCheck):

Delay = DqsRcvEnFineDelay \* 1/64 MEMCLKs, ranging from 0 to 31/64 MEMCLKs.

#### Gross timing:

```
0000b No delay
0001b 0.5 MEMCLK delay
0010b 1.0 MEMCLK delay
0011b 1.5 MEMCLK delay
0100b 2.0 MEMCLK delay
0101b 2.5 MEMCLK delay
0110b 3.0 MEMCLK delay
0111b 3.5 MEMCLK delay
1xxxb Reserved.
```

**DRAM DQS Receiver Enable Timing Control [High, Low] Registers** (For DctOffset registers 0000\_0010h through 0000\_001Bh, the high registers apply to bytes[3:2] and the low registers apply to bytes[1:0]. For DctOffset registers 0000\_0020h through 0000\_002Bh, the high registers apply to bytes[7:6] and the low registers apply to bytes[5:4].

| Bits  | Description                                                                                            |
|-------|--------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved.                                                                                              |
| 28:25 | Reserved.                                                                                              |
| 24:21 | DqsRcvEnGrossDelay[7, 5],[3, 1]: DQS receiver enable gross delay[7, 5],[3, 1]. Reset: 0. Readwrite.    |
| 20:16 | DqsRcvEnFineDelay[7, 5],[3, 1]: DQS receiver enable fine delay[7, 5],[3, 1]. Cold reset: 0. Readwrite. |
| 15:13 | Reserved.                                                                                              |
| 12:9  | Reserved.                                                                                              |
| 8:5   | DqsRcvEnGrossDelay[6, 4],[2, 0]: DQS receiver enable gross delay[6, 4],[2, 0]. Reset: 0. Readwrite.    |
| 4:0   | DqsRcvEnFineDelay[6, 4],[2, 0]: DQS receiver enable fine delay[6, 4],[2, 0]. Cold reset: 0. Readwrite. |

### **DRAM DQS Receiver Enable Timing Control ECC Registers**

See F2x[1, 0]98 for register access information.

| Bits | Description                                                                           |
|------|---------------------------------------------------------------------------------------|
| 31:9 | Reserved.                                                                             |
| 8:5  | DqsRcvEnGrossDelayCheck: DQS receiver enable gross delay ECC. Reset: 0. Read-write.   |
| 4:0  | DqsRcvEnFineDelayCheck: DQS receiver enable fine delay ECC.Cold reset: 0. Read-write. |

## F2x[1, 0]9C\_x[45:30] DRAM DQS Write Timing Control Registers

These registers are valid only when F2x[1, 0]94[Ddr3Mode] = 1 and should be programmed to 0 otherwise. There are two groups of registers for each DDR3 DIMM. DIMM numbers are specified by [The DRAM CS Base Address Registers] F2x[1, 0][5C:40].

| <u>DctOffset</u> | Register                                                        |
|------------------|-----------------------------------------------------------------|
| 0000_0030h       | DRAM DQS Write Timing Control Low DIMM 0: (bytes 0,1)           |
| 0000_0031h       | DRAM DQS Write Timing Control High DIMM 0: (bytes 2,3)          |
| 0000_0032h       | DRAM DQS Write Timing Control ECC DIMM 0                        |
| 0000_0033h       | DRAM DQS Write Timing Control Low DIMM 1: (bytes 0,1)           |
| 0000_0034h       | DRAM DQS Write Timing Control High DIMM 1: (bytes 2,3)          |
| 0000_0035h       | DRAM DQS Write Timing Control ECC DIMM 1                        |
| 0000_0036h - 3Fh | Reserved                                                        |
| 0000_0040h       | DRAM DQS Write Timing Control Low DIMM 0: (bytes 4,5)           |
| 0000_0041h       | DRAM DQS Write Timing Control High DIMM 0: (bytes 6,7)          |
| 0000_0042h       | Reserved                                                        |
| 0000_0043h       | DRAM DQS Write Timing Control Low DIMM 1: (bytes 4,5)           |
| 0000 0044h       | DRAM DQS Write Timing Control High DIMM 1: (bytes 6,7)          |
|                  | Did not bego write Timing Control Tright Briving 1: (bytes 6,7) |

Each of these registers control the DQS timing delay for write commands relative to MEMCLK. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use this register. Individual controls for each byte of data and ECC data are provided. Each control includes a gross timing field and a fine timing field, the

sum of which is the total delay. They are defined as follows:

Fine timing (for WrDqsFineDly and WrDqsChkFineDly):

Delay = WrDqsFineDly \* 1/64 MEMCLKs, ranging from 0 to 31/64 MEMCLKs.

Delay = WrDqsFineDly \* 1/64 MEMCLKs, ranging from 0 to 31/64 MEMCLKs.

#### Gross timing:

| 000b | No delay         |
|------|------------------|
| 001b | 0.5 MEMCLK delay |
| 010b | 1.0 MEMCLK delay |
| 011b | 1.5 MEMCLK delay |
| 1xxh | Reserved         |

#### DRAM DQS Write Timing Control [High, Low] Registers

See F2x[1, 0]98 for register access information. (For DctOffset registers  $0000\_0030h$  through  $0000\_003Bh$ , the high registers apply to bytes[3:2] and the low registers apply to bytes[1:0]. For DctOffset registers  $0000\_0040h$  through  $0000\_0045h$ , the high registers apply to bytes[7:6] and the low registers apply to bytes[5:4])

| Bits  | Description                                                                              |
|-------|------------------------------------------------------------------------------------------|
| 31    | Reserved.                                                                                |
| 30:29 | Reserved. Read-write.                                                                    |
| 28:24 | Reserved.                                                                                |
| 23:21 | WrDqsGrossDly[7, 5],[3, 1]: DQS write gross delay[7, 5],[3, 1]. Reset: 0. Read-write.    |
| 20:16 | WrDqsFineDly[7, 5],[3, 1]: DQS write fine delay[7, 5],[3, 1]. Cold reset: 0. Read-write. |
| 15    | Reserved.                                                                                |
| 14:13 | Reserved.                                                                                |
| 12:8  | Reserved.                                                                                |
| 7:5   | WrDqsGrossDly[6, 4],[2, 0]: DQS write gross delay[6, 4],[2, 0]. Reset: 0. Read-write.    |
| 4:0   | WrDqsFineDly[6, 4],[2, 0]: DQS write fine delay[6, 4],[2, 0]. Cold reset: 0. Read-write. |

#### **DRAM DQS Write Timing Control ECC Registers**

See F2x[1, 0]98 for register access information.

| Bits | Description                                                           |
|------|-----------------------------------------------------------------------|
| 31:8 | Reserved.                                                             |
| 7:5  | WrDqsChkGrossDly: DQS write gross delay ECC. Reset: 0. Read-write.    |
| 4:0  | WrDqsChkFineDly: DQS write fine delay ECC. Cold reset: 0. Read-write. |

#### F2x[1, 0]9C\_x[51:50] DRAM Phase Recovery Control Register [High:Low] Registers

See F2x[1, 0]98 for register access information. These registers are used by BIOS for hardware assisted DRAM training. Writes to these registers seed the phase recovery engine prior to training. Reads from the registers indicate how much the phase recovery engine has advanced to align the MEMCLK and DQS edges and is under hardware control. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use these registers. F2[1, 0]9C\_x50 is the Low Register which controls bytes[3:0] of data. F2[1, 0]9C\_x51 is the High Register which controls bytes[7:4] of data. The fields in these registers are encoded as follows:

Gross timing (PhRecGrossDlyByte): indicates the number of half-MEMCLK periods that the phase recovery engine advanced while aligning edges, ranging from 0.0 to 1.5 MEMCLK periods.

Fine timing (PhRecFineDlyByte):

Delay = PhRecFineDlyByte \* 1/64 of a MEMCLK, ranging from 0/64 to 31/64 MEMCLKs.

The total delay is the sum of these two fields, ranging from 0 to 1 and 63/64 MEMCLKs.

| Bits  | Description                                                                            |
|-------|----------------------------------------------------------------------------------------|
| 31    | Reserved.                                                                              |
| 30:29 | PhRecGrossDlyByte[7, 3]: phase recovery gross delay byte [7, 3]. Read-write. Reset: X. |
| 28:24 | PhRecFineDlyByte[7, 3]: phase recovery fine delay byte [7, 3]. Read-write. Reset: X.   |
| 23    | Reserved.                                                                              |
| 22:21 | PhRecGrossDlyByte[6, 2]: phase recovery gross delay byte [6, 2]. Read-write. Reset: X. |
| 20:16 | PhRecFineDlyByte[6, 2]: phase recovery fine delay byte [6, 2]. Read-write. Reset: X.   |
| 15    | Reserved.                                                                              |
| 14:13 | PhRecGrossDlyByte[5, 1]: phase recovery gross delay byte [5, 1]. Read-write. Reset: X. |
| 12:8  | PhRecFineDlyByte[5, 1]: phase recovery fine delay byte [5, 1]. Read-write. Reset: X.   |
| 7     | Reserved.                                                                              |
| 6:5   | PhRecGrossDlyByte[4, 0]: phase recovery gross delay byte [4, 0]. Read-write. Reset: X. |
| 4:0   | PhRecFineDlyByte[4, 0]: phase recovery fine delay byte [4, 0]. Read-write. Reset: X.   |

### F2x[1, 0]9C\_x52 DRAM ECC Phase Recovery Control Register

Reset: see field definitions. See F2x[1, 0]98 for register access information. This register is provides the same function as  $F2x[1, 0]9C_x[51:50]$  for the ECC bits of the interface; see that register for more information.

| Bits | Description                                                                      |
|------|----------------------------------------------------------------------------------|
| 31:7 | Reserved.                                                                        |
| 6:5  | PhRecEccGrossDlyByte: phase recovery ECC gross delay byte. Read-write. Reset: X. |
| 4:0  | PhRecEccFineDlyByte: phase recovery ECC fine delay byte. Read-write. Reset: X.   |

## F2x[1, 0]9C\_x53 Write Levelization Error Register

Reset: see field definitions. See F2x[1, 0]98 for register access information. This register is used by BIOS for hardware assisted DRAM training. See section 2.8.7.8 [DRAM Training] on page 85 for information on how to use this register.

| Bits | Description                                                                                             |
|------|---------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved.                                                                                               |
| 8:0  | WrLvErr: write levelization error. Read-only. Reset: X. This field indicates the phase recovery         |
|      | error state which is used by BIOS for write levelization training for each byte of data and ECC. Bit[0] |
|      | applies to byte0; bit[1] applies to byte1; etc. Bit[8] indicates the ECC byte state.                    |

# F2x[1, 0]A0 DRAM Controller Miscellaneous Register

Reset: 0000 0000h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

| Bits  | Description                                                                                |  |
|-------|--------------------------------------------------------------------------------------------|--|
| 31:10 | Must be low. Read-write.                                                                   |  |
| 9     | <b>DramEnabled: DRAM enabled.</b> Read-only. This bit is identical to F2x110[DramEnabled]. |  |
| 8:1   | Reserved.                                                                                  |  |
| 0     | <b>MemCleared:</b> memory cleared. Read-only. This bit is identical to F2x110[MemCleared]. |  |

## F2x[1, 0]A8 DRAM Controller Miscellaneous Register 2

Reset: 0000 0000h. See section 2.8.1 [DCT Configuration Registers] on page 61 for general programming information about DCT configuration registers.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                 |
| 15:8  | CtrlWordCS[7:0]: control word chip select. Read-write. This field specifies the target DIMM chip selects used for control word programming. This field is used in conjunction with F2x[1, 0]7C[Send-ControlWord].  00000011b - CS0,CS1 is asserted.  00001100b - CS2,CS3 is asserted.  00110000b - CS4,CS5 is asserted.  11000000b - CS6,CS7 is asserted.  All other values are reserved. |
| 7:0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                 |

## F2x110 DRAM Controller Select Low Register

Reset: 0000 0000h.

| Bits  | Description                                                                                                                                                                                                                                             |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | <b>DctSelBaseAddr[47:27]: DRAM controller select base address bits[47:27]</b> . Read-write. If the DCTs are unganged (based on DctGangEn), this delineates the address range of the two DCTs by specifying the base address of the upper address range. |
| 10    | <b>MemCleared: memory cleared</b> . Read-only. 1=Memory has been cleared since the last warm reset. This bit is set by MemClrInit. See MemClrInit below.                                                                                                |
| 9     | <b>MemClrBusy: memory clear busy</b> . Read-only. 1=The memory clear operation in either of the DCTs is in progress. Reads or writes to DRAM while the memory clear operation is in progress result in undefined behavior.                              |
| 8     | <b>DramEnable: DRAM enabled</b> . Read-only. 1=All of the used DCTs are initialized (see section 2.8.7.5 [DRAM Device Initialization] on page 78) or have exited from self refresh (F2x[1, 0]90[Exit-SelfRef] transitions from 1 to 0).                 |

| 7:6 | DctSelIntLvAddr: DRAM controller select channel interleave address bit. Read-write. This specifies how interleaving is selected between the DCTs. In all cases, if the select function is low then DCT0 is selected; if the select function is high then DCT1 is selected. The select functions are:  00b Address bit 6.  10b Hash: exclusive OR of address bits[20:16, 6].  11b Reserved                                                                                                                                                                                                                                                                                                                                             |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | <b>DctDatIntLv: DRAM controller data interleave enable</b> . Read-write. 1=DRAM data bits from every two consecutive 64-bit DRAM lines are interleaved in the ECC calculation such that a dead bit of a DRAM device is correctable. If ECC is enabled and the DCT is unganged (DctGangEn is clear), DctDatIntLv should be enabled. See section 2.13.2 [DRAM Considerations for ECC] on page 118 for more information.                                                                                                                                                                                                                                                                                                                 |
| 4   | <b>DctGangEn: DRAM controller ganging enable</b> . Read-write. 1=Both DCTs are ganged to form a single double-width DDR interface. 0=The DCTs operate independently. This also affects how DCT configuration registers; see section 2.8.1 [DCT Configuration Registers] on page 61. Note, if ganging is to be enabled, this bit must be set prior to programming any DCT registers.                                                                                                                                                                                                                                                                                                                                                   |
| 3   | <b>MemClrInit:</b> memory clear initialization. Write only; reads as 0. 1=The node writes 0's to all locations of system memory attached to the node and sets the MemCleared bit. The status of the memory clear operation can be determined by reading the MemClrBusy and MemCleared bits. This command is ignored if MemClrBusy=1 when the command is received. Note: DramEnable must be set before setting MemClrInit. The memory prefetcher (see F2x11C) must be disabled before memory clear initialization and then can be re-enabled when MemCleared=1.                                                                                                                                                                        |
| 2   | DctSelIntLvEn: DRAM controller interleave enable. Read-write. 1=Channel interleave is enabled; DctSelIntLvAddr specifies which address bit is used to select between DCT0 and DCT1; this applies from the base system memory address of the node (specified by [The DRAM Base/Limit Registers] F1x[1, 0][7C:40]) to DctSelBaseAddr (if enabled). If the amount of memory connected to each of the DCTs is different, then channel interleaving may be supported across the address range that includes both DCTs, the top of which is specified by DctSelBaseAddr; the remainder of the address space, above DctSelBaseAddr, would then be allocated to only the DCT connected to the larger amount of memory, specified by DctSelHi. |
| 1   | <b>DctSelHi: DRAM controller high select</b> . Read-write. If DctSelHiRngEn is set, this specifies which DCT receives accesses with addresses in the high range (greater than or equal to DctSelBaseAddr). 0=High addresses go to DCT0. 1=High addresses go to DCT1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0   | <b>DctSelHiRngEn: DRAM controller select high range enable</b> . Read-write. 1=Enables addresses greater than or equal to DctSelBaseAddr[47:27] to be used to select between DCT0 and DCT1; Dct-SelHi specifies which DCT occupies the high range. Note: if DctGangEn=1, then this bit is not used.                                                                                                                                                                                                                                                                                                                                                                                                                                   |

# F2x114 DRAM Controller Select High Register

Reset: 0000 0000h.

| Bits  | Description                                                                                                                                                                                                                                                                                                                       |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | DctSelBaseOffset[47:26]: DRAM controller select base offset address bits[47:26]. Read-write. When F2x110[DctSelHiRngEn]=1, this value is subtracted from the physical address of certain transactions before being passed to the DCT. See section 2.8.9.2 [DctSelBaseOffset Programming] on page 105 for programming information. |
| 9:0   | Reserved.                                                                                                                                                                                                                                                                                                                         |

### F2x118 Memory Controller Configuration Low Register

Fields in this register (bits[17:0]) indicate priority of request types. These are encoded as follows:

Low 01b Medium 00b High 10b Variable 11b

Variable priority requests enter the memory controller as medium priority and are promoted to high priority if they have not been serviced in the time specified by MctVarPriCntLmt. This feature may be useful for isochronous IO traffic. If isochronous traffic is specified to be high priority, it may have an adverse effect on the bandwidth and performance of the devices associated with the other types of traffic. However, if isochronous traffic is specified as medium priority, the processor may not meet the isochronous bandwidth and latency requirements. The variable priority allows the memory controller to optimize DRAM transactions until isochronous traffic reaches a time threshold and must be serviced more quickly.

| Bits  | Description                                                                                                                                                                                                |                                                           |                                                      |                                                           |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------|
| 31:28 | MctVarPriCntLmt: variable priority time limit. Read-write. Reset: 0000b.                                                                                                                                   |                                                           |                                                      |                                                           |
|       | 0000b = 80ns                                                                                                                                                                                               | 0100b = 400ns                                             | 1000b = 720ns                                        | 1100b = 1040ns                                            |
|       | 0001b = 160ns                                                                                                                                                                                              | 0101b = 480ns                                             | 1001b = 800ns                                        | 1101b = 1120ns                                            |
|       | 0010b = 240ns                                                                                                                                                                                              | 0110b = 560ns                                             | 1010b = 880ns                                        | 1110b = 1200ns                                            |
|       | 0011b = 320ns                                                                                                                                                                                              | 0111b = 640ns                                             | 1011b = 960ns                                        | 1111b = 1280ns                                            |
| 27    | Reserved.                                                                                                                                                                                                  |                                                           |                                                      |                                                           |
| 26:24 |                                                                                                                                                                                                            | of times a medium- or le                                  |                                                      | ax. Read-write. Reset: 100b. est may be bypassed by high- |
| 23    | Reserved.                                                                                                                                                                                                  |                                                           |                                                      |                                                           |
| 22:20 | McqMedPriByPassMax: memory controller medium bypass low priority max. Read-write. Reset: 100b. Specifies the number of times a low-priority DRAM request may be bypassed by medium-priority DRAM requests. |                                                           |                                                      |                                                           |
| 19:18 | Reserved.                                                                                                                                                                                                  |                                                           |                                                      |                                                           |
| 17:16 | MctPriScrub: scrub                                                                                                                                                                                         | ber priority. Read-write                                  | e. Reset: medium (00b).                              |                                                           |
| 15:14 | MctPriTrace: trace-                                                                                                                                                                                        | mode request priority.                                    | Read-write. Reset: high                              | (10b). This must be set to high.                          |
| 13:12 | 1 2                                                                                                                                                                                                        | refresh read priority. F<br>Refresh And IFCM] on p        | Read-write. Reset: high (2) page 54.                 | 10b). See 2.6.4.2.4                                       |
| 11:10 | MctPriWr: default                                                                                                                                                                                          | write priority. Read-wri                                  | te. Reset: low (01b).                                |                                                           |
| 9:8   | MctPriDefault: default non-write priority. Read-write. Reset: medium (00b).                                                                                                                                |                                                           |                                                      |                                                           |
| 7:6   |                                                                                                                                                                                                            |                                                           | set priority. Read-write. assified as display refres | Reset: medium (00b). This h.                              |
| 5:4   |                                                                                                                                                                                                            | ead with the isoch bit so<br>traffic that is classified a | - ·                                                  | Reset: high (10b). This does not                          |
| 3:2   | MctPriCpuWr: CPI                                                                                                                                                                                           | U write priority. Read-v                                  | vrite. Reset: low (01b).                             |                                                           |
| 1:0   | MctPriCpuRd: CPU                                                                                                                                                                                           | J <b>read priority</b> . Read-wi                          | rite. Reset: medium (00b                             | ).                                                        |

## F2x11C Memory Controller Configuration High Register

The two main functions of this register are to control write bursting and memory prefetching.

**Write bursting**. DctWrLimit and MctWrLimit specify how writes may be burst from the MCT into the DCT to improve DRAM efficiency. When the number of writes in the MCT reaches the value specified in MctWr-Limit, then they are all burst to the DCTs at once. Prior to reaching the watermark, a limited number of writes can be passed to the DCTs (specified by DctWrLimit), tagged as low priority, for the DCTs to complete when otherwise idle. Rules regarding write bursting:

- Write bursting mode only applies to low-priority writes. Medium and high priority writes are not withheld from the DCTs for write bursting.
- If write bursting is enabled, writes stay in the MCQ until the threshold specified by MctWrLimit is reached.
- Once the threshold is reached, all writes in MCQ are converted to medium priority.
- Any write in MCQ that matches the address of a subsequent access is promoted to either medium priority or the priority of the subsequent access, whichever is higher.
- DctWrLimit only applies to low-priority writes.

**Memory prefetching.** The MCT prefetcher detects stride patterns in the stream of requests and then, for predictable stride patterns, generates prefetch requests. A stride pattern is a pattern of requests through system memory that are the same number of cachelines apart. The prefetcher supports strides of -4 to +4 cachelines, which can include alternating patterns (e.g. +1, +2, +1, +2), and can prefetch 1, 2 or 3 cachelines ahead depending on the confidence. In addition, a fixed stride mode (non-alternating) may be used for IO requests which often have fixed stride patterns. This mode bypasses the stride predictor such that CPU-access stride predictions are not adversely affected by IO streams.

The MCT tracks several stride patterns simultaneously. Each of these has a confidence level associated with it that varies as follows:

- Each time a request is received that matches the stride pattern, the confidence level increases by one.
- Each time a request is received within +/- 4 cachelines of the last requested cacheline in the pattern that does not match the pattern, then the confidence level decreases by one.
- When the confidence level reaches the saturation point specified by PrefConfSat, then it no-longer increments.

Each request that is not within +/- 4 cachelines of the last requested cacheline line of all the stride patterns tracked initiates a new stride pattern by displacing one of the existing least-recently-used stride patterns.

• The following settings should be used:

PrefThreeConf = 7 PrefTwoConf = 7 PrefOneConf = 2
PrefConfSat = 1 MctWrLimit = 16

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | MctScrubEn: MCT scrub enable. Read-write. Reset: 0. 1=Enables periodic flushing of prefetches and writes based on the DRAM scrub rate. This is used to ensure that prefetch and write data aging is not so long that soft errors accumulate and become uncorrectable. When enabled, each DRAM scrub event causes a single prefetch to be de-allocated (the oldest one) and all queued writes to be flushed to DRAM. |
| 30   | <b>FlushWr: flush writes command</b> . Read; write-1-only; cleared-by-hardware. Reset: 0. Setting this bit causes write bursting to be cancelled and all outstanding writes to be flushed to DRAM. This bit is cleared when all writes are flushed to DRAM                                                                                                                                                          |

| 29    | <b>FlushWrOnStpGnt: flush writes on stop-grant</b> . Read-write. Reset: 0. 1=Causes write bursting to be cancelled and all outstanding writes to be flushed to DRAM when in the stop-grant state. This bit should be set to ensure writes are drained to DRAM before reset is asserted for the suspend-to-RAM state.                                                                                                                                                                                                                  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28    | <b>PrefDramTrainMode: prefetch DRAM training mode</b> . Read-write; cleared-by-hardware. Reset: 0. 1=Enable DRAM training mode. Hardware clears this bit when the prefetch request limit is reached. Writing a zero to this bit clears the prefetch buffer and disables the DRAM training mode prefetcher. BIOS must write a zero to this bit after training is complete. This bit is valid only when F2x[1, 0]94[BurstLength32]=0 or when F2x[1, 0]94[Ddr3Mode]=1. See section 2.8.7.8.5 [Continuous Pattern Generation] on page 99. |
| 27:25 | <b>PrefThreeConf: prefetch three-ahead confidence</b> . Read-write. Reset: 110b. Confidence level required in order to prefetch three cachelines ahead (same encoding as PrefTwoConf below).                                                                                                                                                                                                                                                                                                                                          |
| 24:22 | <b>PrefTwoConf: prefetch two-ahead confidence</b> . Read-write. Reset: 011b. Confidence level required in order to prefetch two cachelines ahead.  000b = 0 001b = 2 111b = 14                                                                                                                                                                                                                                                                                                                                                        |
| 21:20 | <b>PrefOneConf: prefetch one-ahead confidence</b> . Read-write. Reset: 10b. Confidence level required in order to prefetch one ahead (0 through 3).                                                                                                                                                                                                                                                                                                                                                                                   |
| 19:18 | PrefConfSat: prefetch confidence saturation. Read-write. Reset: 00. Specifies the point at which prefetch confidence level saturates and stops incrementing.  00b = 15 01b = 7 10b = 3 11b = Reserved.                                                                                                                                                                                                                                                                                                                                |
| 17:16 | <b>PrefFixDist: prefetch fixed stride distance</b> . Read-write. Reset: 00b. Specifies the distance to prefetch ahead if in fixed stride mode. 00b=1 cacheline; 01b=2 cachelines; 10b=3 cachelines; 11b=4 cachelines.                                                                                                                                                                                                                                                                                                                 |
| 15    | <b>PrefFixStrideEn: prefetch fixed stride enable</b> . Read-write. Reset: 0. 1=The prefetch stride for all requests (CPU and IO) is fixed (non-alternating).                                                                                                                                                                                                                                                                                                                                                                          |
| 14    | <b>PrefIoFixStrideEn: Prefetch IO fixed stride enable</b> . Read-write. Reset: 0. 1=The prefetch stride for IO requests is fixed (non-alternating).                                                                                                                                                                                                                                                                                                                                                                                   |
| 13    | <b>PrefIoDis: prefetch IO-access disable</b> . Read-write. Reset: 1. 1=Disables IO requests from triggering prefetch requests.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12    | <b>PrefCpuDis: prefetch CPU-access disable</b> . Read-write. Reset: 1. 1=Disables CPU requests from triggering prefetch requests.                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11:7  | MctPrefReqLimit: memory controller prefetch request limit. Read-write. Reset: 1Fh (31). Specifies the maximum number of outstanding prefetch requests allowed.                                                                                                                                                                                                                                                                                                                                                                        |

| 6:2 | <b>MctWrLimit: memory controller write-burst limit</b> . Read-write. Reset: 1_1111b. Specifies the number of writes in the memory controller queue before they are burst into the DCTs. 00000b = 32. 00001b = 31.                                                |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | <br>11110b = 2.<br>11111b = Write bursting disabled.                                                                                                                                                                                                             |
| 1:0 | Ç                                                                                                                                                                                                                                                                |
| 1:0 | <b>DctWrLimit: DRAM controller write limit.</b> Read-write. Reset: 00b. Specifies the maximum number of writes allowed in the DCT queue when write bursting is enabled, prior to when the number of writes in MCQ exceeds the watermark specified by MctWrLimit. |
|     | 00b = 0                                                                                                                                                                                                                                                          |
|     | 01b = 1                                                                                                                                                                                                                                                          |
|     | 10b = 2 $11b = no limit.$                                                                                                                                                                                                                                        |

# 3.6 Function 3 Miscellaneous Control Registers

See section 3.1 [Register Descriptions and Mnemonics] on page 135 for a description of the register naming convention. See section 2.11 [Configuration Space] on page 112 for details about how to access this space.

# F3x00 Device/Vendor ID Register

| Reset: 1 | 1203 1022h.                     |  |
|----------|---------------------------------|--|
| Bits     | Description                     |  |
| 31:16    | DeviceID: device ID. Read-only. |  |
| 15:0     | VendorID: vendor ID. Read-only. |  |

# F3x04 Status/Command Register

| Reset: ( | Reset: 0000 0000h, except bit[20]; see below.                                                                        |  |  |
|----------|----------------------------------------------------------------------------------------------------------------------|--|--|
| Bits     | Description                                                                                                          |  |  |
|          | <b>Status.</b> Read-only. Bit[20] is set to indicate the existence of a PCI-defined capability block, if one exists. |  |  |
| 15:0     | Command. Read-only.                                                                                                  |  |  |

## F3x08 Class Code/Revision ID Register

| Reset: ( | 0600 0000h.                                                                                    |
|----------|------------------------------------------------------------------------------------------------|
| Bits     | Description                                                                                    |
| 31:8     | ClassCode. Read-only. Provides the host bridge class code as defined in the PCI specification. |
| 7:0      | RevID: revision ID. Read-only.                                                                 |

# F3x0C Header Type Register

| Reset: ( | 0080 0000h.                                                                                                                                                              |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits     | Description                                                                                                                                                              |
| 31:0     | <b>HeaderTypeReg.</b> Read-only. These bits are fixed at their default values. The header type field indicates that there are multiple functions present in this device. |

### F3x34 Capability Pointer Register

| Reset: 0000 00??h. |                                                                                                                                                                          |  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits               | Description                                                                                                                                                              |  |
| 31:8               | Reserved.                                                                                                                                                                |  |
| 7:0                | <b>CapPtr.</b> Read-only. Specifies the configuration-space offset of the capabilities pointer. If a capability block is enabled, this reads a F0h; otherwise it is 00h. |  |

### F3x40 MCA NB Control Register

Reset: 0000 0000h. The machine check registers are used to configure the Machine Check Architecture (MCA) functions of the Northbridge (NB) hardware and to provide a method for the NB to report errors in a way compatible with MCA. All of the NB MCA registers, except [The MCA NB Configuration Register] F3x44, are accessible through the MCA-defined MSR method, as well as through PCI configuration space. [The MCA NB Control Register] F3x40 enables MCA reporting of each error checked by the NB. The global MCA error enables must also be set through [The Global Machine Check Exception Reporting Control Register (MCG\_CTL)] MSR0000\_017B. The error enables in this register only affect error reporting through MCA. Actions which the NB may take in addition to MCA reporting are enabled through [The MCA NB Configuration Register] F3x44.

Correctableand uncorrectable errors are logged in [The MCA NB Status Low Register] F3x48, [The MCA NB Status High Register] F3x4C, [The MCA NB Address Low Register] F3x50, and [The DRAM Scrub Address High Register] F3x60 as they occur, as specified by F3x4C[Over]. Uncorrectable errors immediately result in a Machine Check exception. Correctable errors only increment a counter in [The NB Machine Check Misc (Thresholding) Registers] F3x1[78, 70, 68, 60], which may result in a Machine Check exception or a System Management Interrupt.

| Bit   | Description                                                                                                                                                                                                                                                                                                         |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:28 | Reserved.                                                                                                                                                                                                                                                                                                           |  |  |
| 27    | <b>TblWlkDatErrEn: table walk data error enable</b> . Read-write. 1=Enables MCA reporting of uncorrectable errors in returned data from a DEV or GART table walk.                                                                                                                                                   |  |  |
| 26    | <b>NbArrayParEn: Northbridge array parity error reporting enable</b> . Read-write. 1=Enables MCA reporting of parity errors in the NB arrays.                                                                                                                                                                       |  |  |
| 25    | <b>McaUsPwDatErrEn: MCA upstream data error enable</b> . Read-write. 1=Enables MCA reporting of upstream posted writes in which the link error bits indicate a data error.                                                                                                                                          |  |  |
| 24    | <b>SyncPkt3En: link 3 sync packet error reporting enable</b> . Read-write. 1=Enables MCA reporting of link-defined sync error packets detected on link 3. The NB floods its outgoing links with sync packets after detecting a sync packet on an incoming link independent of the state of this bit.                |  |  |
| 23    | <b>CrcErr3En: link 3 CRC error reporting enable</b> . Read-write. 1=Enables MCA reporting of CRC errors detected on link 3 (see the description of CRC Error in Table 52). The NB floods its outgoing links with sync packets after detecting a CRC error on an incoming link independent of the state of this bit. |  |  |
| 22    | RtryHt3En: link 3 retry reporting enable. Read-write. 1=Enables MCA reporting of retries on link 3.                                                                                                                                                                                                                 |  |  |
| 21    | RtryHt2En: link 2 retry reporting enable. Read-write. 1=Enables MCA reporting of retries on link 2.                                                                                                                                                                                                                 |  |  |

| 20 | RtryHt1En: link 1 retry reporting enable. Read-write. 1=Enables MCA reporting of retries on link 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19 | RtryHt0En: link 0 retry reporting enable. Read-write. 1=Enables MCA reporting of retries on link 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 18 | <b>DramParEn: DRAM parity error reporting enable</b> . Read-write. 1=Enables MCA reporting of parity errors on the DRAM address or control signals.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 17 | <b>HtDataEn:</b> link data error reporting enable. Read-write. 1=Enables MCA reporting of packets with data errors detected on links.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16 | <b>HtProtEn: link protocol error reporting enable</b> . Read-write. 1=Enables MCA reporting of protocol errors detected on links. This enable should be cleared before initiating a warm reset to avoid logging spurious errors due to RESET# signal skew.                                                                                                                                                                                                                                                                                                                                |
| 15 | <b>L3ArrayUCEn: L3 cache array uncorrectable error reporting enable</b> . Read-write. 1=Enables MCA reporting of uncorrectable errors in the L3 cache arrays.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 14 | <b>L3ArrayCorEn: L3 cache array correctable error reporting enable</b> . Read-write. 1=Enables MCA reporting of correctable errors in the L3 cache arrays.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 13 | <b>DevErrEn: DEV error reporting enable</b> . Read-write. 1=Enables MCA reporting of SVM DEV errors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12 | <b>WDTRptEn:</b> watchdog timer error reporting enable. Read-write. 1=Enables MCA reporting of watchdog timer errors. The watchdog timer checks for NB system accesses for which a response is expected but no response is received. See [The MCA NB Configuration Register] F3x44 for information regarding configuration of the watchdog timer duration. Note that this bit does not affect operation of the watchdog timer in terms of its ability to complete an access that would otherwise cause a system hang. This bit only affects whether such errors are reported through MCA. |
| 11 | <b>AtomicRMWEn: atomic read-modify-write error reporting enable</b> . Read-write. 1=Enables MCA reporting of atomic read-modify-write (RMW) commands received from an IO link. Atomic RMW commands are not supported. An atomic RMW command results in a link error response being generated back to the requesting IO device. The generation of the link error response is not affected by this bit.                                                                                                                                                                                     |
| 10 | <b>GartTblWkEn: GART table walk error reporting enable</b> . Read-write. 1=Enables MCA reporting of GART cache table walks which encounter a GART PTE entry which is invalid.                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9  | <b>TgtAbortEn: target abort error reporting enable</b> . Read-write. 1=Enables MCA reporting of target aborts to a link. The NB returns an error response back to the requestor with any associated data all 1s independent of the state of this bit.                                                                                                                                                                                                                                                                                                                                     |
| 8  | <b>MstrAbortEn: master abort error reporting enable</b> . Read-write. 1=Enables MCA reporting of master aborts to a link. The NB returns an error response back to the requestor with any associated data all 1s independent of the state of this bit.                                                                                                                                                                                                                                                                                                                                    |
| 7  | <b>SyncPkt2En:</b> link 2 sync packet error reporting enable. Read-write. 1=Enables MCA reporting of link-defined sync error packets detected on link 2. The NB floods its outgoing links with sync packets after detecting a sync packet on an incoming link independent of the state of this bit.                                                                                                                                                                                                                                                                                       |
| 6  | <b>SyncPkt1En:</b> link 1 sync packet error reporting enable. Read-write. 1=Enables MCA reporting of link-defined sync error packets detected on link 1. The NB floods its outgoing links with sync packets after detecting a sync packet on an incoming link independent of the state of this bit.                                                                                                                                                                                                                                                                                       |
| 5  | <b>SyncPkt0En:</b> link 0 sync packet error reporting enable. Read-write. 1=Enables MCA reporting of link-defined sync error packets detected on link 0. The NB floods its outgoing links with sync packets after detecting a sync packet on an incoming link independent of the state of this bit.                                                                                                                                                                                                                                                                                       |

| 4 | <b>CrcErr2En: link 2 CRC error reporting enable</b> . Read-write. 1=Enables MCA reporting of CRC errors detected on link 2 (see the description of CRC Error in Table 52). The NB floods its outgoing links with sync packets after detecting a CRC error on an incoming link independent of the state of this bit. |
|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | <b>CrcErr1En: link 1 CRC error reporting enable</b> . Read-write. 1=Enables MCA reporting of CRC errors detected on link 1 (see the description of CRC Error in Table 52). The NB floods its outgoing links with sync packets after detecting a CRC error on an incoming link independent of the state of this bit. |
| 2 | <b>CrcErr0En: link 0 CRC error reporting enable</b> . Read-write. 1=Enables MCA reporting of CRC errors detected on link 0 (see the description of CRC Error in Table 52). The NB floods its outgoing links with sync packets after detecting a CRC error on an incoming link independent of the state of this bit. |
| 1 | <b>UECCEn: uncorrectable ECC error reporting enable</b> . Read-write. 1=Enables MCA reporting of DRAM uncorrectable ECC errors which are detected in the NB.                                                                                                                                                        |
| 0 | <b>CECCEn:</b> correctable ECC error reporting enable. Read-write. 1=Enables MCA reporting of DRAM correctable ECC errors which are detected in the NB.                                                                                                                                                             |

# F3x44 MCA NB Configuration Register

Reset: 0080 0000h. See also [The Extended NB MCA Configuration Register] F3x180. Generally, it is expected that the fields of this register are programmed to the same value in all nodes (except for bit fields used for error injection, SubLinkSel, GenCrcErrByte1, GenCrcErrByte0, LdtLinkSel).

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | <b>NbMcaLogEn: Northbridge MCA log enable</b> . Read-write. 1=Enables logging (but not reporting) of NB MCA errors even if MCA is not globally enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 30   | SyncOnDramAdrParErrEn: sync flood on DRAM address parity error enable. Read-write. 1=Enables sync flood on detection of a DRAM address parity error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 29   | <b>DisMstAbtCpuErrRsp: master abort CPU error response disable</b> . Read-write. 1=Disables master abort reporting through the CPU MCA error-reporting banks.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 28   | <b>DisTgtAbtCpuErrRsp: target abort CPU error response disable</b> . Read-write. 1=Disables target abort reporting through the CPU MCA error-reporting banks.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 27   | NbMcaToMstCpuEn: machine check errors to master CPU only. Read-write. 1=NB MCA errors in a CMP device are reported only to core 0, and the NB MCA registers in MSR space (MSR0000_0410, MSR0000_0411, MSR0000_0412, MSR0000_0413, MSRC000_04[0A:08], MSRC001_0048) are only accessible from core 0; reads of these MSRs from other cores return 0's and writes are ignored. This field does not affect PCI-defined configuration space accesses to these registers, which are accessible from all cores. See section 3.1 [Register Descriptions and Mnemonics] on page 135 for a description of MSR space and PCI-defined configuration space. 0=NB MCA errors may be reported to the core that originated the request, if applicable and known, and the NB MCA registers in MSR space are accessible from any core.  Notes:  • When the CPU which originated the request is known, it is stored in F3x4C[ErrCPU], regardless of the setting of NbMcaToMstCpuEn. See Table 54 for errors where ErrCPU is known. |
|      | <ul> <li>If IO originated the request, then the error is reported to core 0, regardless of the setting of NbMca-ToMstCpuEn.</li> <li>BIOS should set this bit to 1 in all processors if the machine check handler must execute on core 0.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| 26    | <b>CorrMcaExcEn:</b> correctable error MCA exception enable. Read-write. 1=Correctable errors that are enabled for checking and logging cause a machine check exception (reporting) in addition to being logged.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 25    | <b>DisPciCfgCpuErrRsp: PCI configuration CPU error response disable</b> . Read-write. 1=Disables generation of an error response to the CPU core on detection of a target or master abort error condition, and disables master abort and target abort reporting through the MCA error-reporting banks for PCI configuration accesses. It is recommended that this bit be set in order to avoid MCA exceptions being generated from master aborts for PCI configuration accesses (which is common during device enumeration).                                                                                                                                       |  |  |  |  |
| 24    | <b>IoRdDatErrEn: IO read data error log enable</b> . Read-write. 1=Enables logging and reporting of read data errors (link defined master aborts, target aborts, and data error) for data destined for IO devices. 0=Read data errors for transactions from IO devices are not logged by MCA, although error responses may still be generated to the requesting IO device.                                                                                                                                                                                                                                                                                         |  |  |  |  |
| 23    | ChipKillEccEn: chipkill ECC mode enabled. Read-only. 1=Chipkill ECC mode is enabled; ECC checking is based on ganged 128/16-bit data/ECC and can be used for chipkill. 0=Chipkill ECC mode is not enabled; ECC checking is based on two interleaved, unganged 64/8-bit data/ECC lines and cannot be used for chipkill. Chipkill functionality is possible only when chipkill ECC mode is enabled (as indicated in this field) and the physical configuration is appropriate; see section 2.13.2 [DRAM Considerations for ECC] on page 118 for more details.                                                                                                        |  |  |  |  |
| 22    | <b>DramEccEn: DRAM ECC enable</b> . Read-write. 1=Enables ECC check/correct mode. This bit must be set in order for ECC checking/correcting by the NB to be enabled. If set, ECC is checked and correctable errors are corrected irrespective of whether machine check ECC reporting is enabled. The hardware only allows values to be programmed into this field which are consistent with the ECC capabilities of the device as specified in [The Northbridge Capabilities Register] F3xE8. Attempts to write values inconsistent with the capabilities result in this field not being updated. This bit does not affect ECC checking in the Northbridge arrays. |  |  |  |  |
| 21    | <b>SyncOnAnyErrEn:</b> sync flood on any error enable. Read-write. 1=Enables flooding of all links with sync packets on detection of any MCA error that is uncorrectable, including Northbridge array errors and link protocol errors.                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| 20    | <b>SyncOnWDTEn:</b> sync flood on watchdog timer error enable. Read-write. 1=Enables flooding of all links with sync packets on detection of a watchdog timer error. BIOS should set this bit to 1b.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 19:18 | SubLinkSel: sublink select for CRC error generation. Read-write. Selects the sublink of a link selected by LdtLinkSel to be used for CRC error injection through GenCrcErrByte0 and GenCrcErrByte1. When the link is ganged, SubLinkSel must be 00b. When the link is unganged, the following values indicate which sublink is selected:  00b = Sublink 0.  10b = Reserved.  11b = Reserved.                                                                                                                                                                                                                                                                       |  |  |  |  |
| 17    | <b>GenCrcErrByte1: generate CRC error on byte lane 1</b> . Read-Write. 1=For ganged links, causes a CRC error to be injected on byte lane 1 of the link specified by LdtLinkSel. For unganged links, this field is reserved, and GenCrcErrByte0 must be used. The data carried by the link is unaffected. This bit is cleared after the error has been generated. See also F0x150[ForceErrType].                                                                                                                                                                                                                                                                   |  |  |  |  |
| 16    | <b>GenCrcErrByte0: generate CRC error on byte lane 0</b> . Read-Write. 1=Causes a CRC error to be injected on byte lane 0 of the link specified by LdtLinkSel and the sublink specified by SubLinkSel. The data carried by the link is unaffected. This bit is cleared after the error has been generated. See also F0x150[ForceErrType].                                                                                                                                                                                                                                                                                                                          |  |  |  |  |

| 15:14 | LdtLinkSel: link select for CRC error generation. Read-Write. Selects the link to be used for CRC                                                                                             |  |  |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|       | error injection through GenCrcErrByte1/GenCrcErrByte0.                                                                                                                                        |  |  |  |  |
|       | 00b = link 0                                                                                                                                                                                  |  |  |  |  |
|       | 01b = link 1                                                                                                                                                                                  |  |  |  |  |
|       | 10b = link 2                                                                                                                                                                                  |  |  |  |  |
|       | 11b = link 3                                                                                                                                                                                  |  |  |  |  |
| 13:12 | WDTBaseSel: watchdog timer time base select. Read-write. Selects the time base used by the                                                                                                    |  |  |  |  |
|       | watchdog timer. The counter selected by WDTCntSel determines the maximum count value in the                                                                                                   |  |  |  |  |
|       | time base selected by WDTBaseSel.                                                                                                                                                             |  |  |  |  |
|       | 00b = 1.28  ms $10b = 5  ns$                                                                                                                                                                  |  |  |  |  |
|       | 01b = 1.28  us $11b = reserved$                                                                                                                                                               |  |  |  |  |
| 11:9  | WDTCntSel[2:0]: watchdog timer count select bits[2:0]. Read-write. Selects the count used by the                                                                                              |  |  |  |  |
| 11.7  | watchdog timer. WDTCntSel is a 4-bit field composed of {F3x180[WDTCntSel[3]],                                                                                                                 |  |  |  |  |
|       | F3x44[WDTCntSel[2:0]]}. The counter selected by WDTCntSel determines the maximum count                                                                                                        |  |  |  |  |
|       | value in the time base selected by WDTBaseSel. WDTCntSel is encoded as:                                                                                                                       |  |  |  |  |
|       | 0000b = 4095 $0100b = 255$ $1000b = 8191$                                                                                                                                                     |  |  |  |  |
|       | 0000b = 4093 $0100b = 233$ $1000b = 8191$ $0001b = 2047$ $0101b = 127$ $1001b = 16383$                                                                                                        |  |  |  |  |
|       | 0010b = 1023 $0110b = 63$ $1010b - 1111b = reserved$                                                                                                                                          |  |  |  |  |
|       | 0010b = 1025 $0110b = 03$ $1010b = 1111b = 1eserved$ $0011b = 511$ $0111b = 31$                                                                                                               |  |  |  |  |
|       | Note: Because WDTCntSel is split between two registers, care must be taken when programming                                                                                                   |  |  |  |  |
|       | WDTCntSel to ensure that a reserved value is never used by the watchdog timer or undefined behav-                                                                                             |  |  |  |  |
|       | ior could result.                                                                                                                                                                             |  |  |  |  |
| _     |                                                                                                                                                                                               |  |  |  |  |
| 8     | <b>WDTDis:</b> watchdog timer disable. Read-write. 1=Disables the watchdog timer. The watchdog timer                                                                                          |  |  |  |  |
|       | is enabled by default and checks for NB system accesses for which a response is expected and where                                                                                            |  |  |  |  |
|       | no response is received. If such a condition is detected the outstanding access is completed by gener-                                                                                        |  |  |  |  |
|       | ating an error response back to the requestor. An MCA error may also be generated if enabled in [The                                                                                          |  |  |  |  |
|       | MCA NB Control Register] F3x40.                                                                                                                                                               |  |  |  |  |
| 7     | <b>IoErrDis: IO error response disable</b> . Read-write. 1=Disables setting either Error bit in link                                                                                          |  |  |  |  |
|       | response packets to IO devices on detection of a target abort, master abort, or data error condition.                                                                                         |  |  |  |  |
| 6     | <b>CpuErrDis: CPU error response disable</b> . Read-write. 1=Disables generation of a read data error                                                                                         |  |  |  |  |
|       | response to the CPU core on detection of a target or master abort error condition.                                                                                                            |  |  |  |  |
| 5     | IoMstAbortDis: IO master abort error response disable. Read-write. 1=Signals target abort                                                                                                     |  |  |  |  |
|       | instead of master abort in link response packets to IO devices on detection of a master abort error con-                                                                                      |  |  |  |  |
|       | dition. When IoMstAbortDis and F3x180[MstAbtChgToNoErrs] are both set,                                                                                                                        |  |  |  |  |
|       | F3x180[MstAbtChgToNoErrs] takes precedence.                                                                                                                                                   |  |  |  |  |
| 1     |                                                                                                                                                                                               |  |  |  |  |
| 4     | SyncPktPropDis: sync packet propagation disable. Read-write. 1=Disables flooding of all outgoing links with sync packets when a sync packet is detected on an incoming link. Sync packets are |  |  |  |  |
|       | ing links with sync packets when a sync packet is detected on an incoming link. Sync packets are                                                                                              |  |  |  |  |
|       | propagated by default.                                                                                                                                                                        |  |  |  |  |

| 3 | <b>SyncPktGenDis:</b> sync packet generation disable. Read-write. 1=Disables flooding of all outgoing links with sync packets when a CRC error is detected on an incoming link. By default, sync packet generation for CRC errors is controlled through [The Link Control Registers] F0x[E4, C4, A4, 84].                                                                                                                                                                          |
|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 | <b>SyncOnUcEccEn:</b> sync flood on uncorrectable ECC error enable. Read-write. 1=Enables flooding of all links with sync packets on detection of an uncorrectable ECC error.                                                                                                                                                                                                                                                                                                      |
| 1 | <b>CpuRdDatErrEn: CPU read data error log enable</b> . Read-write. 1=Enables logging and reporting of read data errors (master aborts and target aborts) for data destined for the CPU on this node. This bit should be clear if read data error logging is enabled for the remaining error reporting blocks in the CPU. Logging the same error in more than one block may cause a single error event to be treated as a multiple error event and cause the CPU to enter shutdown. |
| 0 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# F3x48 MCA NB Status Low Register

Cold Reset: xxxx xxxxh.

Software is normally only allowed to write 0's to this register to clear the fields so subsequent errors may be logged. See also MSRC001\_0015[McStatusWrEn]. This register may be accessed through [The NB Machine Check Status Register (MC4\_STATUS)] MSR0000\_0411 as well.

| Bits  | Description                                                                                                                               |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:24 | <b>Syndrome[15:8]: syndrome bits 15:8 for ECC</b> . Read-write. Logs the upper eight syndrome bits when an ECC error is detected.         |  |  |
| 23:21 | Reserved.                                                                                                                                 |  |  |
| 20:16 | <b>ErrorCodeExt: extended error code</b> . Read-write. Logs the extended error code when an error is detected. See Table 53 for encoding. |  |  |
| 15:0  | <b>ErrorCode: error code</b> . Read-write. Logs an error code when an error is detected. See Table 53 for encoding.                       |  |  |

Three types of errors are reported: TLB, memory, or bus errors.

| Error | Error Code |      |      | Error Code Type | Description                                                                                                                                           |
|-------|------------|------|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000  | 0000       | 0001 | TTLL | TLB             | Errors in the GART TLB cache.  TT = Transaction Type  LL = Cache Level                                                                                |
| 0000  | 0001       | RRRR | TTLL | Memory          | Errors in the cache hierarchy (not in NB)  RRRR = Memory Transaction Type  TT = Transaction Type  LL = Cache Level                                    |
| 0000  | 1PPT       | RRRR | IILL | Bus             | General bus errors including link and DRAM PP = Participation Processor T = Timeout RRRR = Memory Transaction Type II = Memory or IO LL = Cache Level |

# **Table 47: Error codes: transaction type**

| TT | Transaction Type |
|----|------------------|
| 00 | Instruction      |
| 01 | Data             |
| 10 | Generic          |
| 11 | Reserved         |

# Table 48: Error codes: cache level

| LL | Cache Level                     |
|----|---------------------------------|
| 00 | Reserved                        |
| 01 | Level 1 (L1)                    |
| 10 | Level 2 (L2)                    |
| 11 | Generic (LG; includes L3 cache) |

# Table 49: Error codes: memory transaction type

| RRRR | Memory Transaction Type              |
|------|--------------------------------------|
| 0000 | GEN: Generic. Includes scrub errors. |
| 0001 | RD: Generic Read                     |
| 0010 | WR: Generic Write                    |
| 0011 | DRD: Data Read                       |
| 0100 | DWR: Data Write                      |
| 0101 | IRD: Instruction Fetch               |
| 0110 | Prefetch                             |
| 0111 | Evict                                |
| 1000 | Snoop (Probe)                        |

# **Table 50: Error codes: participation processor**

| PP | Participation Processor                              |
|----|------------------------------------------------------|
| 00 | Local node originated the request (SRC)              |
| 01 | Local node responded to the request (RES)            |
| 10 | Local node observed the error as a third party (OBS) |
| 11 | Generic                                              |

# Table 51: Error codes: memory or IO

| II | Memory or IO        |
|----|---------------------|
| 00 | Memory Access (MEM) |
| 01 | Reserved            |
| 10 | IO Access (IO)      |

Table 51: Error codes: memory or IO

| II | Memory or IO  |
|----|---------------|
| 11 | Generic (GEN) |

**Table 52: NB error descriptions** 

| Error Type      | Description                                                                                                                                                                                                                                                                                                                                                  | Control Bits (F3x40)                              |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| CRC Error       | CRC error detected on link. If the link is in retry mode, this may indicate excessive link reconnect failures; see F0x[E4, C4, A4, 84][CrcErr, LinkFail, CrcFloodEn].  The NB floods its outgoing links with sync packets after detecting a CRC error on an incoming link independent                                                                        | CrcErr0En, CrcErr1En,<br>CrcErr2En, CrcErr3En     |
|                 | of the state of the control bits.                                                                                                                                                                                                                                                                                                                            |                                                   |
| Sync Error      | Link-defined sync error packets detected on link. The NB floods its outgoing links with sync packets after detecting a sync packet on an incoming link independent of the state of the control bits.                                                                                                                                                         | SyncPkt0En, SyncPkt1En,<br>SyncPkt2En, SyncPkt3En |
| Master Abort    | Master abort seen as result of link operation. Reasons for this error include requests to non-existent addresses, and requesting extended addresses while extended mode disabled (see F0x[E4, C4, A4, 84][Addr64BitEn]). The NB returns an error response back to the requestor with any associated data all 1s independent of the state of the control bit. | MstrAbortEn                                       |
| Target Abort    | Target abort seen as result of link operation. The NB returns an error response back to the requestor with any associated data all 1s independent of the state of the control bit.                                                                                                                                                                           | TgtAbortEn                                        |
| GART Error      | GART cache table walk encountered a GART PTE entry which was invalid.                                                                                                                                                                                                                                                                                        | GartTblWkEn                                       |
| RMW Error       | An atomic read-modify-write (RMW) command was received from an IO link. Atomic RMW commands are not supported. An atomic RMW command results in a link error response being generated back to the requesting IO device. The generation of the link error response is not affected by the control bit.                                                        | AtomicRMWEn                                       |
| WDT Error       | NB WDT timeout due to lack of progress. Error signalled back to requester. Cause of error may be another node or device which failed to respond.                                                                                                                                                                                                             | WDTRptEn                                          |
| ECC Error       | DRAM ECC error detected in the NB.                                                                                                                                                                                                                                                                                                                           | CECCEn, UECCEn                                    |
| DEV Error       | SVM DEV error detected.                                                                                                                                                                                                                                                                                                                                      | DevErrEn                                          |
| Link Data Error | Data error detected on link.                                                                                                                                                                                                                                                                                                                                 | HtDataEn, McaUsPwDatErrEn                         |

**Table 52: NB error descriptions** 

| Error Type                    | Description                                                                                                                                                                                                                                                                                                     | Control Bits (F3x40)                          |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| Link Protocol<br>Error        | Protocol error detected on link. Ensure that error is not due to failure or reset at far end of link or from transmission corruption (should be indicated by CRC error). The enable for this error should be cleared before initiating a warm reset to avoid logging spurious errors due to RESET# signal skew. | HtProtEn                                      |
| L3 Protocol Error             | Protocol error detected in L3. The system cannot continue operation.                                                                                                                                                                                                                                            | HtProtEn                                      |
| NB Array Error                | A parity error was detected in the NB internal arrays.                                                                                                                                                                                                                                                          | NbArrayParEn                                  |
| DRAM Parity<br>Error          | A parity error was detected on the DRAM address or control signals.                                                                                                                                                                                                                                             | DramParEn                                     |
| Link Retry                    | A transmission error occurred on the link; the IO link<br>Error Retry Protocol is executed. Retry may have been<br>initiated by either end of the link.                                                                                                                                                         | RtryHt0En, RtryHt1En,<br>RtryHt2En, RtryHt3En |
| GART Table<br>Walk Data Error | An uncorrectable error was found in data returned from a GART table walk.                                                                                                                                                                                                                                       | TblWlkDatErrEn                                |
| DEV Table Walk<br>Data Error  | An uncorrectable error was found in data returned from a DEV table walk.                                                                                                                                                                                                                                        | TblWlkDatErrEn                                |
| L3 Cache Data<br>Error        | ECC error detected in L3 cache data. A sync flood occurs.                                                                                                                                                                                                                                                       | L3ArrayCorEn, L3ArrayUCEn                     |
| L3 Cache Tag<br>Error         | Error detected in L3 cache tag. A sync flood occurs.  The subcache, index, and way are logged. See Table 54 footnotes for details.                                                                                                                                                                              | L3ArrayCorEn, L3ArrayUCEn                     |
| L3 Cache LRU<br>Error         | Error detected in LRU parity bits. This is a non-fatal error which has no impact on any program execution; LRU state is reset. The cache index is captured for thresholding purposes.                                                                                                                           |                                               |

The NB is capable of reporting the following errors

Table 53: NB error signatures, part 1

|            |                         | Error               |      | Error Code (see F3x48 for encoding) |        |             |              |           |  |  |
|------------|-------------------------|---------------------|------|-------------------------------------|--------|-------------|--------------|-----------|--|--|
| Error Type | Thresh-<br>old<br>Group | 20:16<br>Ext. Error | Туре | 10:9<br>PP                          | 8<br>T | 7:4<br>RRRR | 3:2<br>II/TT | 1:0<br>LL |  |  |
| Reserved.  | -                       | 0_0000              | -    | -                                   | -      | -           | -            | -         |  |  |

<sup>1.</sup> Indicates the type of link attached to the reporting NB, not the instruction type. MEM indicates coherent link, IO indicates IO link.

Table 53: NB error signatures, part 1

|                            | Error                   |                     | Error Code (see F3x48 for enco |            |        |                            |                     |           |  |
|----------------------------|-------------------------|---------------------|--------------------------------|------------|--------|----------------------------|---------------------|-----------|--|
| Error Type                 | Thresh-<br>old<br>Group | 20:16<br>Ext. Error | Type                           | 10:9<br>PP | 8<br>T | 7:4<br>RRRR                | 3:2<br>II/TT        | 1:0<br>LL |  |
| CRC Error                  |                         | 0_0001              | BUS                            | OBS        | 0      | GEN                        | GEN                 | LG        |  |
| Sync Error                 | 1                       | 0_0010              | BUS                            | OBS        | 0      | GEN                        | GEN                 | LG        |  |
| Mst Abort                  |                         | 0_0011              | BUS                            | SRC/OBS    | 0      | RD/WR                      | MEM/IO <sup>1</sup> | LG        |  |
| Tgt Abort                  | Link                    | 0_0100              | BUS                            | SRC/OBS    | 0      | RD/WR                      | MEM/IO <sup>1</sup> | LG        |  |
| GART Error                 | 1                       | 0_0101              | TLB                            | -          | -      | -                          | GEN                 | LG        |  |
| RMW Error                  | 1                       | 0_0110              | BUS                            | OBS        | 0      | GEN                        | IO                  | LG        |  |
| WDT Error                  | 1                       | 0_0111              | BUS                            | GEN        | 1      | GEN                        | GEN                 | LG        |  |
| ECC Error                  | DRAM                    | 0_1000              | BUS                            | SRC/RES    | 0      | RD/WR                      | MEM                 | LG        |  |
| DEV Error                  |                         | 0_1001              | BUS                            | SRC/OBS    | 0      | RD/WR                      | MEM/IO              | LG        |  |
| Link Data Error            | Link                    | 0_1010              | BUS                            | SRC/OBS    | 0      | RD/WR/<br>DWR              | MEM/IO              | LG        |  |
| Link Protocol Error        |                         | 0_1011              | BUS                            | OBS        | 0      | GEN                        | GEN                 | LG        |  |
| L3 Protocol Error          | -                       |                     |                                |            |        |                            |                     |           |  |
| NB Array Error             | -                       | 0_1100              | BUS                            | OBS        | 0      | GEN                        | GEN                 | LG        |  |
| DRAM Parity Error          | DRAM                    | 0_1101              | BUS                            | OBS        | 0      | GEN                        | MEM                 | LG        |  |
| Link Retry                 |                         | 0_1110              | BUS                            | OBS        | 0      | GEN                        | GEN                 | LG        |  |
| GART Table Walk Data Error | Link                    | 0_1111              | TLB                            | =          | -      | -                          | GEN                 | LG        |  |
| DEV Table Walk Data Error  |                         | 0_1111              | BUS                            | OBS        | 0      | GEN                        | MEM                 | LG        |  |
| L3 Cache Data Error        |                         | 1_1100              | MEM                            | -          | -      | RD/Evict<br>/Snoop<br>/GEN | GEN                 | LG        |  |
| L3 CacheTag Error          | L3<br>Cache             | 1_1101              | MEM                            | -          | -      | RD/Evict<br>/Snoop<br>/GEN | GEN                 | LG        |  |
| L3 Cache LRU Error         |                         | 1_1110              | MEM                            | -          | -      | RD/Evict<br>/Snoop<br>/GEN | GEN                 | LG        |  |

<sup>1.</sup> Indicates the type of link attached to the reporting NB, not the instruction type. MEM indicates coherent link, IO indicates IO link.

Table 54: NB error signatures, part 2

| Error Type                       | F3x4C settings                   |                |                                                       |                   |                                         |                                  |                    |            |                    |                   |  |
|----------------------------------|----------------------------------|----------------|-------------------------------------------------------|-------------------|-----------------------------------------|----------------------------------|--------------------|------------|--------------------|-------------------|--|
|                                  | 29<br>UC                         | 26<br>AddrV    | 25<br>PCC                                             | Syndrome<br>Valid | 14<br>CECC                              | 13<br>UECC                       | 12<br>Reser<br>ved | 8<br>Scrub | 7:4<br>LDT<br>Link | 3:0<br>Err<br>CPU |  |
| CRC Error                        | 1                                | 0              | 1                                                     | -                 | 0                                       | 0                                |                    | 0          | Y                  | -                 |  |
| Sync Error                       | 1                                | 0              | 1                                                     | -                 | 0                                       | 0                                |                    | 0          | Y                  | -                 |  |
| Mst Abort                        | 1                                | 1              | If CPU source                                         | -                 | 0                                       | 0                                |                    | 0          | Y                  | Y                 |  |
| Tgt Abort                        | 1                                | 1              | If CPU source                                         | -                 | 0                                       | 0                                |                    | 0          | Y                  | Y                 |  |
| GART Error                       | 1                                | 1              | If CPU source                                         | -                 | 0                                       | 0                                |                    | 0          | -                  | Y                 |  |
| RMW Error                        | 1                                | 1              | 0                                                     | -                 | 0                                       | 0                                |                    | 0          | Y                  | -                 |  |
| WDT Error                        | 1                                | $0^1$          | 1                                                     | -                 | 0                                       | 0                                |                    | 0          | -                  | -                 |  |
| ECC Error                        | If multi-<br>symbol <sup>8</sup> | 1              | If multi-<br>symbol <sup>8</sup><br>and CPU<br>source | 15:0              | If not<br>multi-<br>symbol <sup>8</sup> | If multi-<br>symbol <sup>8</sup> |                    | 1/0        | -                  | -                 |  |
| DEV Error                        | 1                                | 1              | 0                                                     | -                 | 0                                       | 0                                |                    | 0          | Y                  | -                 |  |
| Link Data<br>Error               | 1                                | 1              | 0                                                     | -                 | 0                                       | 0                                |                    | 0          | Y                  | -                 |  |
| Link<br>Protocol<br>Error        | 1                                | $0^2$          | 1                                                     | -                 | 0                                       | 0                                |                    | 0          | Y                  | -                 |  |
| L3 Protocol<br>Error             | 1                                | $0^3$          | 1                                                     | -                 | 0                                       | 0                                |                    | 0          | -                  | -                 |  |
| NB Array<br>Error                | 1                                | 1 <sup>4</sup> | 1                                                     | -                 | 0                                       | 0                                |                    | 0          | -                  | -                 |  |
| DRAM<br>Parity Error             | 1                                | 0              | 1                                                     | -                 | 0                                       | 0                                |                    | 0          | -                  | -                 |  |
| Link Retry <sup>9</sup>          | 0                                | 0              | 0                                                     | -                 | 0                                       | 0                                |                    | 0          | Y                  | -                 |  |
| GART Table<br>Walk Data<br>Error | 1                                | 1              | If CPU source                                         | -                 | 0                                       | 0                                |                    | 0          | -                  | If CPU source     |  |

- 1. See Table 60, "MCA NB Address Low Register encoding for Watchdog Timer Errors," on page 222
- 2. See Table 56, "MCA NB Address Low Register encoding for Link Protocol Errors," on page 219
- 3. See Table 57, "MCA NB Address Low Register encoding for L3 Protocol Errors," on page 220
- 4. See Table 58, "MCA NB Address Low Register encoding for NB Array Errors," on page 221
- 5. See Table 59, "MCA NB Address Register encoding for L3 Array Errors," on page 222
- 6. This field contains the L3 way in error. F3x4C[McaStatSubCache] contains the subcache number.
- 7. Depends on Memory Transaction Type (Table 49); valid if non-zero.
- 8. x4 Chipkill ECC is always enabled in ganged mode. See F3x44[ChipKillEccEn] for information on symbol size.
- 9. Retries initiated by either side of the link are logged.

Table 54: NB error signatures, part 2

| Error Type                      | F3x4C settings |                |           |                   |                   |                  |                    |            |                    |                   |
|---------------------------------|----------------|----------------|-----------|-------------------|-------------------|------------------|--------------------|------------|--------------------|-------------------|
|                                 | 29<br>UC       | 26<br>AddrV    | 25<br>PCC | Syndrome<br>Valid | 14<br>CECC        | 13<br>UECC       | 12<br>Reser<br>ved | 8<br>Scrub | 7:4<br>LDT<br>Link | 3:0<br>Err<br>CPU |
| DEV Table<br>Walk Data<br>Error | 1              | 1              | 0         | -                 | 0                 | 0                |                    | 0          | -                  | -                 |
| L3 Cache<br>Data Error          | If UECC        | 15             | If UC     | 15:0              | If single-<br>bit | If multi-<br>bit |                    | 1/0        | $\mathbf{Y}^6$     | $\mathbf{Y}^7$    |
| L3 Cache<br>Tag Error           |                |                |           |                   |                   |                  |                    |            |                    |                   |
| L3 Cache<br>LRU Error           | 0              | 1 <sup>5</sup> | 0         | 0                 | 0                 | 0                |                    | 0          | -                  | -                 |

- 1. See Table 60, "MCA NB Address Low Register encoding for Watchdog Timer Errors," on page 222
- 2. See Table 56, "MCA NB Address Low Register encoding for Link Protocol Errors," on page 219
- 3. See Table 57, "MCA NB Address Low Register encoding for L3 Protocol Errors," on page 220
- 4. See Table 58, "MCA NB Address Low Register encoding for NB Array Errors," on page 221
- 5. See Table 59, "MCA NB Address Register encoding for L3 Array Errors," on page 222
- 6. This field contains the L3 way in error. F3x4C[McaStatSubCache] contains the subcache number.
- 7. Depends on Memory Transaction Type (Table 49); valid if non-zero.
- 8. x4 Chipkill ECC is always enabled in ganged mode. See F3x44[ChipKillEccEn] for information on symbol size.
- 9. Retries initiated by either side of the link are logged.

#### F3x4C MCA NB Status High Register

Cold Reset: xxxx xxxxh.

Software is normally only allowed to write 0's to this register to clear the fields so subsequent errors may be logged. See also MSRC001\_0015[McStatusWrEn]. This register may be accessed through [The NB Machine Check Status Register (MC4\_STATUS)] MSR0000\_0411 as well.

| Bits | Description                                                                                                                                                                                                                                                                                                                                             |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | <b>Val: error valid</b> . Read-write; set-by-hardware. 1=This bit indicates that a valid error has been detected. This bit should be cleared to 0 by software after the register has been read.                                                                                                                                                         |
| 30   | Over: error overflow. Read-write; set-by-hardware. 1=An error was detected while the valid bit (Val) of this register was set; at least one error was not logged. The machine check mechanism handles the contents of MCi_STATUS during overflow as outlined in section 2.13.1.2.2 [Machine Check Error Logging Overwrite During Overflow] on page 116. |
| 29   | UC: error uncorrected. Read-write; set-by-hardware. 1=The error was not corrected by hardware.                                                                                                                                                                                                                                                          |
| 28   | <b>En: error enable</b> . Read-write; set-by-hardware. 1=The MCA error reporting is enabled for this error in the MCA Control Register.                                                                                                                                                                                                                 |
| 27   | <b>MiscV: miscellaneous error register valid</b> . Read-only. 1=The error currently logged in the NB MCA registers includes valid information in [The NB Machine Check Misc (Thresholding) Registers] F3x1[78, 70, 68, 60].                                                                                                                             |
| 26   | <b>AddrV: error address valid.</b> Read-write; set-by-hardware. 1=The address saved in the address register is the address where the error occurred.                                                                                                                                                                                                    |

| 25    | <b>PCC: processor context corrupt</b> . Read-write; set-by-hardware. 1=The state of the processor may be corrupted by the error condition. Reliable restarting might not be possible.                                                                                                                                                                           |  |  |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 24:23 | Reserved.                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| 22:15 | <b>Syndrome[7:0]: syndrome bits [7:0] for ECC</b> . Read-write. Logs the lower eight syndrome bits when an ECC error is detected.                                                                                                                                                                                                                               |  |  |  |  |
| 14    | <b>CECC: correctable ECC error</b> . Read-write; set-by-hardware. 1=The error was a correctable ECC error.                                                                                                                                                                                                                                                      |  |  |  |  |
| 13    | <b>UECC: uncorrectable ECC error</b> . Read-write; set-by-hardware. 1=The error was an uncorrectable ECC error.                                                                                                                                                                                                                                                 |  |  |  |  |
| 12    | Reserved.                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| 11:10 | <b>McaStatSubCache:</b> L3 subcache in error. Indicates the number of the L3 subcache associated with the error. This field is only valid when an L3 error is recorded.                                                                                                                                                                                         |  |  |  |  |
| 9     | SubLink: sublink or DRAM channel. Read-write; set-by-hardware. For errors associated with a link, this bit indicates if the error was associated with the upper or lower byte of the link. For DRAM parity errors, this bit indicates which channel the error was associated with.  DRAM Channel  O = Channel A  O = Bits [7:0]  1 = Channel B  1 = Bits [15:8] |  |  |  |  |
| 8     | <b>Scrub: error found by DRAM scrubber</b> . Read-write; set-by-hardware. 1=The error was found by the DRAM scrubber.                                                                                                                                                                                                                                           |  |  |  |  |
| 7:4   | LDTLink[3:0]. Read-write; set-by-hardware. For errors associated with a link, this field indicates which link was associated with the error. LDTLink[3] = Error associated with link 3. LDTLink[2] = Error associated with link 2. LDTLink[1] = Error associated with link 1. LDTLink[0] = Error associated with link 0.                                        |  |  |  |  |
|       | For L3 cache errors, this field indicates the L3 way in error, and McaStatSubCache contains subcache number.                                                                                                                                                                                                                                                    |  |  |  |  |
| 3:0   | ErrCPU[3:0]: error associated with CPU N. Read-write; set-by-hardware. This field indicates which CPU core within the node is associated with the error.  ErrCPU[3] = Error associated with CPU core 3.  ErrCPU[2] = Error associated with CPU core 2.  ErrCPU[1] = Error associated with CPU core 1.  ErrCPU[0] = Error associated with CPU core 0.            |  |  |  |  |

## F3x50 MCA NB Address Low Register

Cold Reset: xxxx xxxxh. F3x50 maps the lower half of [The NB Machine Check Address Register (MC4\_ADDR)] MSR0000\_0412, and F3x54 maps the upper half. MC4\_ADDR carries supplemental information associated with a machine check error, generally the address being accessed.

| Bits | Description                                                                                 |
|------|---------------------------------------------------------------------------------------------|
|      | ErrAddr[31:1]: Error Address Bits[31:1]. Read-write. See the tables below for the encoding. |
|      | $ErrAddr[47:1] = \{F3x54[ErrAddr[47:32]], F3x50[ErrAddr[31:1]]\};$                          |
| 0    | Reserved.                                                                                   |

The register format depends on the type of error being logged:

- Link protocol errors contain the error reason code, and are formatted according to Table 56.
- L3 protocol errors contain the error reason code, and are formatted according to Table 57.
- NB array errors indicate the array in error, and are formatted according to Table 58.
- L3 array errors store the physical address which caused the error, and are formatted according to Table 59.
- Watchdog timer errors are formatted according to Table 60.
- All other NB errors which indicate F3x4C[AddrV] are formatted according to Table 55.

### Table 55: Default MCA NB Address Register default encoding

| ErrAddr<br>bits | Description                |
|-----------------|----------------------------|
| 47:1            | Physical address bits 47:1 |
| 0               | Reserved                   |

#### Table 56: MCA NB Address Low Register encoding for Link Protocol Errors

| ErrAddr<br>bits | Link<br>Protocol<br>Error | Description                                                                                                                                                                                                                                                                                                                     |
|-----------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | Type                      |                                                                                                                                                                                                                                                                                                                                 |
| 39:6            | -                         | Reserved                                                                                                                                                                                                                                                                                                                        |
| 5:1             | 0_0000                    | SRQ Read Response without matching request                                                                                                                                                                                                                                                                                      |
|                 | 0_0001                    | Probe Response without matching request                                                                                                                                                                                                                                                                                         |
|                 | 0_0010                    | TgtDone without matching request                                                                                                                                                                                                                                                                                                |
|                 | 0_0011                    | TgtStart without matching request                                                                                                                                                                                                                                                                                               |
|                 | 0_0100                    | Command buffer overflow                                                                                                                                                                                                                                                                                                         |
|                 | 0_0101                    | Data buffer overflow                                                                                                                                                                                                                                                                                                            |
|                 | 0_0110                    | Link retry packet count acknowledge overflow                                                                                                                                                                                                                                                                                    |
|                 | 0_0111                    | Data command in the middle of a data transfer                                                                                                                                                                                                                                                                                   |
|                 | 0_1000                    | Link address extension command followed by a packet other than a command with address.                                                                                                                                                                                                                                          |
|                 | 0_1001                    | A specific coherent-only packet from a CPU was issued to an IO link.                                                                                                                                                                                                                                                            |
|                 | 0_1010                    | A command with invalid encoding was received. This error occurs when: (1) any invalid command is received (including a command with no valid encoding or a coherent link command over an IO link or vice versa) while not in retry mode or (2) any illegal command is received in which the CRC is correct while in retry mode. |
|                 | 0_1011                    | Link CTL deassertion occurred when a data phase was not pending. This error condition may only occur when error-retry mode is not enabled (if it is enabled, this condition triggers a retry).                                                                                                                                  |

# Table 57: MCA NB Address Low Register encoding for L3 Protocol Errors

| ErrAddr | L3       | Description                           |
|---------|----------|---------------------------------------|
| bits    | Protocol |                                       |
|         | Error    |                                       |
|         | Type     |                                       |
| 39:6    | -        | Reserved                              |
| 5:1     | 1_0000   | Request gets multiple hits in L3      |
|         | 1_0001   | Probe access gets multiple hits in L3 |
|         | 1_0010   | Request queue overflow                |
|         | 1_0011   | WrVicBlk hit incompatible L3 state    |
|         | 1_0100   | ClVicBlk hit incompatible L3 state    |

Table 58: MCA NB Address Low Register encoding for NB Array Errors

| ErrAddr<br>bits | Array<br>Code | Description                                   |
|-----------------|---------------|-----------------------------------------------|
| 39:6            | -             | Reserved                                      |
| 5:1             | 0_0000        | SRA: System request address                   |
|                 | 0_0001        | SRD: System request data                      |
|                 | 0_0010        | SPB: System packet buffer                     |
|                 | 0_0011        | MCD: Memory controller data                   |
|                 | 0_0100        | MPB: Memory packet buffer                     |
|                 | 0_0101        | LPB0: Link 0 packet buffer                    |
|                 | 0_0110        | LPB1: Link 1 packet buffer                    |
|                 | 0_0111        | LPB2: Link 2 packet buffer                    |
|                 | 0_1000        | LPB3: Link 3 packet buffer                    |
|                 | 0_1001        | MPBC: Memory controller command packet buffer |
|                 | 0_1010        | MCDBM: Memory controller byte mask            |
|                 | 0_1011        | MCACAM: Memory controller address array       |
|                 | 0_1100        | DMAP: Extended DRAM address map               |
|                 | 0_1101        | MMAP: Extended MMIO address map               |
|                 | 0_1110        | X86MAP: Extended PCI/IO address map           |
|                 | 0_1111        | CFGMAP: Extended config address map           |
|                 | 1_0000        | LPS0: Link 0 packet state buffer              |
|                 | 1_0001        | LPS1: Link 1 packet state buffer              |
|                 | 1_0010        | LPS2: Link 2 packet state buffer              |
|                 | 1_0011        | LPS3: Link 3 packet state buffer              |
|                 | 1_0100        | RHB0: Link 0 retry history buffer             |
|                 | 1_0101        | RHB1: Link 1 retry history buffer             |
|                 |               | RHB2: Link 2 retry history buffer             |
|                 | 1_0111        | RHB3: Link 3 retry history buffer             |
|                 | 1_1000        | SRIMCTRTE: SRI/MCT extended routing table     |
|                 | 1_1001        | LN0LN1RTE: Link 0/1 extended routing table    |
|                 | 1_1010        | LN2LN3RTE: Link 2/3 extended routing table    |
|                 | 1_1011        | GART: GART array                              |
|                 | 1_1100        | DEV: DEV array                                |

Table 59: MCA NB Address Register encoding for L3 Array Errors

| Error Type          | Memory Transaction<br>Type (RRRR; Table 49) | ErrAddr<br>bits <sup>1</sup> | Description                                                                                          |
|---------------------|---------------------------------------------|------------------------------|------------------------------------------------------------------------------------------------------|
| Data Error          | RD, Evict                                   | 47:2                         | Physical address                                                                                     |
|                     | Snoop                                       | 47:6                         | Cache line address requested                                                                         |
|                     |                                             | 5:4                          | Index of the critical octword within the cache line                                                  |
|                     |                                             | 3:2                          | Index of the octword in error within the cache line (normally occupies bits 5:4 in physical address) |
|                     | GEN                                         | 16:6                         | Cache index                                                                                          |
| Tag or LRU<br>error | RD, Evict, Snoop                            | 47:6                         | Physical address contained in the tag (may not match the address requested)                          |
|                     | GEN                                         | 16:6                         | Cache index                                                                                          |
| 1. The physica      | l address includes the cache                | e index in bits              | 16:6.                                                                                                |

Table 60: MCA NB Address Low Register encoding for Watchdog Timer Errors

| ErrAddr | Description                                                                                                                  |
|---------|------------------------------------------------------------------------------------------------------------------------------|
| bits    |                                                                                                                              |
| 39:36   | System Response Count                                                                                                        |
| 35:31   | Wait Code (Implementation-specific. All zeroes means no waiting condition.)                                                  |
| 30      | Wait for Posted Write                                                                                                        |
| 29:27   | Destination Node                                                                                                             |
| 26:25   | Destination Unit $00 = \text{CPU}$ $01 = \text{GART or DEV Table Walker}$ $10 = \text{Memory Controller}$ $11 = \text{Host}$ |
| 24:22   | Source Node                                                                                                                  |
| 21:20   | Source Unit                                                                                                                  |
| 19:15   | Source Pointer (Identifies link as a crossbar source.)                                                                       |
| 14:11   | SRQ Entry State                                                                                                              |
| 10:7    | Ор Туре                                                                                                                      |
| 6:1     | Command                                                                                                                      |

# F3x54 MCA NB Address High Register

Cold Reset: 0000 xxxxh. F3x54 maps the upper half of [The NB Machine Check Address Register (MC4\_ADDR)] MSR0000\_0412, and F3x50 maps the lower half.

| Bits  | Description                                                                            |
|-------|----------------------------------------------------------------------------------------|
| 31:16 | Reserved.                                                                              |
| 15:0  | ErrAddr[47:32]: Error Address Bits[47:32]. Read-write. See F3x50[ErrAddr] for details. |

#### F3x58 Scrub Rate Control Register

Reset: 0000 0000h. This register specifies the ECC scrubbing rate for memory blocks. See also section 2.6.6 [Memory Scrubbers] on page 54. The scrub rate is specified as the time between successive scrub events. A scrub event occurs when a line of memory is checked for errors; the amount of memory that is checked varies based on the memory block (see field descriptions). Each of these fields is defined as follows:

| <b>Bits</b> | Scrub Rate                   | <b>Bits</b> | Scrub Rate | <u>Bits</u> | Scrub Rate       |
|-------------|------------------------------|-------------|------------|-------------|------------------|
| 00h         | Disable sequential scrubbing | 08h         | 5.12 us    | 10h         | 1.31 ms          |
| 01h         | 40 ns                        | 09h         | 10.2 us    | 11h         | 2.62 ms          |
| 02h         | 80 ns                        | 0Ah         | 20.5 us    | 12h         | 5.24 ms          |
| 03h         | 160 ns                       | 0Bh         | 41.0 us    | 13h         | 10.49 ms         |
| 04h         | 320 ns                       | 0Ch         | 81.9 us    | 14h         | 20.97 ms         |
| 05h         | 640 ns                       | 0Dh         | 163.8 us   | 15h         | 42 ms            |
| 06h         | 1.28 us                      | 0Eh         | 327.7 us   | 16h         | 84 ms            |
| 07h         | 2.56 us                      | 0Fh         | 655.4 us   | All oth     | ners - reserved. |

The desired scrubbing rate may vary with different customers. The time required to fully scrub the memory of a node is determined as: Time = ( (memory size in bytes)/64) \* (Scrub Rate). For example, if a node contains 4GB of system memory and DramScrub=1.31ms, then all of the system memory of the node is scrubbed about once every 23 hours.

| Bits  | Description                                                                                                                                                                      |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Reserved.                                                                                                                                                                        |
| 28:24 | L3Scrub: L3 cache scrub rate. Read-write. Read-write. Specifies time between 64-byte scrub events. Note: the L3 scrubber should be disabled (L3Scrub=00h) if F3xE8[L3Capable]=0. |
| 23:21 | Reserved.                                                                                                                                                                        |
| 20:16 | <b>DcacheScrub: data cache scrub rate</b> . Read-write. Specifies time between 64-bit scrub events. BIOS must not set this scrub rate to less than 1.28 us.                      |
| 15:13 | Reserved.                                                                                                                                                                        |
| 12:8  | <b>L2Scrub: L2 cache scrub rate</b> . Read-write. Read-write. Specifies time between 64-byte scrub events. BIOS must not set this scrub rate to less than 1.28 us.               |
| 7:5   | Reserved.                                                                                                                                                                        |
| 4:0   | <b>DramScrub: DRAM scrub rate</b> . Read-write. Specifies time between 64-byte scrub events. See also F3x5C and F3x60.                                                           |

#### F3x5C DRAM Scrub Address Low Register

Reset: see field definitions. In addition to sequential DRAM scrubbing, the DRAM scrubber has a redirect mode for scrubbing DRAM locations accessed during normal operation. This is enabled by setting F3x5C[ScrubReDirEn]. When a DRAM read is generated by any agent other than the DRAM scrubber, correctable ECC errors are corrected as the data is passed to the requestor, but the data in DRAM is not corrected if redirect scrubbing mode is disabled. In scrubber redirect mode, correctable errors detected during normal DRAM read accesses redirect the scrubber to the location of the error. After the scrubber corrects the location in DRAM, it resumes scrubbing from where it left off. DRAM scrub address registers are not modified by the redirect scrubbing mode. Sequential scrubbing and scrubber redirection can be enabled independently or together.

ECC errors detected by the scrubber are logged in the MCA registers (see also [The MCA NB Control Regis-

## ter] F3x40).

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | ScrubAddrLo: DRAM scrubber address bits[31:6]. Read; write to initialize; updated by hardware. Reset: X. The DRAM scrubber address consists of {F3x60[ScrubAddrHi], F3x5C[ScrubAddrLo]}; it points to a DRAM cacheline in physical address space. BIOS should initialize the scrubber address register to the base address of the node specified by [The DRAM Base/Limit Registers] F1x[1, 0][7C:40] prior to enabling sequential scrubbing through F3x58[DramScrub]. When sequential scrubbing is enabled: it starts at the address that the scrubber address registers are initialized to; it increments through address space and updates the scrubber address registers as it does so; when the scrubber reaches the DRAM limit address specified by F1x[1, 0][7C:40], it wraps around to the base address. Reads of the scrubber address registers provide the next cacheline to be scrubbed. |
| 5:1  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0    | ScrubReDirEn: DRAM scrubber redirect enable. Read-write. Reset: 0. If a correctable error is discovered from a non-scrubber DRAM read, then the data is corrected before it is returned to the requestor; however, the DRAM location may be left in a corrupted state (until the next time the scrubber address counts up to that location, if sequential scrubbing is enabled through F3x58[DramScrub]). 1=Enables the scrubber to immediately scrub any address in which a correctable error is discovered. This bit and sequential scrubbing can be enabled independently or together; if both are enabled, the scrubber jumps from the scrubber address to where the correctable error was discovered, scrubs that location, and then jumps back to where it left off; the scrubber address register is not affected during scrubber redirection.                                              |

## F3x60 DRAM Scrub Address High Register

Reset: see field definitions.

| Bits  | Description                                                                           |
|-------|---------------------------------------------------------------------------------------|
| 31:16 | Reserved.                                                                             |
| 15:0  | ScrubAddrHi: DRAM scrubber address bits[47:32]. Read; write to initialize; updated by |
|       | hardware. Reset: X. See F3x5C[ScrubAddrLo].                                           |

## F3x64 Hardware Thermal Control (HTC) Register

See section 2.10.3.1 [PROCHOT\_L and Hardware Thermal Control (HTC)] on page 111 for information on HTC. F3x64 is not accessible if [The Northbridge Capabilities Register] F3xE8[HTC capable]=0.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                         |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved.                                                                                                                                                                                                                                                                                                                                                           |
| 30:28 | <b>HtcPstateLimit: HTC P-state limit select</b> . Read-write. Reset state varies by product. Specifies the P-state limit of all CPU cores when in the HTC-active state. This field is not changed on a write if the value written is greater than MSRC001_0061[PstateMaxVal]. See also section 2.10.3.1 [PROCHOT_L and Hardware Thermal Control (HTC)] on page 111. |
| 27:24 | HtcHystLmt: HTC hysteresis. Read-write. Reset state varies by product. The processor exits the HTC-active state when Tctl is less than HtcTmpLmt minus HtcHystLmt. The encoding is 0.5 * HtcHystLmt, ranging from 0.0 Tctl to 7.5 Tctl.                                                                                                                             |
| 23    | <b>HtcSlewSel: HTC slew-controlled temperature select.</b> Read-write. Reset: 0. 1=HTC logic is driven by the slew-controlled temperature, Tctl, specified in [The Reported Temperature Control Register] F3xA4. 0=HTC logic is driven by the measured control temperature with no slew controls.                                                                   |

| 22:16 | <b>HtcTmpLmt: HTC temperature limit</b> . Read-write. Reset state varies by product. The processor enters the HTC-active state when Tctl reaches or exceeds the value of this register. The encoding is                                                                                                                                                                                                                                                                                                                                                    |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 52.0 + (0.5 * HtcTmpLmt), ranging from 52.0 Tctl to 115.5 Tctl.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15:8  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7     | PslApicLoEn: P-state limit lower value change APIC interrupt enable. Read-write. Reset: 0. PslApicLoEn and PslApicHiEn enable interrupts using [The Thermal Local Vector Table Entry] APIC330 of each CPU core when the active P-state limit in [The P-State Current Limit Register] MSRC001_0061[CurPstateLimit] changes. PslApicLoEn enables the interrupt when the limit value becomes lower (indicating higher performance). PslApicHiEn enables the interrupt when the limit value becomes higher (indicating lower performance). 1=Enable interrupt. |
| 6     | <b>PslApicHiEn: P-state limit higher value change APIC interrupt enable</b> . Read-write. Reset: 0. See PslApicLoEn above.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5     | <b>HtcActSts: HTC-active status</b> . Read; set-by-hardware; write-1-to-clear. Reset: 0. This bit is set by hardware when the processor enters the HTC-active state. It is cleared by writing a 1 to it.                                                                                                                                                                                                                                                                                                                                                   |
| 4     | <b>HtcAct: HTC-active state</b> . Read-only. Reset: X. 1=The processor is currently in the HTC-active state. 0=The processor is not in the HTC-active state.                                                                                                                                                                                                                                                                                                                                                                                               |
| 3     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2     | Must be high. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1     | Must be low. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0     | <b>HtcEn: HTC enable</b> . Read-write. Reset: 0. 1=HTC is enabled; the processor is capable of entering the HTC-active state.                                                                                                                                                                                                                                                                                                                                                                                                                              |

# F3x68 Software Thermal Control (STC) Register

Reset: ?000 0000h. See section 2.10.3.2 [Software Thermal Control (STC)] on page 111 for information on STC. F3x68 is not accessible if [The Northbridge Capabilities Register] F3xE8[HTC capable]=0.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                           |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved.                                                                                                                                                                                                                                                                                                                                             |
| 30:28 | <b>StcPstateLimit: STC P-state limit select</b> . Read-write. Reset state varies by product. Specifies the P-state limit of all CPU cores when in the STC-active state. This field is not changed on a write if the value written is greater than MSRC001_0061[PstateMaxVal]. See also section 2.10.3.2 [Software Thermal Control (STC)] on page 111. |
| 27:24 | <b>StcHystLmt: STC hysteresis</b> . Read-write. The processor exits the STC thermal zone when Tctl drops to StcTmpLmt minus StcHystLmt. The encoding is 1.0 * StcHystLmt, ranging from 0.0 Tctl to 15.0 Tctl.                                                                                                                                         |
| 23    | <b>StcSlewSel: STC slew-controlled temperature select</b> . Read-write. Reset: 0. 1=STC logic is driven by the slew-controlled temperature, Tctl, specified in [The Reported Temperature Control Register] F3xA4. 0=STC logic is driven by the measured control temperature with no slew controls.                                                    |
| 22:16 | <b>StcTmpLmt: STC temperature limit</b> . Read-write. The processor enters the STC thermal zone when Tctl exceeds the value specified by this register. The encoding is 52.0 + (0.5 * StcTmpLmt), ranging from 52.0 Tctl to 115.5 Tctl.                                                                                                               |
| 15    | Reserved.                                                                                                                                                                                                                                                                                                                                             |
| 14:12 | Reserved.                                                                                                                                                                                                                                                                                                                                             |
| 11    | Reserved.                                                                                                                                                                                                                                                                                                                                             |

| 10:8 | Reserved.                                                                                                                                                                                                                                             |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | <b>StcTmpLoSts: STC temperature low status</b> . Read; write-1-to-clear. This bit is set high when the processor exits the STC thermal zone.                                                                                                          |
| 6    | <b>StcTmpHiSts: STC temperature high status</b> . Read; write-1-to-clear. This bit is set high when the processor enters the STC thermal zone.                                                                                                        |
| 5    | StcPstateEn: STC P-state enable. Read-write. 1=Place the processor into the STC-active state.                                                                                                                                                         |
| 4    | Must be low. Read-write. This bit is required to be low.                                                                                                                                                                                              |
| 3    | <b>StcApcTmpLoEn: STC APIC temperature low interrupt enable</b> . Read-write. 1=Enables the generation of an interrupt using [The Thermal Local Vector Table Entry] APIC330 of each CPU core when the processor exits the STC thermal zone.           |
| 2    | <b>StcApcTmpHiEn: STC APIC temperature high interrupt enable</b> . Read-write. 1=Enables the generation of an interrupt using [The Thermal Local Vector Table Entry] APIC330 of each CPU core when the processer enters the STC thermal zone.         |
| 1    | <b>StcSbcTmpLoEn: STC special bus cycle temperature low enable</b> . Read-write. 1=Enables the generation of a link special bus cycle (SysMgtCmd = 1101_xxx1b, processor thermal trip point crossed) when the processor exits the STC thermal zone.   |
| 0    | <b>StcSbcTmpHiEn: STC special bus cycle temperature high enable</b> . Read-write. 1=Enables the generation of a link special bus cycle (SysMgtCmd = 1101_xxx1b, processor thermal trip point crossed) when the processor enters the STC thermal zone. |

#### F3x6C Data Buffer Count Register

Reset: See field definitions. Updates to this register do not take effect until after a warm reset.

• To ensure deadlock free operation the following minimum buffer allocations are required:

UpRspDBC >= 1 DnRspDBC >=1 DnReqDBC >= 1

UpReqDBC >= 1

- If F0x68[DispRefModeEn] is set or any of the F0x[E4, C4, A4, 84][IsocEn] bits are set: IsocRspDBC >= 1
- The total number of data buffers allocated in this register and F3x7C must satisfy the following equation if DatBuf24=0:

IsocRspDBC + UpRspDBC + DnReqDBC + UpReqDBC + DnRspDBC + F3x7C[Sri2XbarFreeXreqDBC] + F3x7C[Sri2XbarFreeRspDBC] <= 16

• The total number of data buffers allocated in this register and F3x7C must satisfy the following equation if DatBuf24=1:

IsocRspDBC + UpRspDBC + DnReqDBC + UpReqDBC + DnRspDBC + F3x7C[Sri2XbarFreeXreqDBC] + F3x7C[Sri2XbarFreeRspDBC] <= 24

• If the system is not a UMA system, DatBuf24 should be set and the following buffer allocations should be used:

UpRspDBC = 1 DnReqDBC = 1 UpReqDBC = 2

 $DnRspDBC = 1 IsocRspDBC = 0^{1}/1^{2}$ 

- 1. If all of the F0x[E4, C4, A4, 84][IsocEn] bits are clear.
- 2. If any of the F0x[E4, C4, A4, 84][IsocEn] bits are set.

| Bits  | Description                                                                                                                                                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved.                                                                                                                                                                                                                                     |
| 30:28 | IsocRspDBC: isochronous response data buffer count. Read-write. Cold reset: 3.                                                                                                                                                                |
| 27:19 | Reserved.                                                                                                                                                                                                                                     |
| 18:16 | UpRspDBC: upstream response data buffer count. Read-write. Cold reset: 2.                                                                                                                                                                     |
| 15    | <b>DatBuf24: data buffer allocation 24</b> . Read-write. Cold reset: 0. 1=24 SRI to XBAR data buffers allocated. 32 SRI to XBAR command buffers allocated. 0=16 SRI to XBAR data buffers allocated. 64 SRI to XBAR command buffers allocated. |
| 14:8  | Reserved.                                                                                                                                                                                                                                     |
| 7:6   | DnRspDBC: downstream response data buffer count. Read-write. Cold reset: 2.                                                                                                                                                                   |
| 5:4   | DnReqDBC: downstream request data buffer count. Read-write. Cold reset: 1.                                                                                                                                                                    |
| 3     | Reserved.                                                                                                                                                                                                                                     |
| 2:0   | UpReqDBC: upstream request data buffer count. Read-write. Cold reset: 2.                                                                                                                                                                      |

#### F3x70 SRI to XBAR Command Buffer Count Register

Reset: See field definitions. Updates to this register do not take effect until after a warm reset.

• To ensure deadlock free operation the following minimum buffer allocations are required:

 $\begin{array}{lll} UpRspCBC >= 1 & UpPreqCBC >= 1 & DnPreqCBC >= 1 \\ UpReqCBC >= 1 & DnRspCBC >= 1 & DnRspCBC >= 1 \end{array}$ 

• If F0x68[DispRefModeEn] is set or any of the F0x[E4, C4, A4, 84][IsocEn] bits are set:

 $IsocReqCBC >= 1 \qquad IsocRspCBC >= 1$ 

• If any of the F0x[E4, C4, A4, 84][IsocEn] bits are set: IsocPreqCBC >= 1

• The total number of SRI to XBAR command buffers allocated in this register and F3x7C must satisfy the following equation if F3x6C[DatBuf24]=0:

IsocRspCBC + IsocPreqCBC + IsocReqCBC + UpRspCBC + DnPreqCBC + UpPreqCBC + DnReqCBC + DnRspCBC + UpReqCBC + F3x7C[Sri2XbarFreeRspCBC] + F3x7C[Sri2XbarFreeXreqCBC] <= 64

• The total number of SRI to XBAR command buffers allocated in this register and F3x7C must satisfy the following equation if F3x6C[DatBuf24]=1:

IsocRspCBC + IsocPreqCBC + IsocReqCBC + UpRspCBC + DnPreqCBC + UpPreqCBC + DnReqCBC + DnRspCBC + UpReqCBC + F3x7C[Sri2XbarFreeRspCBC] + F3x7C[Sri2XbarFreeXreqCBC] <= 32

• If the system is a UMA system, F3x6C[DatBuf24] should be set and the following buffer allocations should be used:

 $\begin{array}{lll} UpRspCBC=2 & UpPreqCBC=1 & DnPreqCBC=1 \\ UpReqCBC=1 & DnReqCBC=1 & DnRspCBC=1 \\ IsocReqCBC=2 & IsocRspCBC=6 & IsocPreqCBC=1 \end{array}$ 

• If the system is not a UMA system, F3x6C[DatBuf24] should be set and the following buffer allocations should be used:

 $\begin{array}{llll} UpRspCBC=4 & UpPreqCBC=1 & DnPreqCBC=1 \\ UpReqCBC=3 & DnReqCBC=1 & DnRspCBC=1 \\ IsocReqCBC=0^1/1^2 & IsocRspCBC=0^1/1^2 & IsocPreqCBC=0^1/1^2 \end{array}$ 

- 1. If all of the F0x[E4, C4, A4, 84][IsocEn] bits are clear.
- 2. If any of the F0x[E4, C4, A4, 84][IsocEn] bits are set.

| Bits  | Description                                                                                   |
|-------|-----------------------------------------------------------------------------------------------|
| 31    | Reserved.                                                                                     |
| 30:28 | IsocRspCBC: isochronous response command buffer count. Read-write. Cold reset: 6.             |
| 27    | Reserved.                                                                                     |
| 26:24 | IsocPreqCBC: isochronous posted request command buffer count. Read-write. Cold reset: 1.      |
| 23    | Reserved.                                                                                     |
| 22:20 | IsocReqCBC: isochronous request command buffer count. Read-write. Cold reset: 7.              |
| 19    | Reserved.                                                                                     |
| 18:16 | UpRspCBC: upstream response command buffer count. Read-write. Cold reset: 4.                  |
| 15    | Reserved.                                                                                     |
| 14:12 | <b>DnPreqCBC: downstream posted request command buffer count</b> . Read-write. Cold reset: 4. |
| 11    | Reserved.                                                                                     |
| 10:8  | UpPreqCBC: upstream posted request command buffer count. Read-write. Cold reset: 4.           |
| 7:6   | DnRspCBC: downstream response command buffer count. Read-write. Cold reset: 2.                |
| 5:4   | DnReqCBC: downstream request command buffer count. Read-write. Cold reset: 2.                 |
| 3     | Reserved.                                                                                     |
| 2:0   | UpReqCBC: upstream request command buffer count. Read-write. Cold reset: 4.                   |

#### F3x74 XBAR to SRI Command Buffer Count Register

Updates to this register do not take effect until after a warm reset.

• To ensure deadlock free operation in a multiprocessor system the following minimum buffer allocations are required:

 $ProbeCBC >= 2 \qquad DnPreqCBC >= 1 \qquad UpPreqCBC >= 1$ 

DnReqCBC >= 1 UpReqCBC >= 1

• To ensure deadlock free operation in a uniprocessor system the following minimum buffer allocations are required:

ProbeCBC >= 2 UpReqCBC >= 1 UpPreqCBC >= 1

- To ensure deadlock free operation ProbeCBC must be less than or equal to 8.
- If F0x68[DispRefModeEn] is set:

IsocReqCBC >= 1

• If any of the F0x[E4, C4, A4, 84][IsocEn] bits are set:

IsocPreqCBC >= 1 IsocReqCBC >= 1

• If F0x68[DispRefModeEn] is set or if any of the F0x[E4, C4, A4, 84][IsocEn] bits are set and F3x158[Lnk-ToXcsDRToken] >0:

 $IsocPreqCBC >= 1 \qquad IsocReqCBC >= 1 \qquad DRReqCBC >= 1$ 

• The total number of XBAR to SRI command buffers allocated in this register and F3x7C must satisfy the following equation if the processor includes a L3 cache:

DRReqCBC + IsocPreqCBC + IsocReqCBC + DnPreqCBC + UpPreqCBC + DnReqCBC + UpReqCBC + F3x7C[Xbar2SriFreeListCBC] + F3x1A0[L3ToSriReqCBC] <= 32

• The total number of XBAR to SRI command buffers allocated in this register and F3x7C must satisfy the following equation if the processor does not include a L3 cache:

DRReqCBC + IsocPreqCBC + IsocReqCBC + DnPreqCBC + UpPreqCBC + DnReqCBC + UpReqCBC + F3x7C[Xbar2SriFreeListCBC] + (F3x1A0[CpuCmdBufCnt] \* (F3xE8[CmpCap] + 1)) <= 32

• If the system is a UMA system and F2x118[MctPriIsoc]=11b, the following settings should be used:

DnPreqCBC = 0 UpReqCBC = 1 F3x7C[Xbar2SriFreeListCBC] = 12

F2x118[MctVarPriCntLmt] = 1

• If the system is a UMA system and F2x118[MctPriIsoc]=10b, the following settings should be used:

 $DRReqCBC = 9 \qquad IsocPreqCBC = 1 \qquad IsocReqCBC = 1$   $ProbeCBC = 8 \qquad UpPreqCBC = 1 \qquad DnReqCBC = 0$ 

DnPreqCBC = 0 UpReqCBC = 1 F3x7C[Xbar2SriFreeListCBC] = 15

• If the system is a UMA system and 32 byte display refresh requests are generated by the graphics engine, the following settings should be used:

 $\begin{array}{ll} DRReqCBC = 15 & IsocPreqCBC = 1 & IsocReqCBC = 1 \\ ProbeCBC = 8 & UpPreqCBC = 1 & DnReqCBC = 0 \end{array}$ 

DnPreqCBC = 0 UpReqCBC = 1 F3x7CXbar2SriFreeListCBC = 9

| Bits  | Description                                                                                      |
|-------|--------------------------------------------------------------------------------------------------|
| 31:28 | DRReqCBC: display refresh request command buffer count. Read-write. Cold reset: 0.               |
| 27    | Reserved.                                                                                        |
| 26:24 | <b>IsocPreqCBC: isochronous posted request command buffer count</b> . Read-write. Cold reset: 0. |
| 23:20 | IsocReqCBC: isochronous request command buffer count. Read-write. Cold reset: 4.                 |
| 19:16 | ProbeCBC: probe command buffer count. Read-write. Cold reset: 8.                                 |
| 15    | Reserved.                                                                                        |
| 14:12 | <b>DnPreqCBC: downstream posted request command buffer count</b> . Read-write. Cold reset: 1.    |
| 11    | Reserved.                                                                                        |
| 10:8  | UpPreqCBC: upstream posted request command buffer count. Read-write. Cold reset: 1.              |
| 7     | Reserved.                                                                                        |
| 6:4   | DnReqCBC: downstream request command buffer count. Read-write. Cold reset: 1.                    |
| 3     | Reserved.                                                                                        |
| 2:0   | UpReqCBC: upstream request command buffer count. Read-write. Cold reset: 1.                      |

#### F3x78 MCT to XBAR Buffer Count Register

Updates to this register do not take effect until after a warm reset.

• To ensure deadlock free operation the following minimum buffer allocations are required:

 $ProbeCBC >= 1 \qquad RspCBC >= 1 \qquad RspDBC >= 2$ 

• To ensure deadlock free operation when online spare is enabled (F2x[1, 0][5C:40][Spare] = 1) the following minimum buffer allocation is required:

RspCBC >= D

• The total number of command buffers allocated in this register must satisfy the following equation: ProbeCBC + RspCBC <= 32

| Bits  | Description                                                                                                                                            |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | Reserved.                                                                                                                                              |
|       | <b>RspDBC:</b> response data buffer count. Read-write. Cold reset: 32. The value of this field is required to be greater than F2x11C[MctPrefReqLimit]. |
| 15:13 | Reserved.                                                                                                                                              |
| 12:8  | ProbeCBC: probe command buffer count. Read-write. Cold reset: Ch.                                                                                      |
| 7:5   | Reserved.                                                                                                                                              |
| 4:0   | RspCBC: response command buffer count. Read-write. Cold reset: 14h.                                                                                    |

#### F3x7C Free List Buffer Count Register

Updates to this register do not take effect until after a warm reset.

- To ensure deadlock free operation the following minimum buffer allocations are required:
  - If Sri2XbarFreeRspCBC = 0: Sri2XbarFreeXreqCBC > 2
  - If Sri2XbarFreeRspCBC != 0: Sri2XbarFreeRspCBC > 2
  - If Sri2XbarFreeRspDBC = 0: Sri2XbarFreeXreqDBC > 2
  - If Sri2XbarFreeRspDBC != 0: Sri2XbarFreeRspDBC > 2
  - Xbar2SriFreeListCBC >= 2
- If the system is a UMA system, the following buffer allocations should be used:

Sri2XbarFreeXreqCBC = 8 Sri2XbarFreeXreqDBC = 7 Sri2XbarFreeRspCBC = 0 Sri2XbarFreeRspDBC = 0

• If the system is not a UMA system, the following buffer allocations should be used:

Sri2XbarFreeXreqCBC = 9 Sri2XbarFreeRspCBC = 0 Sri2XbarFreeRspDBC = 0

| Bits  | Description                                                                                                                                                                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved.                                                                                                                                                                                                                                                                                            |
| 30:28 | <b>Xbar2SriFreeListCBInc: XBAR to SRI free list command buffer increment</b> . Read-write. Cold reset: 0. This is use to add buffers to the free list pool if they are reclaimed from hard allocated entries without having to go through warm reset.                                                |
| 27:23 | Reserved.                                                                                                                                                                                                                                                                                            |
| 22:20 | Sri2XbarFreeRspDBC: SRI to XBAR free response data buffer count. Read-write. Cold reset: 3.                                                                                                                                                                                                          |
| 19:16 | <b>Sri2XbarFreeXreqDBC: SRI to XBAR free request and posted request data buffer count</b> . Readwrite. Cold reset: 3. When Sri2XbarFreeRspDBC=0h, these buffers are shared between requests, responses and posted requests and the number of buffers allocated is two times the value of this field. |

| 15:12 | Sri2XbarFreeRspCBC: SRI to XBAR free response command buffer count. Read-write. Cold                                                                                                                                                                                                                                        |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | reset: 15.                                                                                                                                                                                                                                                                                                                  |
| 11:8  | <b>Sri2XbarFreeXreqCBC: SRI to XBAR free request and posted request command buffer count</b> . Read-write. Cold reset: 15. When Sri2XbarFreeRspCBC=0h, these buffers are shared between requests, responses and posted requests and the number of buffers allocated is two times the value of this field.                   |
| 7:5   | Reserved.                                                                                                                                                                                                                                                                                                                   |
| 4:0   | Xbar2SriFreeListCBC: XBAR to SRI free list command buffer count. Read-write. Cold reset: varies based on the state of F3xE8[CmpCap] and whether the processor includes L3 cache:  1-core without L3cache is 22.  2-core or any processor with L3 cache is 20.  3-core without L3cache is 18.  4-core without L3cache is 16. |

#### F3x[84:80] ACPI Power State Control Registers

Reset: 0000 0000h. This block consists of eight identical 8-bit registers, one for each System Management Action Field (SMAF) code associated with STPCLK assertion commands from the link. Refer to the table below for the associated ACPI state and SMAF code for each of the 8 registers. Some ACPI states and associated SMAF codes may not be supported in certain conditions. Refer to section 2.4 [Power Management] on page 25 for information on which states are supported.

When a link STPCLK assertion command is received by the processor, the power management commands specified by the register with the corresponding SMAF code are invoked. When the STPCLK deassertion command is received by the processor, the processor returns into the operational state.

Note: in multi-node systems, these registers should be programmed identically in all nodes.

**Table 61: ACPI Power State Control Register SMAF Settings** 

| ACPI                 |      | Description/Initiation                                                                                                                                                                                                                                                                              | Register/Setting  |
|----------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| State                | Code |                                                                                                                                                                                                                                                                                                     |                   |
| C2                   | 000b | Initiated by a processor access to the ACPI-defined P_LVL2 register.                                                                                                                                                                                                                                | F3x80[7:0]: 81h   |
| C1E, or<br>Link init | 001b | Initiated by a processor access to the ACPI-defined P_LVL3 register or in response to a write to the Link Frequency Change and Resize LDTSTOP_L Command register in the IO Hub. LDTSTOP_L is expected to be asserted while in this state. C1Eis not supported in multilink or multi-socket systems. |                   |
| FIDVID change        | 010b | Unused                                                                                                                                                                                                                                                                                              | F3x80[23:16]: 00h |
| S1                   | 011b | Initiated by a processor access to the ACPI-defined PM1_CNTa register.                                                                                                                                                                                                                              | F3x80[31:24]: E6h |
| S3                   | 100b | Initiated by a processor access to the ACPI-defined PM1_CNTa register.                                                                                                                                                                                                                              | F3x84[7:0]: E6h   |
| Throttling           | 101b | Occurs based upon SMC hardware-initiated throttling. Refer to section 1.5.2 [Supported Feature Variations] on page 20 for package-specific support. AMD recommends using PROCHOT_L for thermal throttling and not implementing stop clock based throttling.                                         | F3x84[15:8]: 41h  |
| S4/S5                | 110b | Initiated by a processor access to the ACPI-defined PM1_CNTa register.                                                                                                                                                                                                                              | F3x84[23:16]:E6h  |
| C1                   | 111b | Initiated when a Halt instruction is executed by processor. This does not involve the interaction with the SMC, therefore the SMC is required to never send STPCLK assertion commands with SMAF=7h.                                                                                                 | F3x84[31:24]:A0h  |

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:8 | See above.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 7:5  | ClkDivisor: clock divisor. Read-write. Specifies the core clock frequency while in the low-power state. This divisor is relative to the current FID frequency, or:  • 100 MHz * (10h + MSRC001_00[68:64][CpuFid]) of the current P-state specified by MSRC001_0063[CurPstate].  If MSRC001_00[68:64][CpuDid] of the current P-state indicates a divisor that is deeper than specified by this field, then no frequency change is made when entering the low-power state associated with this register. This field is encoded as follows:    Bits   Divisor   Bits   Divisor   Divisor   Divide-by 16.                                                                                                                                                                                                                                                                           |  |  |
| 4    | AltVidEn: alternate VID enable. Read-write. 1=The alternate VID is driven while in the low-power state. If F3xA0[PviMode]=1, then the normal VID is applied; if F3xA0[PviMode]=0, then [The Clock Power/Timing Control 2 Register] F3xDC[AltVid] is applied to the CPU core power plane and the normal VID is applied to VDDNB.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 3    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 2    | <b>NbGateEn:</b> Northbridge gate enable. Read-write. 1=The NB clock is mostly gated off and MEM-CLK is tristated when LDTSTOP_L is asserted while in the low-power state. Setting this bit further reduces dynamic power while in the low-power state. NbLowPwrEn is required to be set if this bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 1    | <b>NbLowPwrEn:</b> Northbridge low-power enable. Read-write. 1=The NB clock is ramped down to the divisor specified by [The Clock Power/Timing Control 0 Register] F3xD4[NbClkDiv] and DRAM is placed into self-refresh mode when LDTSTOP_L is asserted while in the low-power state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 0    | CpuPrbEn: CPU direct probe enable. Read-write. Specifies how probes are handled while in the low-power state. 0=When the probe request comes into the NB, the core clock is brought up to the COF (based on the current P-state), all outstanding probes are completed, the core waits for a hysteresis time based on [The Clock Power/Timing Control 0 Register] F3xD4[ClkRampHystSel], and then the core clock is brought down to the frequency specified by ClkDivisor. 1=The core clock does not change frequency; the probe is handled at the frequency specified by ClkDivisor; this may only be set if:  • ClkDivisor specifies a divide-by 1, 2, 4, 8, or 16 and NbCof <= 3.2 GHz  • ClkDivisor specifies a divide-by 1, 2, 4, or 8 and NbCof >= 3.4 GHz  This bit should be set if probes are expected to occur while in the low-power state associated with the SMAF. |  |  |

## F3x[8C:88] NB Configuration High, Low Registers

These addresses form a duplicated access space for MSRC001\_001F. See MSRC001\_001F[31:0] for F3x88 and MSRC001\_001F[63:32] F3x8C.

## F3x90 GART Aperture Control Register

Reset: 0000 0000h. Note: GART apertures or translations above 1 terabyte are not supported.

| Bits | Description                                                                                                                                                                                                                                                                                     |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | Reserved.                                                                                                                                                                                                                                                                                       |
| 6    | <b>DisGartTblWlkPrb:</b> disable GART table walk probes. Read-write. 1=Disables generation of probes for GART table walks. This bit may be set to improve performance in cases where the GART table entries are in address space which is marked uncacheable in processor MTRRs or page tables. |
| 5    | <b>DisGartIo: disable GART IO accesses</b> . Read-write. 1=Disables requests from IO devices from accessing the GART.                                                                                                                                                                           |
| 4    | <b>DisGartCpu: disable GART CPU accesses</b> . Read-write. 1=Disables requests from CPUs from accessing the GART.                                                                                                                                                                               |
| 3:1  | GartSize: GART size. Read-write. Specifies the size of address space allocated to the GART.  000b = 32 Mbytes  100b = 512 Mbytes  101b = 1 Gbyte  110b = 2 Gbytes  111b = Reserved                                                                                                              |
| 0    | <b>GartEn: GART enable</b> . Read-write. 1=Enables GART address translation for accesses falling within the GART aperture. F3x94[GartAperBaseAddr] and other related registers should be initialized before GartEn is set.                                                                      |

# F3x94 GART Aperture Base Register

Reset: See field definitions.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 14:0  | GartAperBaseAddr[39:25]: GART aperture base address bits[39:25]. Read-write. Reset: X. Specifies the base address of the GART aperture range. Based on F3x90[GartSize], some of the LSB address bits are assumed to be 0 (e.g., if the GART is 1 Gbyte, then only GartAperBaseAddr[39:30] is meaningful). This field along with F3x90[GartSize] specifies the GART aperture address range. BIOS can place the GART aperture below the 4-gigabyte level in address space in order to support legacy operating systems and legacy AGP cards (that do not support 64-bit address space). Note: GART apertures above 1 terabyte are not supported. |

# F3x98 GART Table Base Register

| Reset: xxxx xxx0h. |                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits               | Description                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bits 31:4          | GartTblBaseAdd address of the tabl the GART apertur the physical addre PTE corresponds to lows:  PTE bits 31:12 11:4 3:2 1 0 GART translation | Ir[39:12]: GART table base address bits[39:12]. Read-write. Specifies the base e of GART page table entries (PTEs) used in GART address translation. Accesses to e address range specified by F3x90 and F3x94, address GA[39:0], are translated to ess specified by the corresponding GART PTE. Each PTE is 32-bits wide. The first to the first 4 Kbyte page of the GART aperture, and so on. PTEs are defined as fol-  Description Physical address bits[31:12]. Physical address bits[39:32]. Reserved. Coherent: 1=Probes are required for accesses to the range. Valid: 1=Entry is valid. s to addresses above 1 terabyte are not supported. The page table is required to |
|                    |                                                                                                                                               | AM address ranges. Also, the page tables are expected to translate to DRAM address lations to MMIO ranges result in undefined behavior.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# F3x9C GART Cache Control Register

3:0

Reserved.

| Reset: ( | Reset: 0000 0000h.                                                                                                                                                                                      |  |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits     | Description                                                                                                                                                                                             |  |  |
| 31:2     | Reserved.                                                                                                                                                                                               |  |  |
| 1        | <b>GartPteErr: GART PTE error</b> . Read; set-by-hardware; write-1-to-clear. 1=An invalid PTE was encountered during a table walk.                                                                      |  |  |
| 0        | <b>InvGart: invalidate GART</b> . Read; write-1-only; cleared-by-hardware. Setting this bit causes the GART cache to be invalidated. This bit is cleared by hardware when the invalidation is complete. |  |  |

# F3xA0 Power Control Miscellaneous Register

| Reset: 0000 0000h. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| 31                 | CofVidProg: COF and VID of P-states programmed. Read-only. 1=Out of cold reset, the VID and FID values of the P-state register specified by MSRC001_0071[StartupPstate] have been applied to the processor.0=Out of cold reset, the boot VID is applied to all processor power planes, the NB clock plane is set to 800 MHz (with a FID of 00h=800 MHz and a DID of 0b) and core CPU clock planes are set to 800 MHz (with a FID of 00h=1.6 GHz and a DID of 1h). This affects F3xD4[NbFidEn]. Registers containing P-state information such as FID, DID, and VID values are valid out of cold reset independent of the state of F3xA0[CofVidProg]. BIOS must transition the processor to a valid P-state out of cold reset when F3xA0[CofVidProg]=0. See also section 2.4.2.5 [BIOS Requirements for P-State Initialization and Transitions] on page 34. |  |
| 30                 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |

| 29    | <b>SlamVidMode: slam voltage ID mode</b> . Read-write. This specifies the voltage transition type when changing P-state. 1=The voltage is slammed. 0=The voltage is stepped. This bit is normally set if the regulator includes built-in output voltage slew rate control. It is required to be programmed to the same state in all nodes. See also section 2.4.1.8 [Hardware-Initiated Voltage Transitions] on page 30. BIOS should set this bit to the inverse of F3xA0[PviMode].                         |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 27:16 | <b>PstateId:</b> P-state identifier. Read-only. This field specifies the P-state ID associated with the product.                                                                                                                                                                                                                                                                                                                                                                                            |
| 15:14 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13:11 | PllLockTime: PLL synchronization lock time. Read-write. If a P-state change occurs that applies a new FID to the PLL, this field specifies the time required for the PLL to lock to the new frequency. These bits are encoded as follows:  000b 1 microsecond. 100b 8 microseconds.  001b 2 microseconds. 101b 16 microseconds.  010b 3 microseconds. 110b Reserved.                                                                                                                                        |
|       | 011b 4 microseconds. 111b Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       | BIOS should set this field to 101b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10:9  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8     | <b>PviMode: parallel VID interface mode</b> . Read-only. 1=The parallel VID interface is selected (through a resistor strap on VID[1] to VDDIO); single- or dual-plane operation. 0=The serial VID interface is selected (through a resistor strap on VID[1] to ground); dual-plane operation. See section. 2.4.1.1 [VID Pins And Interface Selection.] on page 26.                                                                                                                                         |
| 7     | <b>PsiVidEn: PSI_L VID enable</b> . Read-write. This bit specifies how PSI_L is controlled. This signal may be used by the voltage regulator to improve efficiency while in reduced power states. 1=Control over the PSI_L signal is as specified by the PsiVid field of this register. 0=PSI_L is always high. See section 2.4.1.4 [PSI_L] on page 27.                                                                                                                                                     |
| 6:0   | PsiVid: PSI_L VID threshold. Read-write. When enabled by PsiVidEn, this field specifies the threshold value of VID code generated by the processor, which in turn determines the state of PSI_L. When the VID code generated by the processor is less than PsiVid (i.e., the VID code is specifying a higher voltage level than the PsiVid-specified voltage level), then PSI_L is high; when the VID code is greater than or equal to PsiVid, PSI_L is driven low. See section 2.4.1.4 [PSI_L] on page 27. |

### F3xA4 Reported Temperature Control Register

The processor measures temperature to 1/2-degree C resolution. However, temperature is reported through Tctl with 1/8th-degree resolution. The translation to finer resolution is accomplished using slew rate controls in this register. These specify how quickly Tctl steps to the measured temperature in 1/8th-degree steps. Separate controls are provided for measured temperatures that are higher and lower than Tctl. The per-step timer counts as long as the measured temperature stays either above or below Tctl; each time the measured temperature flops to the other side of Tctl, the step timer resets. If, for example, step times are enabled in both directions, Tctl=62.625, and the measured temperature keeps jumping quickly between 62.5 and 63.0, then (assuming the step times are long enough) Tctl would not change; however, once the measured temperature settles on one side of Tctl, Tctl can step toward the measured temperature.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:21 | <b>CurTmp: current temperature</b> . Read-only. Reset: X. Provides the current control temperature, Tctl (after the slew-rate controls have been applied). This is encoded as value = 1/8th degree * Tctl, ranging from 0 to 255.875 degrees. See also section 2.10.1 [The Tctl Temperature Scale] on page 110. See also CurTmpSel.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| 20:18 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 17:16 | <ul> <li>CurTmpSel. Current temperature select. Read-write. Reset: 00. These bits may be used for diagnostic software. This bits are encoded as:         <ul> <li>00b = CurTmp provides the read-only Tctl value.</li> <li>01b = Undefined.</li> <li>10b = Undefined.</li> </ul> </li> <li>11b = CurTmp is a read-write register that specifies a value, used to create Tctl. The two LSBs are read-only zero.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 15:13 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 12:8  | <b>PerStepTimeDn[4:0]: per 1/8th degree step time down</b> . Read-write. Cold reset: 18h (1 second). This specifies the time per 1/8-degree step of Tctl when the measured temperature is less than the Tctl. It is encoded the same as PerStepTimeUp.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 7     | <b>TmpSlewDnEn: temperature slew downward enable</b> . Read-write. Cold reset: 0b. 1=Slew rate controls in the downward direction are enabled. 0=Downward slewing disabled; if the measured temperature is detected to be less than Tctl then Tctl is updated to match the measured temperature. BIOS should set this bit to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| 6:5   | TmpMaxDiffUp: temperature maximum difference up. Read-write. Cold reset: 000b. This specifies the maximum difference between Tctl and the measured temperature, when the measured value is greater than Tctl (i.e., when the temperature has risen). If this difference exceeds the specified value, Tctl jumps to the measured temperature value. This field is encoded as follows:  00b = Upward slewing disabled; if the measured temperature is detected to be greater than Tctl then Tctl is updated to match the measured temperature.  01b = Tctl is held to less than or equal to measured temperature minus 1.0 degrees C.  10b = Tctl is held to less than or equal to measured temperature minus 3.0 degrees C.  11b = Tctl is held to less than or equal to measured temperature minus 9.0 degrees C. |  |
| 4:0   | PerStepTimeUp[4:0]: per 1/8th degree step time up. Read-write. Cold reset: 00h. This specifies the time per 1/8-degree step of Tctl when the measured temperature is greater than the reported temperature. It is encoded as follows:    Bits[4:3]   Step Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |

# F3xB0 On-Line Spare Control Register

See 2.8.10 [On-Line Spare] on page 106 for more details on on-line spare.

| Bits  | Description                                                                                            |
|-------|--------------------------------------------------------------------------------------------------------|
| 31:28 | LvtOffset: local vector table offset. Reset: 0000b. This specifies the address of the LVT entry in the |
|       | APIC registers as follows: LVT address = (LvtOffset shifted left 4 bits) + 500h (see APIC[530:500]).   |
|       | This offset applies to SwapDoneInt and EccErrInt interrupts.                                           |

| 27:24 | <b>EccErrCnt: ECC error count</b> . Read-write (modified by EccErrCntWrEn). Reset: 0. This field returns the number of ECC errors for the chip select selected by the EccErrCntDramCs, and EccErrCntChan. This field can be written by software to clear the count. This field returns Fh if 15 or more correctable ECC errors have occurred.                                                                                                                                                                                                                                                               |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 23    | <b>EccErrCntWrEn: ECC error counter write enable</b> . Read-write. Reset: 0. 1=Enable writes to the EccErrCnt field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| 22    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| 21:20 | EccErrCntChan: ECC error counter channel. Read-write. Reset: 0. These bits specify the channel for which ECC error count information is returned in the EccErrCnt field as follows:    Memory Interface                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 19:16 | <ul> <li>EccErrCntDramCs[3:0]: ECC error counter DRAM chip select. Read-write. Reset: 0. This field specifies the DRAM chip select (as specified in [The DRAM CS Base Address Registers] F2x[1, 0][5C:40]) for which ECC error count information is returned in the EccErrCnt field. Depending only the production, this field is interpreted as follows:</li> <li>DDR products: EccErrCntDramCs[3] does not matter and EccErrCntDramCs[2:0] specifies the error count for the address range of one of the eight chip select specified by [The DRAM CS Base Address Registers] F2x[1, 0][5C:40].</li> </ul> |  |
| 15:14 | <ul> <li>EccErrInt: ECC error interrupt type. Read-write. Reset: 0. This field specifies the type of interrupt generated when the EccErrCnt field for any chip select and channel transitions to 1111b.</li> <li>00b = No Interrupt.</li> <li>01b = APIC based interrupt (see LvtOffset) to all CPU cores.</li> <li>10b = SMI trigger event (always routed to CpuCoreNum 0, as defined in section 2.9.2 [CPU Cores and Downcoring] on page 107); see section 2.14.2.3 [SMI Sources And Delivery] on page 125.</li> <li>11b = Reserved.</li> </ul>                                                           |  |
| 13:12 | SwapDoneInt: swap done interrupt type. Read-write. Reset: 0. This field specifies the type of interrupt generated when a swap is complete.  00b = No Interrupt.  01b = APIC based interrupt (see LvtOffset) to all CPU cores.  10b = SMI trigger event (always routed to CpuCoreNum 0, as defined in section 2.9.2 [CPU Cores and Downcoring] on page 107); see section 2.14.2.3 [SMI Sources And Delivery] on page 125.  11b = Reserved.                                                                                                                                                                   |  |
| 11    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| 10:8  | BadDramCs1: bad DRAM chip select DCT1. Read-write. Cold reset: 0. See BadDramCs0 below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 7     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| 6:4   | <b>BadDramCs0:</b> bad DRAM chip select DCT0. Read-write. Cold reset: 0. This field is programmed with the DRAM chip select to be replaced when SwapEn is set. This field cannot be written when SwapDone is set. BadDramCs0 applies to DCT0 and BadDramCs1 applies to DCT1.                                                                                                                                                                                                                                                                                                                                |  |
| 3     | <b>SwapDone1: swap done DCT1</b> . Read-write; set-by-hardware. Cold reset: 0. See SwapDone0 below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 2     | SwapEn1: swap enable DCT1. Read; write-1-only. Cold reset: 0. See SwapEn0 below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |

| 1 | <b>SwapDone0: swap done DCT0</b> . Read-write; set-by-hardware. Cold reset: 0. 1=The hardware has completed copying the data to the spare rank. This bit can also be set by BIOS to immediately enable the swap to the spare rank after suspend to RAM. Once this bit is set it cannot be cleared by software. This bit cannot be set by software if DRAM is enabled F2x110[DramEnable]. SwapDone0 applies to DCT0 and SwapDone1 applies to DCT1.                                                                                                                                                                                                                                      |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | <b>SwapEn0: swap enable DCT0</b> . Read; write-1-only. Cold reset: 0. Setting this bit causes the hardware to copy the contents of the DRAM chip select identified by BadDramCs to the spare rank. The DRAM scrubber (F3x5C) must be enabled with a scrub address range that encompasses the address of the bad chip select for the swap to occur. The scrub rate is accelerated automatically by hardware until the copy completes, at which point the scrub rate returns to normal. During the copy, DRAM accesses (including accesses to the bad CS) proceed normally. Once this bit is set, it cannot be cleared by software. SwapEn0 applies to DCT0 and SwapEn1 applies to DCT1. |

# F3xD4 Clock Power/Timing Control 0 Register

| D .     |     | C* 1  | 11  | C.           | • . •  |
|---------|-----|-------|-----|--------------|--------|
| Reset:  | CAA | t1Δ[/ | h r | $\Delta$ tin | 1110nc |
| INCSCI. | 3CC | 1161  | ıч  | CHI          | HUUHS. |

| Bits  | Description                                                                                                                                | on                                                                                                                                                                                                                                                |                                                                                                                         |                                               |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| 31    | NbClkDiv                                                                                                                                   | ApplyAll. Read-write. C                                                                                                                                                                                                                           | Cold reset: 0b.                                                                                                         | See NbClkDiv. BIOS should set this bit to 1b. |
| 30:28 | divisor ass<br>divisor is a<br>F3x[84:80<br>specified by<br>quency, or<br>• 200 MH<br>If MSRCO<br>by this fiel<br>with this r<br>remains 2 | sociated with [The ACPI] applied while LDTSTOP [ClkDivisor], is set to "to F3x[84:80][ClkDivisor]: [z * (4 + F3xD4[NbFid]). [001_00[68:64][NbDid] of ld, then no NB frequency egister (i.e., if this field spends while in the low-power states.] | Power State C is asserted if turn off clocks' r] is applied. The current Pchange is made pecifies a dividual. This fiel |                                               |
|       | Bits<br>000b                                                                                                                               | <u>Divisor</u><br>Divide-by 1.                                                                                                                                                                                                                    | <u>Bits</u><br>100b                                                                                                     | <u>Divisor</u><br>Divide-by 16.               |
|       | 001b                                                                                                                                       | Divide-by 2.                                                                                                                                                                                                                                      | 101b                                                                                                                    | Reserved.                                     |
|       | 010b                                                                                                                                       | Divide-by 4.                                                                                                                                                                                                                                      | 110b                                                                                                                    | Reserved.                                     |
|       | 011b                                                                                                                                       | Divide-by 8.                                                                                                                                                                                                                                      | 111b                                                                                                                    | Reserved.                                     |
|       | BIOS should set this field to 100b.                                                                                                        |                                                                                                                                                                                                                                                   |                                                                                                                         |                                               |

| 27:24 | <b>PowerStepUp.</b> Read-write. Cold reset: 0000b. This specifies the rate at which blocks of CPU core       |
|-------|--------------------------------------------------------------------------------------------------------------|
|       | and NB logic are gated on while the processor transitions from a quiescent state to an active state as       |
|       | part of a power management state transition. There are about 15 steps in this transition of each CPU         |
|       | core and about 5 steps for the NB for the PowerStepDown and PowerStepUp transitions. So the total            |
|       | transition time for a single CPU core is about 15 times the time specified by PowerStepDown and              |
|       | PowerStepUp and the transition time for the NB is about 5 times the time specified by PowerStep-             |
|       | Down and PowerStepUp. Use of longer transition times may help reduce voltage transients associated           |
|       | with power state transitions. The bits for PowerStepUp and PowerStepDown are encoded as follows:             |
|       | Bits Time Bits Time Bits Time Bits Time                                                                      |
|       | 0000b 400ns. 0100b 90ns. 1000b 50ns. 1100b 30ns.                                                             |
|       | 0001b 300ns. 0101b 80ns. 1001b 45ns. 1101b 25ns.                                                             |
|       | 0010b 200ns. 0110b 70ns. 1010b 40ns. 1110b 20ns.                                                             |
|       | 0011b 100ns. 0111b 60ns. 1011b 35ns. 1111b 15ns.                                                             |
|       | Note that if PowerStepDown or PowerStepUp are programmed to greater than 50ns, then the value                |
|       | applied to NB steps is clipped to 50ns. BIOS should set this field to 1000b for all processors in desk-      |
|       | top and mobile systems, and use the following equation for processors in server systems: Power-              |
|       | StepUp (ns) = $400 / \#$ of cores (e.g. 4 cores = $400 / 4 = 100$ ns = $0011$ b).                            |
| 23:20 | <b>PowerStepDown</b> . Read-write. Cold reset: 0000b. This specifies the rate at which blocks of CPU core    |
|       | and NB logic are gated off while the processor transitions from an active state to a quiescent state as      |
|       | part of a power management state transition. See PowerStepUp for details.                                    |
| 19:18 | Reserved.                                                                                                    |
| 17:16 | <b>LnkPllLock</b> . Read-write. Cold reset: 00b. This specifies the link PLL lock time applied when the link |
|       | frequency is programmed to change during a link disconnect-reconnect sequence. The reconnect                 |
|       | sequence is delayed to ensure that the PLL is locked. BIOS should set this field to 01b.                     |
|       | Bits PLL lock time                                                                                           |
|       | 00b 1 microsecond.                                                                                           |
|       | 01b 10 microseconds.                                                                                         |
|       | 10b 100 microseconds.                                                                                        |
|       | 11b 1000 microseconds.                                                                                       |
| 15:12 | Reserved.                                                                                                    |
| 11:8  | ClkRampHystSel: clock ramp hysteresis select. Read-write. Cold reset: 000b. When the CPU                     |
|       | core(s) are in the stop-grant or halt state and a probe request is received, the CPU core clock may need     |
|       | to be brought up to service the probe.                                                                       |
|       | • If F3x[84:80][CpuPrbEn]=0 for the low-power state, then this field specifies how long the core             |
|       | clock is left up to service additional probes before being brought back down. Each time a probe              |
|       | request is received, the hysteresis timer is reset such that the period of time specified by this field      |
|       | must expire with no probe request before the CPU core clock is brought back down. For revision B,            |
|       | the hysteresis time is encoded as 320ns * (1 + ClkRampHystSel). If F3x[84:80][CpuPrbEn]=1 for                |
|       | the low-power state, and for requests to change CPU core P-states, then this field specifies a fixed         |
|       | amount of time to allow for probes to be serviced after completing the transition of each CPU core.          |
|       | If, for example, two CPU cores enter stop-grant or halt at the same time, then (1) the first CPU core        |
|       | would complete the transition to the low power state, (2) probe traffic would be serviced for the            |
|       | time specified by this field, (3) the second CPU core would complete the transition to the low power         |
|       | state, and (4) probe traffic would be seviced for the time specified by this field (and afterwards,          |
|       | until the next power state transition). For this purpose, values range from 0h=40ns to Fh=640ns,             |
|       | encoded as 40ns * (1 + ClkRampHystSel).                                                                      |
|       | • BIOS should set this field to 1111b.                                                                       |
| 7:6   | Reserved.                                                                                                    |
| ·     |                                                                                                              |

| 5   | <b>NbFidEn: Northbridge frequency ID enable</b> . Read-write. Cold reset: value is the same as F3xA0[CofVidProg]. This specifies the NB FID after warm or cold resets. 0=After a cold reset, the NB FID is 800 MHz, regardless of the state of NbFid. After a warm reset, the NB FID is the NB FID before the warm reset, regardless of the state of NbFid.1=The NB FID is specified by NbFid. See also section 2.4.2 [P-states] on page 31.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0 | NbFid: Northbridge frequency ID. Read-write. Cold reset: value varies by product. After a cold reset, this specifies the FID at which the NB is designed to operate. After a warm or cold reset, the NB FID may or may not be reflected in this field, based on the state of NbFidEn. The NB FID may be updated to the value of this field through a warm or cold reset if NbFidEn=1. If that has occurred, then the NB COF is specified by:  • NB COF = 200 MHz * (F3xD4[NbFid] + 4h) / (2^MSRC001_00[68:64][NbDid]).  This field must be programmed to the requirements specified in MSRC001_0071[MaxNbFid] and must be less than or equal to 1Bh, otherwise undefined behavior results. This field must be programmed to the same value for all nodes in the coherent fabric as specified by 2.4.2.6 [BIOS Northbridge COF and VID Configuration] on page 35. See also section 2.4.2 [P-states] on page 31. BIOS must not change the NbFid after enabling the DRAM controller. |

#### F3xD8 Clock Power/Timing Control 1 Register

The VID(s) are provided by the processor to the external voltage regulator(s). They can be altered through P-state changes. The VDD VID(s) can also be automatically controlled when entering low-power states, as specified by [The ACPI Power State Control Registers] F3x[84:80][AltVidEn].

When exiting low-power states in which the alternate VID has been applied, the processor provides the previous operational VID to the voltage regulator. Some voltage regulators may not be able to support the rapid voltage change while operating at the higher P-states (such as the full-frequency P-state). Software can resolve this by programming AltVidStart to specify a voltage below that used in the full-frequency P-state. Thus, this field prevents the alternate VID from being applied during the full-frequency P-state while allowing it to be applied during lower-frequency P-states.

If the alternate VID is applied, then the exit sequence includes: (1) the processor applies the prior operational VID (slamming or stepping based on the state of F3xA0[SlamVidMode]), (2) the processor waits for the time specified by VSSlamTime, and (3) the processor allows instruction execution to continue. When entering such low-power states, CPU core clocks are ramped down prior to applying the alternate VID.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 27:24 | <b>ReConDel:</b> link reconnect delay. Read-write. Cold reset: 0. Specifies the approximate delay, in microseconds, from the deassertion of LDTSTOP_L until the link initialization process is allowed to start in Gen1 mode if F0x[E4, C4, A4, 84][LdtStopTriEn]=1 and F0x[18C:170][LS2En]=1. The assertion of CTL is delayed until the specified time has elapsed. See section 2.7.6 [Link LDTSTOP_L Disconnect-Reconnect] on page 58 for information on when this is applied. The receiver is always enabled 1us after deassertion of LDTSTOP_L, regardless of the setting of this field or other delays in assertion of CTL. BIOS should program this field to 3h.  Oh = 1.6us.  1h = 2us.   9h = 10us.  All other values are reserved. |

| 23    | Reserved                                                                                                |                                                                                    |                                                                                             |                                                                                                                                                                                                                                                                                                                                       |
|-------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:16 | required provided                                                                                       | before driving out the alter                                                       | rnate VID. The<br>aly if the voltage                                                        | te. Cold reset: 00h. Specifies the current VID limit alternate VID (specified by F3xDC[AltVid]) is e specified by the current VID is less than or equal                                                                                                                                                                               |
| 15:7  | Reserved                                                                                                |                                                                                    |                                                                                             |                                                                                                                                                                                                                                                                                                                                       |
| 6:4   | wait for v<br>PVI is us<br>internal 7<br>end of ea<br>Initiated<br>Bits<br>000b<br>001b<br>010b<br>011b | voltage stabilization after e ed), if the voltage level is bit VID code to PVI VID | ach internal 7 b<br>ramped. Refer t<br>encodings. If in<br>art of the next S                | Read-write. Cold reset: 000b. Specifies the time to it VID increment (regardless of whether the SVI or to section 2.4.1.6 [VID Encodings] on page 27 for a SVI mode, this time measures the period from the SVI command. See also section 2.4.1.8 [Hardware-  Time 60 microseconds 100 microseconds 200 microseconds 500 microseconds |
| 3     | Reserved                                                                                                |                                                                                    |                                                                                             |                                                                                                                                                                                                                                                                                                                                       |
| 2:0   | wait for valso sectitime meanument Bits 000b 001b 010b 011b                                             | voltage stabilization if a ne                                                      | ew VID is provi<br>lated Voltage Tend of the SVI of<br>Bits<br>100b<br>101b<br>110b<br>111b | ead-write. Cold reset: 000b. Specifies the time to ded to the voltage regulator without ramping. See ransitions] on page 30. If in SVI mode, then this command.  Time 60 microseconds 100 microseconds 200 microseconds 500 microseconds                                                                                              |

# F3xDC Clock Power/Timing Control 2 Register

Reset: see field definitions.

| Bits  | Description |
|-------|-------------|
| 31:15 | Reserved.   |

| 14 | 4:12 | NbsynPtrAdj: NB/core synchronization FIFO pointer adjust. Read-write. Cold reset: 000b. There is a synchronization FIFO between the NB clock domain and CPU core clock domains. At cold reset, the read pointer and write pointer for each of these FIFOs is positioned conservatively, such that FIFO latency may be greater than is necessary. This field may be used to position the read pointer and write pointer of each FIFO closer to each other such that latency is reduced. Each increment of this field represents one clock cycle of whichever is the slower clock (longer period) between the NB clock and the CPU core clock. After writing to this field, the new values are applied after a warm reset. BIOS should program this field to 5h for optimal performance.  Oh Position the read pointer 0 clock cycles closer to the write pointer.  1h Position the read pointer 1 clock cycles closer to the write pointer.  7h Position the read pointer 7 clock cycles closer to the write pointer. |
|----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | 11   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|    | 0:8  | PstateMaxVal: P-state maximum value. Read-write. Cold reset: specified by the reset state of MSRC001_00[68:64][PstateEn]; the cold reset value is the highest P-state number corresponding to the MSR in which PstateEn is set (e.g., if MSRC001_0064 and MSRC001_0065 have this bit set and the others do not, then PstateMaxVal=1; if PstateEn is not set in any of these MSRs, then PstateMaxVal=0). This specifies the highest P-state value (lowest performance state) supported by the hardware. See also MSRC001_0061[PstateMaxVal].                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|    | 7    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|    | 6:0  | <b>AltVid:</b> alternate VID. Read-write. Cold reset: value varies by product. If F3xA0[PviMode]=0, this specifies the VID driven to the VDD power plane while in the low-power state, as specified by [The ACPI Power State Control Registers] F3x[84:80][AltVidEn]. This field is required to be programmed as specified by MSRC001_0071[MaxVid and MinVid]. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

# F3xE4 Thermtrip Status Register

Reset: 0000 0000h, except bits[14:8, 5, 3 and 1]; see below.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                         |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | <b>SwThermtp: software THERMTRIP.</b> Write-1-only. Writing a 1 to this bit position induces a THERMTRIP event. This bit returns 0 when read. This is a diagnostic bit, and it should be used for testing purposes only.                                                                                                                                            |
| 30:15 | Reserved.                                                                                                                                                                                                                                                                                                                                                           |
| 14:8  | <b>DiodeOffset</b> . Read-only. Reset: value varies by product. This field is used to specify the correction value applied to thermal diode measurements. See also section 2.10.2 [Thermal Diode] on page 110. It is encoded as follows:  00h is undefined.  01h to 3Fh: correction = +11C - DiodeOffset, or {01h to 3Fh} = {+10C to -52C}.  40h to 7Fh: undefined. |
| 7:6   | Reserved.                                                                                                                                                                                                                                                                                                                                                           |
| 5     | <b>ThermtpEn: THERMTRIP enable</b> . Read-only. 1=The THERMTRIP state as specified in section 2.10.3.3 [THERMTRIP] on page 112 is supported by the processor.                                                                                                                                                                                                       |
| 4     | Reserved.                                                                                                                                                                                                                                                                                                                                                           |
| 3     | <b>ThermtpSense: THERMTRIP</b> sense. Read-only. Cold reset: 0. 1=The processor temperature exceeded the THERMTRIP value (regardless as to whether the THERMTRIP state is enabled).                                                                                                                                                                                 |

| 2 | Reserved.                                                                                              |
|---|--------------------------------------------------------------------------------------------------------|
| 1 | <b>Thermtp: THERMTRIP</b> . Read-only. Cold reset: 0. 1=The processor has entered the THERMTRIP state. |
| 0 | Reserved.                                                                                              |

# F3xE8 Northbridge Capabilities Register

All fields are read-only. Unless otherwise specified, 1=The feature is supported by the processor; 0=The feature is not supported.

| ture is i | not supported.                                                                                                                                                                                                                                                                                                 |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits      | Description                                                                                                                                                                                                                                                                                                    |
| 31:27     | Reserved.                                                                                                                                                                                                                                                                                                      |
| 26        | <b>HtAcCapable</b> . 1=Specifies that the links are capable of operating in AC-coupled mode or DC-coupled mode. 0=Only DC-coupled operation is supported.                                                                                                                                                      |
| 25        | L3Capable. 1=Specifies that an L3 cache is present. See also CPUID Fn8000_0006_EDX.                                                                                                                                                                                                                            |
| 24        | Reserved.                                                                                                                                                                                                                                                                                                      |
| 23:20     | <b>UnGangEn: link unganging enabled</b> . 0=Link is forced into the ganged state and may not be placed into the unganged state. 1=Unganging is supported. Bit[20] applies to link 0; bit[21] applies to link 1; bit[22] applies to link 2; bit[23] applies to link 3. See also section 2.7 [Links] on page 55. |
| 19        | Reserved.                                                                                                                                                                                                                                                                                                      |
| 18:16     | MpCap: MP capability. Specifies the maximum number of processors supported as follows:  111b 1 processor. 110b 2 processors.  101b 4 processors. 100b 8 processors.  All other values are reserved.                                                                                                            |
| 15        | Reserved.                                                                                                                                                                                                                                                                                                      |
| 14        | Multiple VID plane capable.                                                                                                                                                                                                                                                                                    |
| 13:12     | <b>CmpCap: CMP capable</b> . Specifies the number of CPU cores enabled on the node. 00b=1; 01b=2; 10b=3; 11b=4.                                                                                                                                                                                                |
| 11        | LnkRtryCap. Link error-retry capable.                                                                                                                                                                                                                                                                          |
| 10        | HTC capable. This affects F3x64 and F3x68.                                                                                                                                                                                                                                                                     |
| 9         | SVM capable.                                                                                                                                                                                                                                                                                                   |
| 8         | MctCap: memory controller (on the processor) capable.                                                                                                                                                                                                                                                          |
| 7:5       | DdrMaxRate. Specifies the maximum DRAM data rate that the processor is designed to support.BitsDDR limitBitsDDR limit000bNo limit100b800 MT/s001b1600 MT/s101b667 MT/s010b1333 MT/s110b533 MT/s011b1067 MT/s111b400 MT/s                                                                                       |
| 4         | Chipkill ECC capable.                                                                                                                                                                                                                                                                                          |
| 3         | ECC capable.                                                                                                                                                                                                                                                                                                   |
| 2         | Eight-node multi-processor capable.                                                                                                                                                                                                                                                                            |
| 1         | Dual-node multi-processor capable.                                                                                                                                                                                                                                                                             |
| 0         | DctDualCap: two-channel DRAM capable (i.e., 128 bit). 0=Single channel (64-bit) only.                                                                                                                                                                                                                          |
| l         | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                          |

#### F3xF0 DEV Capability Header Register

See section 2.6.3 [DMA Exclusion Vectors (DEV)] on page 51. Note: if SVM is not supported, as specified by F3xE8[SVM Capable], then this register is reserved.

DMA Exclusion Vectors (DEV) are contiguous arrays of bits in physical memory. Each bit in the DEV table represents a 4KB page of physical memory; the DEV applies to accesses that target system memory and MMIO, but not to accesses within the GART aperture (see section 2.6.2 [The GART] on page 50). The DEV table is packed as follows: bit[0] of byte 0 (pointed to by the DEV table base address, F3xF8\_x0 and F3xF8\_x1) controls the first 4K bytes of physical memory (starting at address 00\_0000\_0000h); bit[1] of byte 0 controls the second 4K bytes of physical memory; etc. When a DEV table bit is set to one, accesses to that physical page by external DMA devices is not allowed. If an external device attempts to access a protected physical page, then the processor master aborts the request.

In addition, the processor supports multiple protection domains. There is a DEV table for each protection domain. Link-defined UnitIDs may be assigned to the DEV of a specific protection domain through F3xF8\_x2. DEV table walks for each protection domain are cached in the NB to reduce the number DEV table access to system memory.

The DEV function is configured through F3xF0, F3xF4, F3xF8, and an array of registers called F3xF8\_DF[8:0], which are defined following F3xF8. [The DEV Function/Index Register] F3xF4 and [The DEV Data Port] F3xF8 are used to access F3xF8\_DF[8:0]. The register number (i.e., the number that follows "\_DF" in the register mnemonic) is specified by F3xF4[DevFunction]. In addition, F3xF8\_x0, F3xF8\_x1, and F3xF8\_x2 are each instantiated multiplied times, indexed by F3xF4[DevIndex]. To access the registers, F3xF4[DevFunction and DevIndex] are programmed to point to the appropriate register and the read or write access is directed at F3xF8.

| Bits  | Description                                                                                                                                                                |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:22 | Reserved.                                                                                                                                                                  |  |
| 21    | <b>ntCap:</b> interrupt reporting capability. Read-only. Reset: 0. 0=Indicates that interrupt reporting of DEV protection violations is not present on this device.        |  |
| 20    | <b>MceCap: MCE reporting capability</b> . Read-only. Reset: 1. Indicates that machine check architecture reporting of DEV protection violations is present on this device. |  |
| 19    | Reserved.                                                                                                                                                                  |  |
| 18:16 | <b>CapType: DEV capability block type</b> . Read-only. Reset: 000b. Specifies the layout of the Capability Block.                                                          |  |
| 15:8  | CapPtr: capability pointer. Read-only. Reset: 00h. Indicates that this is the last capability block.                                                                       |  |
| 7:0   | CapId: capability ID. Read-only. Reset: 0Fh. Indicates a DEV capability block.                                                                                             |  |

#### F3xF4 DEV Function/Index Register

Reset: 0000 0000h. Note: if SVM is not supported, as specified by F3xE8[SVM Capable], then this register is reserved.

| Bits  | Description |
|-------|-------------|
| 31:16 | Reserved.   |

| 15:8 | <b>DevFunction</b> . Read-write. See F3xF0 for details. Valid values for this field are 00h through 08h.                                                                                                                                                                                                                                  |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|      | <b>DevIndex</b> . Read-write. See F3xF0 for details. Valid values for this field are (1) 00h through (F3xF8_x3[NDomains] - 1) when either F3xF8_x0 or F3xF8_x1 are being accessed and (2) 00h through (F3xF8_x3[NMaps] - 1) when F3xF8_x2 is being accessed; this field is ignored for accesses to all other DEV configuration registers. |  |

#### F3xF8 DEV Data Port

Note: if SVM is not supported, as specified by F3xE8[SVM Capable], then this location and registers F3xF8\_DF[8:0] are reserved. See F3xF0 for details about this port.

#### F3xF8\_x0 DEV Base Address/Limit Low Register

Reset: 0000 0000h. This register is instantiated multiple times, specified by F3xF8\_x3[NDomains]. Each instantiation corresponds to a protection domain number, identical to F3xF4[DevIndex], which is the index to the instantiation. See F3xF0 for more details.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | BaseAddress[31:12]: DEV table base address bits[31:12]. Read-write. These bits are combined with F3xF8_x1[BaseAddress[47:32]] to specify the base address of the DEV table. The DEV table is required to be in either non-cacheable or write-through memory. If any part of the DEV table is in other than system memory, then undefined behavior results. |
| 11:7  | Reserved.                                                                                                                                                                                                                                                                                                                                                  |
| 6:2   | <b>Size: DEV table size</b> . Read-write. These bits specify the size of the memory region that the DEV table covers, 4GB*(2^Size). The corresponding DEV table size is 128KB*(2^Size).                                                                                                                                                                    |
| 1     | <b>Protect: protect out-of-range addresses</b> . Read-write. 0=DMA accesses to addresses that are outside the range covered by the DEV table are allowed. 1=DMA accesses to addresses that are outside the range covered by the DEV table are protected.                                                                                                   |
| 0     | <b>Valid: DEV table valid.</b> Read-write. 1=The DEV table for the protection domain specified by F3xF4[DevIndex] is enabled. 0=The DEV table is not enabled; all IO accesses from devices assigned to the corresponding protection domain are allowed.                                                                                                    |

#### F3xF8\_x1 DEV Base Address/Limit High Register

Reset: 0000 0000h. This register is instantiated multiple times, specified by F3xF8\_x3[NDomains]. Each instantiation corresponds to a protection domain number, identical to F3xF4[DevIndex], which is the index to the instantiation. See F3xF0 for more details.

| Bits  | Description                                                                                            |
|-------|--------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved.                                                                                              |
|       | <b>BaseAddress[47:32]: DEV table base address bits[47:32]</b> . Read-write. See F3xF8_x0[BaseAddress]. |

#### F3xF8\_x2 DEV Map Register

Reset: 0000 0000h. This register is instantiated multiple times, specified by F3xF8\_x3[NMaps]. See F3xF0 for more details. Referencing the fields of this register, if Valid[1:0] is set, then the address of DMA requests received by the processor from an IO link of bus number BusNu and with a UnitID of Unit[1:0] are checked against the DEV table of protection domain number Dom[1:0] to determine if the transaction is allowed. If the

UnitID and BusNu of the request do not match any of these registers, then the address of the request is checked against the DEV table of protection domain 0 to determine if the transaction is allowed. A UnitID can only be assigned to one protection domain. If a UnitID is assigned to more than one protection domain the results are undefined. Note: if UnitID clumping is employed through F0x[11C, 118, 114, 110] and F0x[12C, 128, 124, 120], then only the base UnitID of each clump should be programmed into the Unit0/Unit1 fields of this register; otherwise undefined behavior results.

| Bits  | Description                                                                                                                                   |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:26 | <b>Dom1: protection domain 1</b> . 3 LSBs are read-write; 3 MSBs are read-only, 000b. This is the protection domain number assigned to Unit1. |  |
| 25:20 | <b>Dom0: protection domain 0</b> . 3 LSBs are read-write; 3 MSBs are read-only, 000b. This is the protection domain number assigned to Unit0. |  |
| 19:12 | BusNu: bus number. Read-write.                                                                                                                |  |
| 11    | Valid1: UnitID 1 valid. Read-write. 1=Enable DEV checking for Unit1 and Dom1.                                                                 |  |
| 10:6  | Unit1: IO link UnitID 1. Read-write.                                                                                                          |  |
| 5     | Valid0: UnitID 0 valid. Read-write. 1=Enable DEV checking for Unit0 and Dom0.                                                                 |  |
| 4:0   | Unit0: IO link UnitID 0. Read-write.                                                                                                          |  |

### F3xF8\_x3 DEV Capabilities Register

| Bits  | Description                                                                                                                                                                       |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved.                                                                                                                                                                         |
|       | <b>NMaps: number of map registers implemented</b> . Read-only, 04h. Specifies the number of instantiations of F3xF8_x2.                                                           |
| 15:8  | <b>NDomains: number of protection domains implemented</b> . Read-only, 08h. Specifies the number of protection domains and the number of instantiations of F3xF8_x0 and F3xF8_x1. |
| 7:0   | Revision: DEV register-set revision number. Read-only, 00h.                                                                                                                       |

### F3xF8\_x4 DEV Control Register

| Reset: ( | Reset: 0000 0000h.                                                                                                                                                                                                                                    |  |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits     | Description                                                                                                                                                                                                                                           |  |  |
| 31:7     | Reserved.                                                                                                                                                                                                                                             |  |  |
| 6        | <b>DevTblWalkPrbDis: DEV table walk probe disable</b> . Read-write. 1=Disable probing of CPU caches during DEV table walks. This bit may be set to improve DEV cache table walk performance when the DEV is in non-cacheable or write-through memory. |  |  |
| 5        | <b>SIDev: secure loader DEV protection enable</b> . Read-write; set-by-hardware. This bit is set by hardware after an SKINIT instruction. 1=The memory region associated with the SKINIT instruction is protected from DMA access.                    |  |  |
| 4        | <b>DevInv: invalidate DEV cache</b> . Read; write-1-only; cleared-by-hardware. 1=Invalidate the DEV table-walk cache. This bit is cleared by hardware when invalidation is complete.                                                                  |  |  |
| 3        | <b>MceEn: MCE reporting enable</b> . Read-write. 1=Enable reporting of DEV protection violations through a machine check exception.                                                                                                                   |  |  |

|   | <b>IoDis: upstream IO disable</b> . Read-write; set-by-hardware. This bit is set by hardware after an SKINIT instruction. 1=Upstream IO-space accesses are regarded as DEV protection violations. |  |
|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1 | Reserved. Read-write.                                                                                                                                                                             |  |
| 0 | <b>DevEn: DEV enable</b> . Read-write. 1=Enables DMA exclusion vector protection.                                                                                                                 |  |

### F3xF8\_x5 DEV Error Status Register

Cold reset: 0000 0000h. This register logs DEV protection violations. Bits[7:0], [ErrTypeDest, ErrTypeSrc, ErrTypeAccType], together form the error type field. When a DEV protection violation occurs, then ErrVal is set, the error type is logged, and, if there is an address associated with the transaction, ErrAddrVal is set and the address is recorded in F3xF8\_x6 and F3xF8\_x7.

| Bits                                                                                                                                                       | Description                                                                                                                                                                                                                                 |                                                                                                   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| 31                                                                                                                                                         | <b>ErrVal: error valid.</b> Read-write; set-by-hardware. 1=A valid DEV protection violation has been logged in this register.                                                                                                               |                                                                                                   |
| 30                                                                                                                                                         | <b>ErrOver: error overflow</b> . Read-write; set-by-hardware. 1=A DEV protection violation was detected while ErrVal was set for a prior violation. DEV protection violations detected while ErrVal is set are not logged in this register. |                                                                                                   |
| 29                                                                                                                                                         | <b>ErrAddrVal: error address valid.</b> Read-write; set-by-hardware. 1=The address saved in F3xF8_x6 and F3xF8_x7 is the address associated with the error.                                                                                 |                                                                                                   |
| 28:24                                                                                                                                                      | Reserved.                                                                                                                                                                                                                                   |                                                                                                   |
| 23:16                                                                                                                                                      | ModelSpecErr: model specific error. Read-only, 00h.                                                                                                                                                                                         |                                                                                                   |
| 15:8                                                                                                                                                       | Reserved.                                                                                                                                                                                                                                   |                                                                                                   |
| 7:5 <b>ErrCodeDest: error code destination</b> . Read-write; set-by-hardware. Specifies the destina transaction that resulted in the protection violation. |                                                                                                                                                                                                                                             | on.                                                                                               |
|                                                                                                                                                            | 000b = Generic (or could not be determined)<br>001b = DRAM                                                                                                                                                                                  | 100b = IO space<br>101b = Configuration                                                           |
|                                                                                                                                                            | 010b = MMIO                                                                                                                                                                                                                                 | 110b = reserved                                                                                   |
|                                                                                                                                                            | 011b = reserved                                                                                                                                                                                                                             | 111b = reserved                                                                                   |
| 4:2                                                                                                                                                        | ErrCodeSrc: error code source. Read-write; se tion that resulted in the protection violation.  000b = Generic (or could not be determined)  001b = CPU                                                                                      | t-by-hardware. Specifies the source of the transac-<br>010b = IO device<br>011b - 111b = reserved |
| 1:0                                                                                                                                                        | ErrCodeAccType: error code access type. Read-write; set-by-hardware. Specifies the access type                                                                                                                                              |                                                                                                   |
|                                                                                                                                                            | of the transaction that resulted in the protection violation.                                                                                                                                                                               |                                                                                                   |
|                                                                                                                                                            | 00b = Generic (or could not be determined)                                                                                                                                                                                                  | 10b = Write                                                                                       |
|                                                                                                                                                            | 01b = Read                                                                                                                                                                                                                                  | 11b = Read-modify-write                                                                           |

### F3xF8\_x6 DEV Error Address Low Register

| Cold reset: 0000 0000h. |                                                                                           |  |
|-------------------------|-------------------------------------------------------------------------------------------|--|
| Bits                    | Description                                                                               |  |
| 31:2                    | ErrAddr: error address bits[31:2]. Read-write; set-by-hardware. See F3xF8_x5 for details. |  |
| 1:0                     | Reserved.                                                                                 |  |

#### F3xF8\_x7 DEV Error Address High Register

| Cold reset: 0000 0000h. |                                                                                            |
|-------------------------|--------------------------------------------------------------------------------------------|
| Bits                    | Description                                                                                |
| 31:16                   | Reserved.                                                                                  |
| 15:0                    | ErrAddr: error address bits[47:32]. Read-write; set-by-hardware. See F3xF8_x5 for details. |

#### F3xF8 x8 Reserved.

### F3xFC CPUID Family/Model Register

These values are identical to the values read out through CPUID Fn[8000\_0001, 0000\_0001]\_EAX; see that register for details.

| Bits  | Description                            |
|-------|----------------------------------------|
| 31:28 | Reserved.                              |
| 27:20 | ExtFamily: extended family. Read-only. |
| 19:16 | ExtModel: extended model. Read-only.   |
| 15:12 | Reserved.                              |
| 11:8  | BaseFamily. Read-only.                 |
| 7:4   | BaseModel. Read-only.                  |
| 3:0   | Stepping. Read-only.                   |

### F3x140 SRI to XCS Token Count Register

F3x140, F3x144, and F3x1[54, 50, 4C, 48] specify the number of XCS (XBAR command scheduler) entries assigned to each virtual channel within each source port. See also section 2.6.1 [Northbridge (NB) Architecture] on page 50. The totals of SRI, MCT and the links must not exceed the number of XCS entries. The default totals are:

- SRI: 10.
- MCT: 6.
- Link: 10 \* 4 (one group per link).
- Total: 56, which is the total number of entries supported by XCS.

Note that the defaults for F3x140, F3x1[54, 50, 4C, 48], and F3x158 do not allocate any tokens in the isochronous channel. If isochronous flow control mode (IFCM) is enabled (F0x[E4, C4, A4, 84][IsocEn]) or display refresh mode is enabled (F0x68[DispRefModeEn]), then the XCS token counts must be changed. Notes on these modes:

- If IFCM is enabled on any link, then the F3x140[IsocReqTok, IsocPreqTok, and IsocRspTok] must each be non-zero. Or, in display refresh mode, F3x140[IsocReqTok and IsocRspTok] must be non-zero. This requires tokens to be reduced elsewhere to avoid exceeding the 56 token maximum. Note that links which are not connected or links which are ganged include excess tokens which may be used for this purpose.
- If IFCM is enabled on any link, then it may be advantageous to allocate isochronous tokens to that link/sub-link in F3x1[54, 50, 4C, 48]. However this would result in excessive tokens for a fully populated system, especially if the links are unganged. To account for this, the processor supports IFCM being enabled on a link without allocating dedicated isochronous XCS tokens. In this case:
  - The isochronous channel uses the base channel tokens.

- The isochronous channel has preferential access to these tokens.
- If an IOMMU is present on a link, F3x1[54, 50, 4C, 48][IsocReqTok] for that link must be non-zero.
- In display refresh mode, F3x1[54, 50, 4C, 48][IsocReqTok] and F3x1[54, 50, 4C, 48][IsocPreqTok] for the enabled link and F3x158[LnkToXcsDRToken] must be non-zero.

• If the system is a UMA system using display refresh mode, the following XCS token settings should be used:

```
FreeTok = 12
                             IsocRspTok = 3
                                                         IsocPreqTok = 1
IsocReqTok = 3
                             DnRspTok = 1
                                                         UpRspTok = 3
DnPreqTok = 1
                             UpPreqTok = 1
                                                         DnReqTok = 1
                             F3x144[ProbeTok] = 3
UpReqTok = 2
                                                         F3x144[RspTok] = 6
F3x148[IsocRspTok0] = 0
                             F3x148[IsocPreqTok0] = 1
                                                         F3x148[IsocReqTok0] = 1
F3x148[ProbeTok0] = 0
                             F3x148[RspTok0] = 2
                                                         F3x148[PReqTok0] = 2
```

 $F3x148[ReqTok0] = 2 \qquad \qquad F3x148[FreeTok] = 8 \qquad \qquad F3x158[LnkToXcsDRToken] = 3$ 

• If the system is not using IFCM or display refresh mode, the following XCS token settings should be used:

 $\label{eq:freeTok} \begin{array}{lll} FreeTok = 8 & IsocRspTok = 0 & IsocPreqTok = 0 \\ IsocReqTok = 0 & DnRspTok = 1 & UpRspTok = 3 \\ DnPreqTok = 1 & UpPreqTok = 1 & DnReqTok = 1 \\ UpReqTok = 2 & F3x144[ProbeTok] = 3 & F3x144[RspTok] = 3 \end{array}$ 

For each enabled link:

F3x1[50:48][IsocRspTok0] = 0 F3x1[50:48][IsocPreqTok0] = 0 F3x1[50:48][IsocReqTok0] = 0 F3x1[50:48][ProbeTok0] = 2 F3x1[50:48][ProbeTok0] = 2 F3x1[50:48][ProbeTok0] = 2

F3x1[50:48][ReqTok0] = 2 F3x1[50:48][FreeTok] = 3

Updates to this register do not take effect until after a warm reset.

| Bits  | Description                                                                                                                                                     |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved.                                                                                                                                                       |
| 23:20 | <b>FreeTok: free tokens</b> . Read-write. Cold reset: 2. The number of free tokens must always be greater than or equal to 2 to ensure deadlock free operation. |
| 19:18 | Reserved.                                                                                                                                                       |
| 17:16 | IsocRspTok: isochronous response tokens. Read-write. Cold reset: 0.                                                                                             |
| 15:14 | IsocPreqTok: isochronous posted request tokens. Read-write. Cold reset: 0.                                                                                      |
| 13:12 | IsocReqTok: isochronous request tokens. Read-write. Cold reset: 0.                                                                                              |
| 11:10 | <b>DnRspTok: downstream response tokens</b> . Read-write. Cold reset: 1.                                                                                        |
| 9:8   | UpRspTok: upstream response tokens. Read-write. Cold reset: 2.                                                                                                  |
| 7:6   | <b>DnPreqTok: downstream posted request tokens</b> . Read-write. Cold reset: 1.                                                                                 |
| 5:4   | UpPreqTok: upstream posted request tokens. Read-write. Cold reset: 1.                                                                                           |
| 3:2   | DnReqTok: downstream request tokens. Read-write. Cold reset: 1.                                                                                                 |
| 1:0   | UpReqTok: upstream request tokens. Read-write. Cold reset: 2.                                                                                                   |

### F3x144 MCT to XCS Token Count Register

See F3x140 for more information. Updates to F3x144 do not take effect until after a warm reset.

| Bits | Description                                         |
|------|-----------------------------------------------------|
| 31:8 | Reserved.                                           |
| 7:4  | ProbeTok: probe tokens. Read-write. Cold reset: 3.  |
| 3:0  | RspTok: response tokens. Read-write. Cold reset: 3. |

#### F3x1[54, 50, 4C, 48] Link to XCS Token Count Registers

F3x148 applies to link 0; F3x14C applies to link 1; F3x150 applies to link 2; F3x154 applies to link 3. See F3x140 for more information. The cold reset default value for some of the fields of this register vary based on the ganged/unganged state specified by F0x[18C:170][Ganged]. Most of the fields in this register are duplicated for each sublink; if the link is ganged, then the sublink 0 fields apply and the sublink 1 fields should be 0. Updates to F3x1[54, 50, 4C, 48] do not take effect until after a warm reset.

| Bits D           | Description                                                                                                                                                                                                                                     |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 <b>F</b>   | FreeTok[3:2]: free tokens. Read-write. See FreeTok[1:0] below.                                                                                                                                                                                  |
| 29 R             | Reserved.                                                                                                                                                                                                                                       |
| 28 Is            | socRspTok1: isochronous response tokens sublink 1. Read-write. Cold reset: 0.                                                                                                                                                                   |
| 27 R             | Reserved.                                                                                                                                                                                                                                       |
| 26 Is            | socPreqTok1: isochronous posted request tokens sublink 1. Read-write. Cold reset: 0.                                                                                                                                                            |
| 25 R             | Reserved.                                                                                                                                                                                                                                       |
| 24 Is            | socReqTok1: isochronous request tokens sublink 1. Read-write. Cold reset: 0.                                                                                                                                                                    |
| 23:22 <b>P</b>   | ProbeTok1: probe tokens sublink 1. Read-write. Cold reset: 0 ganged, 1 unganged.                                                                                                                                                                |
| 21:20 R          | RspTok1: response tokens sublink 1. Read-write. Cold reset: 0 ganged, 1 unganged.                                                                                                                                                               |
| 19:18 <b>P</b>   | PReqTok1: posted request tokens sublink 1. Read-write. Cold reset: 0 ganged, 1 unganged.                                                                                                                                                        |
| 17:16 <b>R</b>   | ReqTok1: request tokens sublink 1. Read-write. Cold reset: 0 ganged, 1 unganged.                                                                                                                                                                |
| fi               | FreeTok[1:0]: free tokens. Read-write. Cold reset: 0010b (for FreeTok[3:0]). FreeTok[3:0] is 4-bit ield composed of {FreeTok[3:2], FreeTok[1:0]} in this register. If the link is unganged, the free okens are shared between the two sublinks. |
| 13:12 <b>I</b> s | socRspTok0: isochronous response tokens sublink 0. Read-write. Cold reset: 0.                                                                                                                                                                   |
| 11:10 <b>I</b> s | socPreqTok0: isochronous posted request tokens sublink 0. Read-write. Cold reset: 0.                                                                                                                                                            |
| 9:8 <b>I</b> s   | socReqTok0: isochronous request tokens sublink 0. Read-write. Cold reset: 0.                                                                                                                                                                    |
| 7:6 <b>P</b>     | ProbeTok0: probe tokens sublink 0. Read-write. Cold reset: 2 ganged, 1 unganged.                                                                                                                                                                |
| 5:4 R            | RspTok0: response tokens sublink 0. Read-write. Cold reset: 2 ganged, 1 unganged.                                                                                                                                                               |
| 3:2 <b>P</b>     | PReqTok0: posted request tokens sublink 0. Read-write. Cold reset: 2 ganged, 1 unganged.                                                                                                                                                        |
| 1:0 <b>R</b>     | ReqTok0: request tokens sublink 0. Read-write. Cold reset: 2 ganged, 1 unganged.                                                                                                                                                                |

#### F3x158 Link to XCS Token Count Registers

See F3x140 for more information. Updates to F3x158 do not take effect until after a warm reset.

| Bits | Description                                                                   |
|------|-------------------------------------------------------------------------------|
| 31:4 | Reserved.                                                                     |
| 3:0  | LnkToXcsDRToken: display refresh tokens all links. Read-write. Cold reset: 0. |

#### F3x1[78, 70, 68, 60] NB Machine Check Misc (Thresholding) Registers

These registers may also be accessed through [The NB Machine Check Misc (Thresholding) Register (MC4\_MISC0)] MSR0000\_0413 and MSRC000\_04[0A:08]. These registers are associated with the following error types as specified by the "Error Threshold Group" in Table 53 of [The MCA NB Status Low Register] F3x48[ErrorCode]:

- F3x160 (MSR0000\_0413): DRAM.
- F3x168 (MSRC000\_0408): Link.
- F3x170 (MSRC000\_0409): L3 Cache. If the product does not include an L3 cache, per [The L2/L3 Cache

and L2 TLB Identifiers] CPUID Fn8000\_0006\_EDX, then the Valid and CntP

bits are both 0 and the register logs no information.

• F3x178 (MSRC000\_040A): Reserved.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | <b>Valid</b> . Read-only from configuration space; read-only or read-write from MSR space based on MSRC001_0015[McStatusWrEn]. Reset=1b. 1=A valid CntP field is present in this register.                                                                                                                                                                                                                                                                                                                      |
| 30    | CntP: counter present. Read-only from configuration space; read-only or read-write from MSR space based on MSRC001_0015[McStatusWrEn]. Reset=1b. 1=A valid threshold counter is present. This bit is affected by MSRC001_0015[McStatusWrEn].                                                                                                                                                                                                                                                                    |
| 29    | <b>Locked</b> . Read-only from configuration space; read-only or read-write from MSR space based on MSRC001_0015[McStatusWrEn]. Reset=0b. This bit is set by BIOS to indicate that the this register is not available for OS use. When this bit is set, write to bits[28:0] of this register are ignored. BIOS should set this bit if IntType is set to SMI. Note: when MSRC001_0015[McStatusWrEn] is set, MSR writes to this register update all bits, regardless of the state of the Locked bit in the write. |
| 28:24 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 23:20 | <b>LvtOffset: LVT offset</b> . Read-write. Reset=0000b. This field specifies the address of the LVT entry in the APIC registers as follows: LVT address = (LvtOffset shifted left 4 bits) + 500h (see APIC[530:500]). Only values 0 through 3 are valid; all others reserved.                                                                                                                                                                                                                                   |
| 19    | CntEn: counter enable. Read-write (see also the F3x1[78, 70, 68, 60][Locked]). Reset=0b. 1=Counting of errors specified by "Error Threshold Group" (see above) is enabled.                                                                                                                                                                                                                                                                                                                                      |
| 18:17 | IntType: interrupt type. Read-write (see also the F3x1[78, 70, 68, 60][Locked]). Cold reset=X. This field specifies the type of interrupt signaled when Ovrflw is set.  00b = No Interrupt.  01b = APIC based interrupt (see LvtOffset above) to all CPU cores.  10b = SMI trigger event (always routed to CpuCoreNum 0, as defined in section 2.9.2 [CPU Cores and Downcoring] on page 107); see section 2.14.2.3 [SMI Sources And Delivery] on page 125.  11b = Reserved.                                     |
| 16    | <b>Ovrflw: overflow.</b> Read-write (see also the F3x1[78, 70, 68, 60][Locked]); set-by-hardware. Cold reset=X. This bit is set by hardware when ErrCnt transitions from FFEh to FFFh. When this bit is set, the interrupt selected by the IntType field is generated.                                                                                                                                                                                                                                          |
| 15:12 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11:0  | <b>ErrCnt: error counter.</b> Read-write (see also the F3x1[78, 70, 68, 60][Locked]). Cold reset=X. This is written by software to set the starting value of the error counter. This is incremented by hardware when errors are logged. When this counter overflows, it stays at FFFh (no rollover). To set the threshold value, software should subtract the desired error count (the number of errors necessary in order for an interrupt to be taken) from FFFh and write the result into this field.        |

### F3x180 Extended NB MCA Configuration Register

Reset: 0000 0000h. Note: this register is an extension of [The MCA NB Configuration Register] F3x44.

| Bits  | Description |
|-------|-------------|
| 31:23 | Reserved.   |

| 22 | <b>SyncFloodOnTblWalkErr: sync flood on table walk error enable.</b> Read-write. 1=A sync flood is generated when the DEV or GART table walkers encounter an uncorrectable error. A machine check exception is generated independent of the state of this bit. It is recommended that this bit be set for normal operation. |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21 | <b>SyncFloodOnCpuLeakErr: sync flood on CPU leak error enable.</b> Read-write. 1=A sync flood is generated when one of the CPU cores encounters an uncorrectable error which cannot be contained to the process on the CPU core. It is recommended that this bit be set for normal operation.                               |
| 20 | <b>SyncFloodOnL3LeakErr:</b> sync flood on L3 cache leak error enable. Read-write.1=A sync flood is generated when the L3 cache encounters an uncorrectable error which cannot be contained to the process on one CPU core. It is recommended that this bit be set for normal operation.                                    |
| 10 | Reserved.                                                                                                                                                                                                                                                                                                                   |
| 9  | SyncOnUncNbAryEn: sync flood on uncorrectable NB array error enable. Read-write. 1=Enables sync flood on detection of an error in a NB array that is uncorrectable.                                                                                                                                                         |
| 8  | <b>SyncOnHtProtEn:</b> sync flood on link protocol error enable. Read-write. 1=Enables sync flood on detection of a protocol error on a link.                                                                                                                                                                               |
| 7  | <b>SyncFloodOnTgtAbtErr</b> . Read-write. 1=Enable sync flood on generated or received link responses that indicate target aborts.                                                                                                                                                                                          |
| 6  | <b>SyncFloodOnDatErr</b> . Read-write. 1=Enable sync flood on generated or received link responses that indicate data error.                                                                                                                                                                                                |
| 5  | <b>DisPciCfgCpuMstAbtRsp</b> . Read-write. 1=Disable MCA error reporting for master abort responses to CPU-initiated configuration accesses.                                                                                                                                                                                |
| 4  | <b>MstAbtChgToNoErrs</b> . Read-write. 1=Signal no errors instead of master abort in link response packets to IO devices on detection of a master abort condition. When MstAbtChgToNoErrs and F3x44[IoMstAbortDis] are both set, MstAbtChgToNoErrs takes precedence.                                                        |
| 3  | <b>DatErrChgToTgtAbt</b> . Read-write. 1=Signal target abort instead of data error in link response packets to IO devices (for Gen1 link compatibility).                                                                                                                                                                    |
| 2  | WDTCntSel[3]: watchdog timer count select bit[3]. Read-write. See F3x44[WDTCntSel].                                                                                                                                                                                                                                         |
| 1  | SyncFloodOnUsPwDataErr: sync flood on upstream posted write data error. Read-write. 1=Enable sync flood generation when an upstream posted write data error is detected.                                                                                                                                                    |
| 0  | McaLogUsPwDataErrEn: MCA log of upstream posted write data error enable. Read-write. 1=Enable logging of upstream posted write data errors in MCA (if NB MCA registers are appropriately enabled and configured).                                                                                                           |

# F3x190 Downcore Control Register

Cold reset: 0000 0000h. See section 2.9.2 [CPU Cores and Downcoring] on page 107. Changes to this register do not take effect until after a warm reset.

| Bits | Description                                                                                             |
|------|---------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved.                                                                                               |
|      | <b>DisCore</b> [3:0]. Read-write. 1=Disable the CPU core. 0=Enable the CPU core. Reads provide the last |
|      | value written regardless of whether there has been a warm reset or not.                                 |

#### F3x1A0 L3 Buffer Count Register

Updates to this register do not take effect until after a warm reset.

- To ensure deadlock free operation the following minimum buffer allocations are required: CpuCmdBufCnt >= 1
- If the processor includes an L3 cache (as specified by CPUID Fn8000\_0006\_EDX[L3Size]), then to ensure deadlock free operation the following minimum buffer allocations are required:

  L3ToSriReqCBC >= 2 L3ToSriReqCBC >= (number of CPU cores)
- If the processor does not include an L3 cache, then L3ToSriReqCBC may be 0h.

| Bits  | Description                                                                                                                                                                                                                                                                                                                              |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | Reserved.                                                                                                                                                                                                                                                                                                                                |
| 14:12 | L3ToSriReqCBC: L3 cache to SRI request command buffer count. Read-write. Cold reset: 4h.                                                                                                                                                                                                                                                 |
| 11:9  | Reserved.                                                                                                                                                                                                                                                                                                                                |
| 8:4   | L3FreeListCBC: L3 free list command buffer counter for CPU requests. Read-write. Cold reset = 1Ch for single-core parts, 18h for dual-core parts, and 10h for quad-core parts. BIOS should set this field up per the following equation (although lower values are legal):  • L3FreeListCBC = 32 - CpuCmdBufCnt * (number of CPU cores). |
| 3     | Reserved.                                                                                                                                                                                                                                                                                                                                |
| 2:0   | <b>CpuCmdBufCnt: CPU to SRI command buffer count</b> . Read-write. Cold reset = 4 if the product includes an L3 cache or 2 if it does not. Each CPU core is allocated the number of buffers specified by this field.                                                                                                                     |

#### F3x1CC IBS Control Register

Reset: 0000 0000h. This register can also be read from MSRC001\_103A. The BIOS should program this register to enable performance modeling software to use IBS interrupts.

| Bits | Description                                                                                                                                                                                                                                                                |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved.                                                                                                                                                                                                                                                                  |
| 8    | <b>LvtOffsetVal:</b> local vector table offset valid. Read-write. 1=The offset in LvtOffset is valid. 0=The offset in LvtOffset is not valid and IBS interrupt generation is disabled. The BIOS should set this bit to 1b.                                                 |
| 7:4  | Reserved.                                                                                                                                                                                                                                                                  |
| 3:0  | <b>LvtOffset: local vector table offset</b> . Read-write. This specifies the address of the IBS LVT entry in the APIC registers as follows: LVT address = (LvtOff shifted left 4 bits) + 500h (see APIC[530:500]). Only values of 03b-00b may be programmed in this field. |

#### F3x1E4 SBI Control Register

This register specifies the behavior associated with the SIC and SID pins which may be used to support SMBus-based sideband interface (SBI) protocol. See section 2.13.3 [Sideband Interface (SBI)] on page 121.

| Bits | Description                                                                                          |
|------|------------------------------------------------------------------------------------------------------|
| 31   | SbiRegWrDn: SBI register write done. Reset 1b. Read-only; Set-and-cleared-by-hardware.               |
|      | 1=Write to the SBI registers through F3x1EC has completed. 0=Write to the SBI registers in progress. |

| 30:7 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4  | <b>SbiAddr: SMBus-based sideband interface address</b> . Read-write. Cold reset: specified by the SA[2:0] strap pins (value matches the pins until the deassertion of RESET_L for a cold reset only; value is not changed by a warm reset); 000b in products that do not include SA[2:0] pins. Specifies bits[3:1] of the SMBus address of the processor SBI ports. SMBus address bits [3:1] = {~SA[2],SA[1:0]}. |
| 3    | <b>SbTsiDis: SMBus-based sideband temperature sensor interface disable</b> . Read-only. 1=The processor does not support SMBus-based SB-TSI protocol.                                                                                                                                                                                                                                                            |
| 2    | Must be high. Read-write.                                                                                                                                                                                                                                                                                                                                                                                        |
| 1    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                        |

#### F3x1E8 SBI Address Register

Cold reset 0000\_0000h. The SB-TSI registers can be directly accessed by the processor using F3x1E8 and F3x1EC. To access the registers, F3x1E8[SbiBankSel and SbiRegAddr] are programmed to point to the appropriate register and the read or write access is directed at F3x1EC.

| Bi | its | Description                                                                                                                          |
|----|-----|--------------------------------------------------------------------------------------------------------------------------------------|
| 31 | :8  | Reserved.                                                                                                                            |
| 7: |     | <b>SbiRegAddr: SBI SMBus register address</b> . Read-write. This field specifies the 8-bit address of the SB-TSI register to access. |

## F3x1EC SBI Data Register

Reset 0000\_0000h.

| Bits | Description                                                                                         |
|------|-----------------------------------------------------------------------------------------------------|
| 31:8 | Reserved.                                                                                           |
|      | SbiRegDat: SBI SMBus register data. Read-write. This field specifies the data to be read or written |
|      | to the SBI register selected by F3x1E8[SbiRegAddr].                                                 |

#### F3x1F0 Product Information Register

| Bits  | Description                                                                                                                                                                                                                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | Reserved.                                                                                                                                                                                                                                                                                                   |
| 18:16 | ClkDivAltVid: clock divisor for alternate VID. Read-only. Specifies the ClkDivisor value that must be programmed into the [The ACPI Power State Control Registers] F3x[84:80] associated with C3 or C1E in order to support the default value of [The Clock Power/Timing Control 2 Register] F3xDC[AltVid]. |
| 15:0  | <b>BrandId</b> . Read-only. Brand identifier. This is identical to CPUID Fn8000_0001_EBX[BrandId].                                                                                                                                                                                                          |

## F3x1FC Product Information Register

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
| 21:17 | <b>DualPlaneNbVidOff[4:0].</b> Read-only. Specifies the NbVid offset value required for NB operation at the frequency specified by DualPlaneNbFid. DualPlaneNbVidOff is applied relative to SinglePlaneNbVid using the following formula: DualPlaneNbVid = SinglePlaneNbVid - {00b, DualPlaneNbVid-Off[4:0]}. See also section 2.4.2.6 [BIOS Northbridge COF and VID Configuration] on page 35. |
| 16:14 | <b>DualPlaneNbFidOff[2:0].</b> Read-only. Specifies the NbFid value for platforms with separate VDD and VDDNB power planes. This offset is applied relative to SinglePlaneNbFid using the following formula: DualPlaneNbFid = SinglePlaneNbFid + {00b, DualPlaneNbFidOff[2:0]}. See also section 2.4.2.6 [BIOS Northbridge COF and VID Configuration] on page 35.                               |
| 13:7  | <b>SinglePlaneNbVid[6:0].</b> Read-only. Specifies the NbVid value required for NB operation at the frequency specified by SinglePlaneNbFid. See also section 2.4.2.6 [BIOS Northbridge COF and VID Configuration] on page 35.                                                                                                                                                                  |
| 6:2   | <b>SinglePlaneNbFid[4:0].</b> Read-only. Specifies the NbFid value for platforms with unified VDD and VDDNB power planes. See also section 2.4.2.6 [BIOS Northbridge COF and VID Configuration] on page 35.                                                                                                                                                                                     |
| 1     | <b>NbVidUpdateAll.</b> Read-only. Indicates that software is required to update NbVid after cold reset based on the sequence defined in section 2.4.2.6 [BIOS Northbridge COF and VID Configuration] on page 35.                                                                                                                                                                                |
| 0     | <b>NbCofVidUpdate.</b> Read-only. Indicates that software is required to update the NB COF and NbVid after cold reset based on the sequence defined in section 2.4.2.6 [BIOS Northbridge COF and VID Configuration] on page 35.                                                                                                                                                                 |

## 3.7 Function 4 Link Control Registers

See section 3.1 [Register Descriptions and Mnemonics] on page 135 for a description of the register naming convention. See section 2.11 [Configuration Space] on page 112 for details about how to access this space.

#### F4x00 Device/Vendor ID Register

| Reset: 1204 1022h. |                                 |
|--------------------|---------------------------------|
| Bits               | Description                     |
| 31:16              | DeviceID: device ID. Read-only. |
| 15:0               | VendorID: vendor ID. Read-only. |

## F4x04 Status/Command Register

| Reset: ( | Reset: 00?0 0000h.                                                                                                                                                                                                                                                                         |  |  |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits     | Description                                                                                                                                                                                                                                                                                |  |  |
|          | <b>Status.</b> Read-only. Only bit[20] may be set to indicate the existence of a PCI-defined capability block. 0=No supported links are unganged. 1=At least one link may be unganged, in which case there is a capability block associated with sublink one of the link in this function. |  |  |
| 15:0     | Command. Read-only.                                                                                                                                                                                                                                                                        |  |  |

#### F4x08 Class Code/Revision ID Register

| Reset: 0600 0000h. |                                                                                                |
|--------------------|------------------------------------------------------------------------------------------------|
| Bits               | Description                                                                                    |
| 31:8               | ClassCode. Read-only. Provides the host bridge class code as defined in the PCI specification. |
| 7:0                | RevID: revision ID. Read-only.                                                                 |

#### F4x0C Header Type Register

| Reset: 0080 0000h. |      |                                                                                                                                                                          |
|--------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Bits | Description                                                                                                                                                              |
| Ī                  |      | <b>HeaderTypeReg.</b> Read-only. These bits are fixed at their default values. The header type field indicates that there are multiple functions present in this device. |

## F4x34 Capabilities Pointer Register

| Reset: ( | Reset: 0000 00??h.                                             |                                                                                              |  |  |
|----------|----------------------------------------------------------------|----------------------------------------------------------------------------------------------|--|--|
| Bits     | Descriptio                                                     | Description                                                                                  |  |  |
| 31:8     | Reserved.                                                      |                                                                                              |  |  |
| 7:0      | CapPtr: c                                                      | apabilities pointer. Read-only. Specifies the offset of the link capabilities block based on |  |  |
|          | which links are supported and unganged. The value provided is: |                                                                                              |  |  |
|          | 80h                                                            | 80h If link 0 is supported and unganged.                                                     |  |  |
|          | A0h                                                            | If link 0 is ganged/unsupported and link 1 is supported and unganged.                        |  |  |
|          | C0h                                                            | If link 0 and 1 are ganged/unsupported and link 2 is supported and unganged.                 |  |  |
|          | E0h                                                            | If link 0, 1, and 2 are ganged/unsupported and link 3 is supported and unganged.             |  |  |

### F4x[E0, C0, A0, 80] Sublink 1 Capability Registers

See F0x[E0, C0, A0, 80] for details of this register. If the link is ganged or not supported, then this register is reserved. Note: the CapPtr field is controlled similarly to F0x[E0, C0, A0, 80][CapPtr]. However, based on whether the next link is supported *and* unganged.

#### F4x[E4, C4, A4, 84] Sublink 1 Control Registers

See F0x[E4, C4, A4, 84] for details of this register. If the link is ganged or not supported, then this register is reserved.

#### F4x[E8, C8, A8, 88] Sublink 1 Frequency/Revision Registers

See F0x[E8, C8, A8, 88] for details of this register. If the link is ganged or not supported, then this register is reserved.

#### F4x[EC, CC, AC, 8C] Sublink 1 Feature Capability Registers

See F0x[EC, CC, AC, 8C] for details of this register. If the link is ganged or not supported, then this register is reserved.

#### F4x[F0, D0, B0, 90] Sublink 1 Base Channel Buffer Count Registers

See F0x[F0, D0, B0, 90] for details of this register. If the link is ganged or not supported, then this register is reserved.

#### F4x[F4, D4, B4, 94] Sublink 1 Isochronous Channel Buffer Count Registers

See F0x[F4, D4, B4, 94] for details of this register. If the link is ganged or not supported, then this register is reserved.

#### F4x[F8, D8, B8, 98] Sublink 1 Link Type Registers

See F0x[F8, D8, B8, 98] for details of this register. If the link is ganged or not supported, then this register is reserved.

#### F4x1[98, 90, 88, 80] Link Phy Offset Registers

Cold reset: 8000 0000h. The links each include an array of registers called F4x1[9C, 94, 8C, 84]\_x[NN:00], which are defined following F4x1[9C, 94, 8C, 84]. These are used primarily to control link electrical parameters and to program the link BIST engine. [The Link Phy Offset Registers] F4x1[98, 90, 88, 80] and [The Link Phy Data Port] F4x1[9C, 94, 8C, 84] are used to access these registers. The register number (i.e., the number that follows "\_x" in the register mnemonic) is specified by F4x1[98, 90, 88, 80][LinkPhyOffset]. Access to these registers is accomplished as follows:

#### · Reads:

- Write the register number to F4x1[98, 90, 88, 80][LinkPhyOffset] with F4x1[98, 90, 88, 80][LinkPhyWrite]=0.
- Poll F4x1[98, 90, 88, 80][LinkPhyDone] until it is high.
- Read the register contents from F4x1[9C, 94, 8C, 84].

#### • Writes:

- Write all 32 bits of register data to F4x1[9C, 94, 8C, 84] (individual byte writes are not supported).
- Write the register number to F4x1[98, 90, 88, 80][LinkPhyOffset] with F4x1[98, 90, 88, 80][LinkPhyWrite]=1.
- Poll F4x1[98, 90, 88, 80][LinkPhyDone] until it is high to ensure that the contents of the write have been delivered to the phy.

The links also include an array of direct map registers. A link phy register is not a direct map register unless it is specified in the register description. The read and write access to the direct map registers is similar to the process described above except for the following:

- F4x1[98, 90, 88, 80][DirectMapEn] must be set.
- The register number (i.e., the number that follows "\_x" in the register mnemonic) expands to 16 bit wide and is specified by F4x1[98, 90, 88, 80][{UpperLinkPhyOffset, LinkPhyOffset}].For example, to access [The DLL Control and Test Register 3] F4x1[9C, 94, 8C, 84]\_x[530A, 520A], F4x1[98, 90, 88, 80][{UpperLink-PhyOffset, LinkPhyOffset}] must be programmed as 4'h530A or 4'h520A.

Note: Read or write accesses to undocumented or undefined register numbers can result in undefined behavior.

Note: Read or write accesses to links that are not implemented on the package complete with undefined results.

F4x180 and F4x184 are for link 0; F4x188 and F4x18C are for link 1; F4x190 and F4x194 are for link 2; F4x198 and F4x19C are for link 3.

| Bits  | Description                                                                                                                                                                                                                         |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | <b>LinkPhyDone: link phy access done</b> . Read-only. 1=The access to one of the F4x1[9C, 94, 8C, 84]_x[NN:00] registers is complete. 0=The access is still in progress.                                                            |
| 30    | LinkPhyWrite: link phy read/write select. Read-write. 0=Read one of the F4x1[9C, 94, 8C, 84]_x[NN:00] registers. 1=Write one of the F4x1[9C, 94, 8C, 84]_x[NN:00] registers.                                                        |
| 29    | <b>DirectMapEn: direct map enable</b> . Read-write. Cold reset 0. 1=Enable link phy address direct map mode. This bit should only be set to access direct map link phy address registers as specified in the register descriptions. |
| 28:16 | Reserved.                                                                                                                                                                                                                           |
| 15:9  | UpperLinkPhyOffset: upper link phy offset address bits. Read-write.                                                                                                                                                                 |
| 8:0   | LinkPhyOffset: link phy offset. Read-write.                                                                                                                                                                                         |

#### F4x1[9C, 94, 8C, 84] Link Phy Data Port

See F4x1[98, 90, 88, 80] for details about this port.

#### F4x1[9C, 94, 8C, 84]\_x[D0, C0] Link Phy Impedance Registers

See F4x1[98, 90, 88, 80] for register access information. The \_xC0 register number specifies values for CAD[7:0], CTL0, and CLK0; the \_xD0 register number specifies values for CAD[15:8], CTL1, and CLK1. These register bits are updated as specified by F0x16C[ImmUpdate]. Note: updates to these registers that result in a change to impedance may not take effect in the phy for up to 2 microseconds after the update to this register completes (or until a disconnect if ImmUpdate is clear).

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:29 | RttCtl: receiver termination resistance (Rtt) control. Read-write. Cold reset: 0. This field specifies how the receiver termination resistance value is calculated. All values between 00h and 1Fh are valid.  Bits Definition  000b Rtt is as determined by the compensation circuit, F4x1[9C, 94, 8C, 84]_xE0[RttRawCal].  001b Rtt is as specified by the index field (F4x1[9C, 94, 8C, 84]_x[D0, C0][RttIndex]).  010b Rtt is as specified by the difference: RttRawCal - RttIndex. If this results in a value that is less than 00h, then 00h is used. 011bRtt is as specified by the sum: RttRawCal + RttIndex. If this results in a value that is greater than 1Fh, then 1Fh is used.  100b Enable only one tap of the Rtt resistor, as specified by RttIndex, and disable the base resistor that is normally always enabled. This is intended for testing purposes only.  101b - 111b: reserved. |  |  |
|       | For all modes (except 100b), higher values reduce the resistance of Rtt and lower values increase the resistance of Rtt. See section 2.7.2 [Termination and Compensation] on page 56 for more information about compensation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 28:21 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 20:16 | RttIndex: receiver termination resistance (Rtt) index. Read-write. Cold reset: 1_1111b. See RttCtl for details about how this field is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |

| 15:13 | RonCtl                                                                                                                                      | RonCtl: transmitter resistance (Ron) control. Read-write. Cold reset: 0. This field specifies how                                                                                                                                                                 |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|       | the trans                                                                                                                                   | the transmitter resistance value is calculated.                                                                                                                                                                                                                   |  |  |
|       | <u>Bits</u>                                                                                                                                 | <u>Definition</u>                                                                                                                                                                                                                                                 |  |  |
|       | 000b                                                                                                                                        | Ron is as determined by the compensation circuit, F4x1[9C, 94, 8C, 84]_xE0[RonRawCal].                                                                                                                                                                            |  |  |
|       | 001b                                                                                                                                        | Ron is as specified by the index field (F4x1[9C, 94, 8C, 84]_x[D0, C0][RonIndex]).                                                                                                                                                                                |  |  |
|       | 010b                                                                                                                                        | Ron is as specified by the difference: RonRawCal - RonIndex. If this results in a value that is less than 00h, then 00h is used. 011bRon is as specified by the sum: RonRawCal + RonIndex. If this results in a value that is greater than 1Fh, then 1Fh is used. |  |  |
|       | 100b<br>101b -                                                                                                                              | Enable only one tap of the Ron resistor, as specified by RonIndex, and disable the base resistor that is normally aways enabled. This is intended for testing purposes only. 111b: reserved.                                                                      |  |  |
|       | resistanc                                                                                                                                   | nodes (except 100b), higher values reduce the resistance of Ron and lower values increase the ce of Ron. See section 2.7.2 [Termination and Compensation] on page 56 for more tion about compensation.                                                            |  |  |
| 12:5  | Reserve                                                                                                                                     | d.                                                                                                                                                                                                                                                                |  |  |
| 4:0   | <b>RonIndex: transmitter resistance (Ron) index</b> . Read-write. Cold reset: 1_1111b. See RonCtl for details about how this field is used. |                                                                                                                                                                                                                                                                   |  |  |

## F4x1[9C, 94, 8C, 84]\_x[D1, C1] Link Phy Receiver Loop Filter Registers

See F4x1[98, 90, 88, 80] for register access information. The \_xC1 register number specifies values for CAD[7:0], CTL0, and CLK0; the \_xD1 register number specifies values for CAD[15:8], CTL1, and CLK1. These register bits are updated as specified by F0x16C[ImmUpdate].



Figure 12: Link phy recovered clock and sample clock.

When the link is in a mode that relies on dynamic phase alignment (automatic sample-clock correction), then the processor generates a recovered clock for each lane based on transitions in the lane. The ideal recovered clock transitions at exactly the same time as the transitions in the lane. Phase detection logic detects if the recovered clock transitions before or after the lane transition. The digital loop filter (DLF) is logic that adjusts the phase of the recovered clock such that its transitions match the transition time of the lane as much as possible. The DLF counts the number of times the lane transitions before the recovered clock versus after to determine whether to adjust the recovered clock phase. The DLF uses an 8-bit counter, called the loop filter counter (LFC) for this purpose. The LFC controls are included in this register. They specify DLF behavior as follows:

- LfcMax is programmed to be greater than LfcMin.
- The LFC is initialized to LfcMin.
- The LFC is updated periodically. The logic keeps a tally of the number of lane transitions occurring before and after the recovered clock transition within each update period.
- To start, if there is a net lane transition occurs after the recovered clock transition within the update period,

the LFC is incremented by the net value; on the other hand, if there is a net lane transition occurs before the recovered clock transition, the LFC is decremented. However, if the LFC is ever decremented while it is zero, these rules are reversed (and the LFC is incremented instead). Thus, if there is a phase correction needed, the LFC trends either upward or downward; if it trends downward, it hits zero and then trends upward again.

• If the LFC reaches LfcMax value, then (1) the phase of the recovered clock is adjusted in the appropriate direction, (2) the LFC is set to the LfcMin value.

The LfcMin and LfcMax fields are designed to improve the stability of the recovered clock phase while improving the response time for multiple phase updates in the same direction. For example, if the recovered clock phase needs several adjustments in the same direction, then: the LFC increments until it hits LfcMax value and then be set to LfcMin (and trigger a phase adjustment); then it would increment to LfcMax value again to trigger the next phase adjustment. If, however, the next phase adjustment needs to be in the opposite direction, the LFC would decrement to zero, change direction, and then increment up to LfcMax again. In this way, phase adjustments in the same direction occur more quickly than phase adjustments in the opposite direction of the prior phase adjustment.

The nominal sample clock is offset by 90 degrees from the *recovered clock*. An offset can be inserted to move the sample clock from the nominal position, based on SamClkPiOffset and SamClkPiOffsetSign.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 29:22 | <b>LfcMax: loop filter counter maximum value</b> . Read-write. Cold reset: 80h. The BIOS should program this field to 20h if link frequency is 1.2GHz or greater or 10h if link frequency is less than 1.2GHz.                                                                                                                                                                                                                                                                                                                                           |
| 21:14 | <b>LfcMin: loop filter counter minimum value</b> . Read-write. Cold reset: 40h. The BIOS should program this field to 10h if link frequency is 1.2GHz or greater or 8h if link frequency is less than 1.2GHz.                                                                                                                                                                                                                                                                                                                                            |
| 13:10 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9:8   | Must be 10b. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7     | SamClkPiOffsetEn: sample clock phase interpolator offset enable. Read-write. Cold reset: 0. 1=Enable offset insertion around the nominal sample clock position.                                                                                                                                                                                                                                                                                                                                                                                          |
| 6:4   | <ul> <li>SamClkPiOffset: sample clock phase interpolator offset setting. Read-write. Cold reset: X. This field specifies the magnitude of the offset of the sample clock from the nominal position. See Figure 12. This field is encoded as follows.</li> <li>Sample clock phase interpolator offset = (SamClkPiOffset + 1) * step size.</li> <li>If link speed is &gt;3.6GT/s, the expected typical step size is 2ps with a +/-1ps error.</li> <li>If link speed is &lt;=3.6GT/s, the expected typical step size is 3ps with a +/-1ps error.</li> </ul> |
| 3     | SamClkPiOffsetSign: sample clock phase interpolator offset setting sign bit. Read-write. Cold reset: X. 0=Sample clock is moved to before the nominal position. 1=Sample clock is moved to after the nominal position. See SamClkPiOffset and Figure 12.                                                                                                                                                                                                                                                                                                 |
| 2:0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### F4x1[9C, 94, 8C, 84]\_x[D3, C3] Link Phy Timing Margin Registers

See F4x1[98, 90, 88, 80] for register access information. The \_xC3 register number specifies values for CAD[7:0], CTL0, and CLK0; the \_xD3 register number specifies values for CAD[15:8], CTL1, and CLK1.

The built in jitter injection test mode is useful for checking the clock data recovery tracking bandwidth of the receiver. By forcing the sample clock to move from the lock position by a controlled amount and then observing the time it takes to recover, the tracking rate and bandwidth can be estimated. This register provides the control of the test mode.

The jitter injection test mode works as follows.

- The circuit is clocked by a jitter injection clock derived from dividing the link forwarded clock by 2.5; for example, if the link speed is 5.2GT/s and the link forwarded clock frequency is 2.6GHz, the jitter injection clock frequency becomes 1.04GHz.
- There are 2 phases, the on phase and the off phase. It starts with the on phase once the test mode is enabled.
- During the on phase, at every tick of jitter injection clock, the sample clock is moved away from the nominal lock position by 1/96\*UI.
- The direction of adjustment is specified by JitterInjDir.
- The on phase adjustment continues for a number of times as specified by JitterInjOnCnt.
- Then the adjustment turns off for a duration specified by {JitterInjOffCnt, JitterInjOnCnt} \* jitter injection clock period, this is known as the off phase. During this time, clock data recovery resumes to try to adjust the position of the sample clock back to the center of the data eye.
- The off phase is followed by the on phase again. The process continues to alternate between the on phase and the off phase until the jitter injection test mode is disabled.

In addition, the JitterInjHold bit may be set to inject a hold state at the end of the on phase. This stops clock data recovery from resuming after the on phase, hence holding the sample clock at its last adjusted position until the JitterInjHold bit is cleared. This test mode may be useful for margining the width of the input data eye.

Note: This margining mechanism is not characterized for precision jitter adjustments or measurements.

| Bits  | Description                                                                                                                                                                                                                                       |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31    | Reserved.                                                                                                                                                                                                                                         |  |  |
| 30    | <b>JitterInjEn: jitter injection enable</b> . Read-write. Cold reset: 0. 1=Jitter injection test mode is enabled.                                                                                                                                 |  |  |
| 29    | JitterInjDir: jitter injection direction. Read-write. Cold reset: 0.                                                                                                                                                                              |  |  |
|       | Bit Definition                                                                                                                                                                                                                                    |  |  |
|       | 0 Move clock before the nominal lock position.                                                                                                                                                                                                    |  |  |
|       | 1 Move clock after the nominal lock position.                                                                                                                                                                                                     |  |  |
| 28:23 | JitterInjOnCnt: jitter injection on count. Read-write. Cold reset: 0.                                                                                                                                                                             |  |  |
| 22:16 | Reserved.                                                                                                                                                                                                                                         |  |  |
| 15:10 | <b>JitterInjOffCnt:jitter injection off count.</b> Read-write. Cold reset: 0. The jitter injection off time count is a 12bit code, this field specifies the most significant 6 bits. The least significant 6 bits are the same as JitterInjOnCnt. |  |  |
| 9     | JitterInjHold:jitter injection hold. Read-write. Cold reset: 0. 1=Jitter injection hold is enabled.                                                                                                                                               |  |  |
| 8:0   | Reserved.                                                                                                                                                                                                                                         |  |  |

#### F4x1[9C, 94, 8C, 84] x[D4, C4] Link Phy DFE and DFR Control Registers

See F4x1[98, 90, 88, 80] for register access information. The \_xC4 register number specifies values for CAD[7:0], CTL0, and CLK0; the \_xD4 register number specifies values for CAD[15:8], CTL1, and CLK1. These register bits are updated as specified by F0x16C[ImmUpdate].

The processor supports decision feedback restore (DFR), a function that enables on-chip AC coupling on the receiver path in Gen3 DC-coupled mode, to improve the receiver's ability to operate over a longer channel. In this mode, the receiver on the processor must be programmed with the expected peak single-ended DC voltage level over the single-ended DC common mode voltage level when a static 1 or 0 is driven. For example, without deemphasis at nominal supply voltage of 1.2V, the peak single ended voltage is expected to be 300mV above the single ended DC common mode voltage level. The value is dependent on the deemphasis setting of the transmitter on the other end of the channel. BIOS should set up the DCV field as follows.

| Far-device deemphasis setting | DC\ |
|-------------------------------|-----|
| No deemphasis                 | 28h |
| -3dB postcursor               | 1Ch |
| -6dB postcursor               | 14h |
| -8dB postcursor               | 10h |

Decision feedback equalization (DFE) can be enabled to enhance Gen3 link operation. Once enabled, the receiver uses the logic level of the previous data bit to adjust the voltage threshold of the sampler in the direction that causes the sampler to switch sooner when the data bit transitions to the opposite logic level for the next bit. The control and DFE voltage level are included in this register.

| Bits  | Description                                                                                                |  |  |
|-------|------------------------------------------------------------------------------------------------------------|--|--|
| 31:16 | Reserved.                                                                                                  |  |  |
| 15:10 | DCV: transmit single ended DC voltage level. Read-write. Cold reset: 0.                                    |  |  |
|       |                                                                                                            |  |  |
| 9:8   | Reserved.                                                                                                  |  |  |
| 7     | <b>DfeEn: DFE enable</b> . Read-write. Cold reset: 0. 1=Decision feedback equalization is enabled.         |  |  |
| 6:5   | <b>DfeVoltage: DFE offset voltage level.</b> Read-write. Cold reset: 0. This field specifies the magnitude |  |  |
|       | of the DFE offset voltage.                                                                                 |  |  |
|       | <u>Bits</u> <u>Definition</u>                                                                              |  |  |
|       | 00b DFE offset voltage=25mV.                                                                               |  |  |
|       | 01b DFE offset voltage=12.5mV.                                                                             |  |  |
|       | 10b DFE offset voltage=20mV.                                                                               |  |  |
|       | 11b DFE offset voltage=35mV.                                                                               |  |  |
| 4     | Must be low. Read-write.                                                                                   |  |  |
| 3     | Must be low. Read-write.                                                                                   |  |  |
| 2     | Must be low. Read-write.                                                                                   |  |  |
| 1:0   | Reserved.                                                                                                  |  |  |

#### F4x1[9C, 94, 8C, 84]\_x[D5, C5] Link Phy Deemphasis Value Registers

See F4x1[98, 90, 88, 80] for register access information. The \_xC5 register number specifies the deemphasis values for CAD[7:0], CTL0, and CLK0; the \_xD5 register number specifies the deemphasis values for CAD[15:8], CTL1, and CLK1. See section 2.7.3 [Equalization] on page 57 for more information about deemphasis. These register bits are updated as specified by F0x16C[ImmUpdate].

In Gen3 link DC-coupled mode, three postcursor deemphasis settings, -3dB, -6dB and -8dB are supported. In addition, for Gen3 link AC-coupled mode, a -11dB postcursor deemphasis setting and a -8dB precursor setting are supported. Normally, the precursor setting is only enabled together with the -11dB postcursor setting. The fields in this register can be programmed during link initialization to select the right deemphasis setting as follows.

| Gen3 deemphasis setting | <u>DL1, DL2, DP1</u> | PostCur1En | PostCur2En | PreCur1En | MapPostCur2En |
|-------------------------|----------------------|------------|------------|-----------|---------------|
| No deemphasis           | 00h, 00h, 00h        | 0          | 0          | 0         | 0             |
| -3dB postcursor         | 12h, 00h, 00h        | 1          | 0          | 0         | 0             |
| -6dB postcursor         | 1Fh, 00h, 00h        | 1          | 0          | 0         | 0             |
| -8dB postcursor         | 1Fh, 06h, 00h        | 1          | 1          | 0         | 1             |
| -11dB postcursor        | 1Fh, 0Dh, 00h        | 1          | 1          | 0         | 1             |
| -11dB postcursor with   |                      |            |            |           |               |
| -8dB precursor          | 1Fh, 06h, 07h        | 1          | 1          | 1         | 1             |
|                         |                      |            |            |           |               |

#### Note:

- MapPreCurEn=0 for all the supported Gen 3 deemphasis settings.
- Deemphasis is not supported by the transmit clock lanes.

Deemphasis is not supported when operating at Gen1 link frequencies. Hence, all relevant deemphasis fields in this register should be left in the default state; otherwise, it can cause undefined behavior.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | <b>PostCur1En: post-cursor 1 deemphasis enable</b> . Read-write. Cold reset: 0. 1=Post-cursor deemphasis is enabled. 0=Post-cursor 1 deemphasis is not supported.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 30    | <b>PostCur2En: post-cursor 2 deemphasis enable</b> . Read-write. Cold reset: 0. 1=Post-cursor deemphasis is enabled. 0=Post-cursor 2 deemphasis is not supported.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 29    | <b>PreCur1En: pre-cursor 1 deemphasis enable</b> . Read-write. Cold reset: 0. 1=The data path to the transmitter is delayed by one bit time in support of pre-cursor 1 deemphasis. 0=The data path to the transmitter is not delayed by one bit time; pre-cursor 1 deemphasis is not supported. If pre-cursor 1 deemphasis is not required, this bit should be left in the low state for better performance.                                                                                                                                                                                |
| 28:26 | Must be 000b. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 25:21 | <ul> <li>VML: transmitter voltage margin level. Read-write. Cold reset: 0. 0=Voltage margining is disabled. This field specifies a reduction in the nominal output differential voltage levels, full-swing or deemphasized, as follows:</li> <li>Margined diff voltage = nominal diff voltage * (1 - VML/3Eh)</li> <li>Voltage margining controlled by this field is intended to aid in link electrical testing and characterization. Note that the actual voltage levels are subject to quantization effects and other effects that reduce the accuracy of the above equations.</li> </ul> |
| 20:16 | <b>DL1: deemphasis level 1</b> . Read-write. Cold reset: 12h. The cold reset value supports -3dB deemphasis level for booting in Gen3 link AC-coupled mode.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15:13 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12:8  | <b>DL2: deemphasis level 2</b> . Read-write. Cold reset: 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6     | <b>MapPostCur2En: Map post-cursor 2 deemphasis enable</b> . Read-write. Cold reset: 0. 1=Post-cursor 2 deemphasis is mapped to post-cursor 1 deemphasis. See above.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5     | <b>MapPreCurEn: Map pre-cursor deemphasis enable.</b> Read-write. Cold reset: 0. 1=Pre-cursor deemphasis is mapped to post-cursor 1 deemphasis. See above.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4:0   | DP1: deemphasis pre-cursor level 1. Read-write. Cold reset: 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### F4x1[9C, 94, 8C, 84]\_x[DF, CF] Link FIFO Read Pointer Optimization Registers

Cold reset: 0000 0000h. See F4x1[98, 90, 88, 80] for register access information. The \_xCF register number specifies values for CAD[7:0], CTL0, and CLK0; the \_xDF register number specifies values for CAD[15:8], CTL1, and CLK1.

There is a synchronization FIFO between the NB clock domain and each of the link clock domains. At cold reset, the read pointer and write pointer for each of these FIFOs is positioned conservatively (30 bit-times apart), such that FIFO latency may be greater than is necessary. This register may be used to position the read pointer and write pointer of each FIFO closer to each other such that latency is reduced. Each of the fields of this register specify the number of positions to move read pointer closer to the write pointer. After writing to this register, the new values are applied to the FIFOs each time the link disconnects and reconnects, including warm resets and LDTSTOP\_L assertions. Reads from the register after a write but before the link disconnects and reconnects, returns the current value, not the pending value from the last write. Async clocking mode does not move the pointers closer than programmed, it only allows them to keep the programmed separation when the received clock is faster or slower than the transmit clock.

This register should be programmed to 0000\_006Dh for Gen 1 links.

| Bits | Descrip                                                                                                                                                                                                                                                                                                               | Description                                                                                                                                                                                                                                                                                        |  |  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:8 | Reserve                                                                                                                                                                                                                                                                                                               | Reserved.                                                                                                                                                                                                                                                                                          |  |  |
| 7:4  | 7:4 XmtRdPtr: transmit FIFO read pointer. Read-write. Specified in double-bit time increments.  Oh Position the read pointer 0 bit times closer to the write pointer.  1h Position the read pointer 2 bit times closer to the write pointer.   Fh Position the read pointer 30 bit times closer to the write pointer. |                                                                                                                                                                                                                                                                                                    |  |  |
| 3:0  | RcvRd<br>Oh<br>1h<br><br>Fh                                                                                                                                                                                                                                                                                           | Ptr: receive FIFO read pointer. Read-write. Specified in double-bit time increments.  Position the read pointer 0 bit times closer to the write pointer.  Position the read pointer 2 bit times closer to the write pointer.   Position the read pointer 30 bit times closer to the write pointer. |  |  |

#### F4x1[9C, 94, 8C, 84]\_xE0 Link Phy Compensation Control Register

See F4x1[98, 90, 88, 80] for register access information. These register bits are updated as specified by F0x16C[ImmUpdate].

| Bits  | Description                                                                                     |  |  |
|-------|-------------------------------------------------------------------------------------------------|--|--|
| 31:30 | CompCyc: compensation cycle. Read-write. Cold reset: 0. This specifies the number of internal   |  |  |
|       | clock cycles used in averaging out compensation values.                                         |  |  |
|       | Bits Number of clocks                                                                           |  |  |
|       | 00b 256                                                                                         |  |  |
|       | 01b 128                                                                                         |  |  |
|       | 10b 64                                                                                          |  |  |
|       | 11b 32                                                                                          |  |  |
|       | It is recommended that these bits remain in the default state.                                  |  |  |
| 29:28 | Reserved.                                                                                       |  |  |
| 27:23 | RttRawCal: receiver termination resistance (Rtt) raw calibration value. Read-only. Cold reset:  |  |  |
|       | X. This field provides the raw Rtt calibration value as determined by the compensation circuit. |  |  |

| 22:18 | RonRawCal: transmitter resistance (Ron) raw calibration value. Read-only. Cold reset: X. This |
|-------|-----------------------------------------------------------------------------------------------|
|       | field provides the raw Ron calibration value as determined by the compensation circuit.       |
| 17:0  | Reserved.                                                                                     |

# F4x1[9C, 94, 8C, 84]\_x100 Link BIST Control Register

| Bits  | Description                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                |                                                                  |                                                                 |                                                                                                                               |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31    | <b>Width</b> . Read-only. Indicates the implemented width of the BIST engine. 0=8 bits. In 16-bit links, the same patterns are transmitted on the upper and lower sublinks. The upper bit of F0x[18C:170][Lane-Sel] selects which half of the link is checked in the receiver. |                                                                                                                                                                                                                                                                                                                                                |                                                                  |                                                                 |                                                                                                                               |  |  |  |
| 30:27 | Reserved.                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                |                                                                  |                                                                 |                                                                                                                               |  |  |  |
| 26:16 | undefined behaupon detection                                                                                                                                                                                                                                                   | <b>ErrCnt: error count</b> . Read; write-1s-only-to-clear (writes other than all-zeroes or all-ones result in undefined behavior); controlled by hardware. Cold reset: 0. This field is incremented by hardware upon detection of each error on any lane. This count is the sum of error counts from each lane, each of which saturates at 63. |                                                                  |                                                                 |                                                                                                                               |  |  |  |
| 15:13 | Reserved.                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                |                                                                  |                                                                 |                                                                                                                               |  |  |  |
| 12:8  | ones result in the ware to the land tiple bits fail at ErrLnNum I 0000b (0001b (0010b (0011b)).                                                                                                                                                                                | undefined behavior); co<br>ne of the sublink that fai<br>t the same time, the hig                                                                                                                                                                                                                                                              | ontrolled by led upon det thest-numbe ErrLnNum 0101b 0111b 1000b | hardware. Cold resection of the first extended bit is recorded. | tes other than all-zeroes or all-<br>set: 0. This value is set by hard-<br>error by the BIST receiver. If mul-                |  |  |  |
| 7:6   | undefined beha<br>error type upon<br>Bits Status<br>00b no error<br>01b training of<br>10b pattern m<br>11b reserved<br>InvRotEn: inv                                                                                                                                          | avior); controlled by hat n detection of the first elerror niscompare version rotate enable.                                                                                                                                                                                                                                                   | Read-write.                                                      | d reset: 00b. This BIST receiver.                               | an all-zeroes or all-ones result in value is set by hardware to the s bit enables rotation of [The BC, 84]_x110 and [The Link |  |  |  |
|       |                                                                                                                                                                                                                                                                                | ound RX Inversion R                                                                                                                                                                                                                                                                                                                            | _                                                                |                                                                 | 4]_x130 at the completion of                                                                                                  |  |  |  |
| 4:2   | Reserved.                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                |                                                                  |                                                                 |                                                                                                                               |  |  |  |

| 1 | <b>RxDis: receiver disable</b> . Read-write. Cold reset: 0. 1=Disables checking of BIST patterns in the |
|---|---------------------------------------------------------------------------------------------------------|
|   | receiver if BIST is already active. An LDTSTOP# or RESET# assertion is still required to exit BIST.     |
|   | If BIST has not started yet, setting this bit additionally removes any dependency on receiver link      |
|   | training, such that the transmitter sequences through the minimum training sets and begin sending       |
|   | BIST patterns at the completion of these training sets.                                                 |
| 0 | Reserved.                                                                                               |

# F4x1[9C, 94, 8C, 84]\_x104 Link BIST Southbound TX Pattern Control Register

See F4x1[98, 90, 88, 80] for register access information.

|       | 1[98, 90, 88, 80] for register access information.                                                                                                                                                                           |                                                                                                                                                       |  |  |  |  |  |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Bits  | Description                                                                                                                                                                                                                  |                                                                                                                                                       |  |  |  |  |  |  |
| 31:26 | Reserved.                                                                                                                                                                                                                    |                                                                                                                                                       |  |  |  |  |  |  |
| 25:21 | ConstCnt: constant generator count. Read-write. Cold reset: 0. Selects the number of times to repeat the constant selected by ConstSel, in multiples of 24 bits. 00000b: 0 (disabled) 00001b: 24 bits 11111b: 24*31=744 bits |                                                                                                                                                       |  |  |  |  |  |  |
| 20    | ConstSel:                                                                                                                                                                                                                    | constant generator select. Read-write. Cold reset: 0. Selects 0 or 1 to send for the time                                                             |  |  |  |  |  |  |
|       |                                                                                                                                                                                                                              | ant generator is active.                                                                                                                              |  |  |  |  |  |  |
| 19:13 |                                                                                                                                                                                                                              | modulo-N count. Read-write. Cold reset: 0. Selects the number of times to repeat the N counter (a counter with a period of N bits) pattern, 0 to 127. |  |  |  |  |  |  |
| 12:10 | ModSel: n                                                                                                                                                                                                                    | nodulo-N select. Read-write. Cold reset: 0. Selects the pattern sent by the Modulo-N                                                                  |  |  |  |  |  |  |
|       | counter:                                                                                                                                                                                                                     |                                                                                                                                                       |  |  |  |  |  |  |
|       | <u>Bits</u>                                                                                                                                                                                                                  | <u>Divisor – Pattern</u>                                                                                                                              |  |  |  |  |  |  |
|       | 001b                                                                                                                                                                                                                         | L/2 – 0101_0101_0101_0101_0101_0101b                                                                                                                  |  |  |  |  |  |  |
|       | 010b                                                                                                                                                                                                                         | L/4 - 0011_0011_0011_0011_0011b                                                                                                                       |  |  |  |  |  |  |
|       | 011b                                                                                                                                                                                                                         | L/6 - 0001_1100_0111_0001_1100_0111b                                                                                                                  |  |  |  |  |  |  |
|       | 100b                                                                                                                                                                                                                         | L/8 - 0000_1111_0000_1111_0000_1111b                                                                                                                  |  |  |  |  |  |  |
|       | 110b                                                                                                                                                                                                                         | L/24 - 0000_0000_0000_1111_1111_1111b                                                                                                                 |  |  |  |  |  |  |
|       | all others                                                                                                                                                                                                                   | reserved                                                                                                                                              |  |  |  |  |  |  |
| 9:3   | PatCnt: pa                                                                                                                                                                                                                   | attern buffer count. Read-write. Cold reset: 0. Selects the number of times to repeat                                                                 |  |  |  |  |  |  |
|       | the pattern                                                                                                                                                                                                                  | n selected by F4x1[9C, 94, 8C, 84]_x118, 0 to 127.                                                                                                    |  |  |  |  |  |  |
| 2:0   | <b>Order</b> . Read-write. Cold Reset: 0. Selects the order in which each pattern is sent.                                                                                                                                   |                                                                                                                                                       |  |  |  |  |  |  |
|       | Bits                                                                                                                                                                                                                         | <u>Order</u>                                                                                                                                          |  |  |  |  |  |  |
|       | 000b                                                                                                                                                                                                                         | Pattern Buffer, Modulo-N Counter, Constant Generator                                                                                                  |  |  |  |  |  |  |
|       | 001b                                                                                                                                                                                                                         | Pattern Buffer, Constant Generator, Modulo-N Counter                                                                                                  |  |  |  |  |  |  |
|       | 010b                                                                                                                                                                                                                         | Modulo-N Counter, Pattern Buffer, Constant Generator                                                                                                  |  |  |  |  |  |  |
|       | 011b                                                                                                                                                                                                                         | Modulo-N Counter, Constant Generator, Pattern Buffer                                                                                                  |  |  |  |  |  |  |
|       | 100b                                                                                                                                                                                                                         | Constant Generator, Pattern Buffer, Modulo-N Counter                                                                                                  |  |  |  |  |  |  |
|       | 101b                                                                                                                                                                                                                         | Constant Generator, Modulo-N Counter, Pattern Buffer                                                                                                  |  |  |  |  |  |  |
|       | 110, 111b                                                                                                                                                                                                                    | reserved                                                                                                                                              |  |  |  |  |  |  |

# F4x1[9C, 94, 8C, 84]\_x108 Link BIST Southbound TX Pattern Buffer 1 Register

| Bits Description | 5001 | See I Milys, 50, 60, 60, 101 register access information. |  |  |  |  |  |  |  |
|------------------|------|-----------------------------------------------------------|--|--|--|--|--|--|--|
|                  | Bits | Description                                               |  |  |  |  |  |  |  |

| 31:24 | Reserved.                                                                               |
|-------|-----------------------------------------------------------------------------------------|
| 23:0  | Pattern1[23:0]. Read-write. Cold Reset: 0. Holds the first 24 bits of Pattern Buffer 1. |

#### F4x1[9C, 94, 8C, 84]\_x10C Link BIST Southbound TX Mask Register

See F4x1[98, 90, 88, 80] for register access information.

| Bits | Desc | cription              |            |                                                                     |
|------|------|-----------------------|------------|---------------------------------------------------------------------|
| 31:9 | Rese | erved.                |            |                                                                     |
| 8:0  | TxN  | fask[8:0]. Read-write | . Cold     | Reset: 1FFh. Selects lanes of the sublinks to transmit a logical 0. |
|      | 1=L  | ane active. 0=Lane ma | asked.     |                                                                     |
|      | Bit  | <u>Lane</u>           | <u>Bit</u> | <u>Lane</u>                                                         |
|      | 0    | CAD0                  | 5          | CAD5                                                                |
|      | 1    | CAD1                  | 6          | CAD6                                                                |
|      | 2    | CAD2                  | 7          | CAD7                                                                |
|      | 3    | CAD3                  | 8          | CTL                                                                 |
|      | 4    | CAD4                  |            |                                                                     |

## F4x1[9C, 94, 8C, 84]\_x110 Link BIST Southbound TX Inversion Register

See F4x1[98, 90, 88, 80] for register access information.

|      | <u>,</u>   |                                                                                                          |            |                                                                    |  |  |  |  |
|------|------------|----------------------------------------------------------------------------------------------------------|------------|--------------------------------------------------------------------|--|--|--|--|
| Bits | Desc       | Description                                                                                              |            |                                                                    |  |  |  |  |
| 31:9 | Rese       | erved.                                                                                                   |            |                                                                    |  |  |  |  |
| 8:0  | TxI        | nv[8:0]. Read-write. (                                                                                   | Cold Re    | eset: 0. Selects lanes of the sublinks to invert. 1=Lane inverted. |  |  |  |  |
|      | 0=L        | ane unmodified.                                                                                          |            |                                                                    |  |  |  |  |
|      | <u>Bit</u> | <u>Lane</u>                                                                                              | <u>Bit</u> | <u>Lane</u>                                                        |  |  |  |  |
|      | 0          | O CADO 5 CAD5                                                                                            |            |                                                                    |  |  |  |  |
|      | 1          | 1 CAD1 6 CAD6                                                                                            |            |                                                                    |  |  |  |  |
|      | 2          | CAD2                                                                                                     | 7          | CAD7                                                               |  |  |  |  |
|      | 3          | 3 CAD3 8 CTL                                                                                             |            |                                                                    |  |  |  |  |
|      | 4          | 4 CAD4                                                                                                   |            |                                                                    |  |  |  |  |
|      | Whe        | When F4x1[9C, 94, 8C, 84]_x100[InvRotEn] is set, the bits corresponding to active lanes rotate to the    |            |                                                                    |  |  |  |  |
|      | left a     | left at the completion of each BIST loop: {NxtTxInv[8:0]}={TxInv[7:0],TxInv[8]}. Note: if the trans-     |            |                                                                    |  |  |  |  |
|      | mitte      | mitter and receiver are different widths, inversion rotation can only be used for 16/8-bit links and the |            |                                                                    |  |  |  |  |
|      | initi      | al pattern in the invers                                                                                 | ion reg    | gister must repeat on 9-bit boundaries.                            |  |  |  |  |

## F4x1[9C, 94, 8C, 84]\_x114 Link BIST Southbound TX Pattern Buffer 2 Register

See F4x1[98, 90, 88, 80] for register access information.

| Bits  | Description                                                                             |
|-------|-----------------------------------------------------------------------------------------|
| 31:24 | Reserved.                                                                               |
| 23:0  | Pattern2[23:0]. Read-write. Cold Reset: 0. Holds the first 24 bits of Pattern Buffer 2. |

#### F4x1[9C, 94, 8C, 84]\_x118 Link BIST Southbound TX Pattern Buffer 2 Enable Register

| Bits | Desc       | cription                |            |                                                                           |  |  |  |
|------|------------|-------------------------|------------|---------------------------------------------------------------------------|--|--|--|
| 31:9 | Rese       | Reserved.               |            |                                                                           |  |  |  |
| 8:0  |            |                         |            | Reset: 0. Selects lanes of the sublinks that use Pattern Buffer 2 instead |  |  |  |
|      | of Pa      | attern Buffer 1. 1=Buff | fer 2 s    | elected. 0=Buffer 1 selected.                                             |  |  |  |
|      | <u>Bit</u> | <u>Lane</u>             | <u>Bit</u> | <u>Lane</u>                                                               |  |  |  |
|      | 0          | CAD0                    | 5          | CAD5                                                                      |  |  |  |
|      | 1          | CAD1                    | 6          | CAD6                                                                      |  |  |  |
|      | 2          | CAD2                    | 7          | CAD7                                                                      |  |  |  |
|      | 3          | CAD3                    | 8          | CTL                                                                       |  |  |  |
|      | 4          | CAD4                    |            |                                                                           |  |  |  |

## F4x1[9C, 94, 8C, 84]\_x11C Link BIST Southbound TX Pattern Buffer Extension Register

See F4x1[98, 90, 88, 80] for register access information.

| Bits  | Description                                                                              |
|-------|------------------------------------------------------------------------------------------|
| 31:16 | Pattern2[39:24]. Read-write. Cold Reset: 0. Holds the upper 16 bits of Pattern Buffer 2. |
| 15:0  | Pattern1[39:24]. Read-write. Cold Reset: 0. Holds the upper 16 bits of Pattern Buffer 1. |

# F4x1[9C, 94, 8C, 84]\_x120 Link BIST Southbound TX Scramble Register

See F4x1[98, 90, 88, 80] for register access information.

| Bits | Desc                                        | Description                                                                                                                                                                |  |  |  |  |  |
|------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31:9 | Rese                                        | Reserved.                                                                                                                                                                  |  |  |  |  |  |
| 8:0  | enab<br><u>Bit</u><br>0<br>1<br>2<br>3<br>4 | TxScramble. Read-write. Cold Reset: 0. Selects lanes of the sublinks to scramble. 1=Scrambling enabled. 0=Scrambling disabled.BitLaneBitLane0CAD05CAD51CAD16CAD62CAD27CAD7 |  |  |  |  |  |

## F4x1[9C, 94, 8C, 84]\_x124 Link BIST Northbound RX Pattern Control Register

| Bits  | Description                                                                                                                                                                                                                  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved.                                                                                                                                                                                                                    |
| 25:21 | ConstCnt: constant generator count. Read-write. Cold reset: 0. Selects the number of times to repeat the constant selected by ConstSel, in multiples of 24 bits. 00000b: 0 (disabled) 00001b: 24 bits 11111b: 24*31=744 bits |

| 20    | <b>ConstSel: constant generator select</b> . Read-write. Cold reset: 0. Selects 0 or 1 to send for the time the constant generator is active.                        |                                                                                      |  |  |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|--|--|
| 19:13 | ModCnt: modulo-N count. Read-write. Cold reset: 0. Selects the number of times to repeat the Modulo-N counter (a counter with a period of N bits) pattern, 0 to 127. |                                                                                      |  |  |  |  |
| 12:10 | ModSel: n                                                                                                                                                            | nodulo-N select. Read-write. Cold reset: 0. Selects the pattern sent by the Modulo-N |  |  |  |  |
|       | counter:                                                                                                                                                             |                                                                                      |  |  |  |  |
|       | <u>Bits</u>                                                                                                                                                          | <u>Divisor – Pattern</u>                                                             |  |  |  |  |
|       | 001b                                                                                                                                                                 | L/2 – 0101_0101_0101_0101_0101b                                                      |  |  |  |  |
|       | 010b                                                                                                                                                                 | L/4 - 0011_0011_0011_0011_0011b                                                      |  |  |  |  |
|       | 011b                                                                                                                                                                 | L/6 - 0001_1100_0111_0001_1100_0111b                                                 |  |  |  |  |
|       | 100b                                                                                                                                                                 | L/8 - 0000_1111_0000_1111_0000_1111b                                                 |  |  |  |  |
|       | 110b                                                                                                                                                                 | L/24 - 0000_0000_0000_1111_1111_1111b                                                |  |  |  |  |
|       | all others                                                                                                                                                           | reserved                                                                             |  |  |  |  |
| 9:3   | PatCnt: pattern buffer count. Read-write. Cold reset: 0. Selects the number of times to repeat                                                                       |                                                                                      |  |  |  |  |
|       | the pattern                                                                                                                                                          | n selected by F4x1[9C, 94, 8C, 84]_x118, 0 to 127.                                   |  |  |  |  |
| 2:0   | <b>Order</b> . Read-write. Cold Reset: 0. Selects the order in which each pattern is sent.                                                                           |                                                                                      |  |  |  |  |
|       | Bits                                                                                                                                                                 | <u>Order</u>                                                                         |  |  |  |  |
|       | 000b                                                                                                                                                                 | Pattern Buffer, Modulo-N Counter, Constant Generator                                 |  |  |  |  |
|       | 001b                                                                                                                                                                 | Pattern Buffer, Constant Generator, Modulo-N Counter                                 |  |  |  |  |
|       | 010b                                                                                                                                                                 | Modulo-N Counter, Pattern Buffer, Constant Generator                                 |  |  |  |  |
|       | 011b                                                                                                                                                                 | Modulo-N Counter, Constant Generator, Pattern Buffer                                 |  |  |  |  |
|       | 100b                                                                                                                                                                 | Constant Generator, Pattern Buffer, Modulo-N Counter                                 |  |  |  |  |
|       | 101b                                                                                                                                                                 | Constant Generator, Modulo-N Counter, Pattern Buffer                                 |  |  |  |  |
|       | 110, 111b                                                                                                                                                            | reserved                                                                             |  |  |  |  |

# $F4x1[9C,94,8C,84]\_x128\ Link\ BIST\ Northbound\ RX\ Pattern\ Buffer\ 1\ Register$

See F4x1[98, 90, 88, 80] for register access information.

| Bits  | Description                                                                             |
|-------|-----------------------------------------------------------------------------------------|
| 31:24 | Reserved.                                                                               |
| 23:0  | Pattern1[23:0]. Read-write. Cold Reset: 0. Holds the first 24 bits of Pattern Buffer 1. |

# F4x1[9C, 94, 8C, 84]\_x12C Link BIST Northbound RX Mask Register

| Bits | Description |              |                                                                                                                                                                    |
|------|-------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved.   |              |                                                                                                                                                                    |
| 8:0  |             | ne active. 0 | Reset: 1FFh. Selects lanes of the selected sublink that are checked =Lane masked. Software is responsible for clearing bits 7:4 for 4-bit  Lane CAD5 CAD6 CAD7 CTL |

## F4x1[9C, 94, 8C, 84]\_x130 Link BIST Northbound RX Inversion Register

See F4x1[98, 90, 88, 80] for register access information.

| Bits | Description              |                                                                                                                                    |                                                                          |  |  |
|------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--|--|
| 31:9 | Reserved.                |                                                                                                                                    |                                                                          |  |  |
| 8:0  | inverted. 0=Lane uni     | <b>RxInv[8:0]</b> . Read-write. Cold Reset: 0. Selects lanes of the sublink that are inverted. 1=Lane inverted. 0=Lane unmodified. |                                                                          |  |  |
|      | Bit Lane<br>0 CAD0       | <u>Bit</u><br>5                                                                                                                    | <u>Lane</u><br>CAD5                                                      |  |  |
|      | 1 CAD1                   | 6                                                                                                                                  | CAD6                                                                     |  |  |
|      | 2 CAD2                   | 7                                                                                                                                  | CAD7                                                                     |  |  |
|      | 3 CAD3                   | 8                                                                                                                                  | CTL                                                                      |  |  |
|      | 4 CAD4                   |                                                                                                                                    |                                                                          |  |  |
|      | When F4x1[9C, 94, 8      | 8C, 84]_x100                                                                                                                       | O[InvRotEn] is set, the bits corresponding to active lanes rotate to the |  |  |
|      | left at the completion   | of each BIS                                                                                                                        | ST loop: {NxtTxInv[8:0]}={TxInv[7:0],TxInv[8]}. Note: if the trans-      |  |  |
|      | mitter and receiver a    | re different v                                                                                                                     | widths, inversion rotation can only be used for 16/8-bit links and the   |  |  |
|      | initial pattern in the i | inversion reg                                                                                                                      | gister must repeat on 9-bit boundaries.                                  |  |  |

## F4x1[9C, 94, 8C, 84]\_x134 Link BIST Northbound RX Pattern Buffer 2 Register

See F4x1[98, 90, 88, 80] for register access information.

| Bits  | Description                                                                             |
|-------|-----------------------------------------------------------------------------------------|
| 31:24 | Reserved.                                                                               |
| 23:0  | Pattern2[23:0]. Read-write. Cold Reset: 0. Holds the first 24 bits of Pattern Buffer 2. |

#### F4x1[9C, 94, 8C, 84]\_x138 Link BIST Northbound RX Pattern Buffer 2 Enable Register

See F4x1[98, 90, 88, 80] for register access information.

| Bits | Desc       | cription                      |            |                                                                          |
|------|------------|-------------------------------|------------|--------------------------------------------------------------------------|
| 31:9 | Rese       | erved.                        |            |                                                                          |
| 8:0  | Pat2       | <b>2En[8:0]</b> . Read-write. | Cold F     | Reset: 0. Selects lanes of the sublink that use Pattern Buffer 2 instead |
|      | of P       | attern Buffer 1. 1=Buf        | fer 2 s    | elected. 0=Buffer 1 selected.                                            |
|      | <b>Bit</b> | <u>Lane</u>                   | <u>Bit</u> | <u>Lane</u>                                                              |
|      | 0          | CAD0                          | 5          | CAD5                                                                     |
|      | 1          | CAD1                          | 6          | CAD6                                                                     |
|      | 2          | CAD2                          | 7          | CAD7                                                                     |
|      | 3          | CAD3                          | 8          | CTL                                                                      |
|      | 4          | CAD4                          |            |                                                                          |

## F4x1[9C, 94, 8C, 84]\_x13C Link BIST Northbound RX Pattern Buffer Extension Register

| Bits  | Description                                                                              |
|-------|------------------------------------------------------------------------------------------|
| 31:16 | Pattern2[39:24]. Read-write. Cold Reset: 0. Holds the upper 16 bits of Pattern Buffer 2. |
| 15:0  | Pattern1[39:24]. Read-write. Cold Reset: 0. Holds the upper 16 bits of Pattern Buffer 1. |

# F4x1[9C, 94, 8C, 84]\_x140 Link BIST Northbound RX Scramble Register

See F4x1[98, 90, 88, 80] for register access information.

| Bits | Description                                                        |                                    |                                                                                                  |
|------|--------------------------------------------------------------------|------------------------------------|--------------------------------------------------------------------------------------------------|
| 31:9 | Reserved.                                                          |                                    |                                                                                                  |
| 8:0  | enabled. 0=Scrambling  Bit Lane 0 CAD0 1 CAD1 2 CAD2 3 CAD3 4 CAD4 | disabled.  Bit 5 6 7 8 se bits hav | Lane CAD5 CAD6 CAD7 CTL  re no effect; scrambling is controlled for all receiver and transmitter |

## F4x1[9C, 94, 8C, 84]\_x144 Link BIST Northbound RX Error Status Register

See F4x1[98, 90, 88, 80] for register access information.

|      |             | ·      | • |                                                                                                                                                                       |
|------|-------------|--------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits | Description |        |   |                                                                                                                                                                       |
| 31:9 | Rese        | erved. |   |                                                                                                                                                                       |
| 8:0  |             | •      |   | ar (all bits of the field must be 0; if any of them are set, the write is Reset: 0. Indicates lanes of the selected sublink that had errors.  Lane CAD5 CAD6 CAD7 CTL |

## F4x1[9C, 94, 8C, 84]\_x[530A, 520A] DLL Control and Test Register 3

These registers are direct mapped registers, see F4x1[98, 90, 88, 80] for direct map register access information. The \_x520A register number specifies values for CAD[7:0], and CTL0; the \_x530A register number specifies values for CAD[15:8], and CTL1.

| Bits  | Description                                                                                                                                                                     |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | Ls2ExitTime: LS2 exit time. Read-write. Cold reset: 0. This field selects the internal timer that                                                                               |
|       | delays the turn-on of the DLL after exit from LS2 state to L0 state. The added delay allows the                                                                                 |
|       | forwarded input clock to achieve better stability.                                                                                                                              |
|       | Bits <u>Definition</u>                                                                                                                                                          |
|       | 000b Delay=10us.                                                                                                                                                                |
|       | 001b Delay=5us.                                                                                                                                                                 |
|       | 010b Delay=2.5us.                                                                                                                                                               |
|       | 011b Delay=1.25us.                                                                                                                                                              |
|       | 100b Delay=625ns.<br>101b Delay=0s.                                                                                                                                             |
|       | 110b,111b reserved.                                                                                                                                                             |
|       | Note: The value specified by Ls2ExitTime must be less than the value specified by F0x16C[T0Time],                                                                               |
|       | or it can cause undefined behavior.                                                                                                                                             |
| 28:18 | Reserved.                                                                                                                                                                       |
| 17    | DllLockFastModeEn: DLL lock fast mode enable. Read-write. Cold reset: 0. 1=Enables DLL lock                                                                                     |
| 17    | fast mode; this is the recommended BIOS setting for mobile platforms only. 0=DLL lock operates at standard speed; this is the recommended setting for all non-mobile platforms. |
| 16.15 | Reserved.                                                                                                                                                                       |
|       |                                                                                                                                                                                 |
| 14:13 | AnalogWaitTime: analog wait time to turn on DLL. Read-write. Cold reset: 0. This field is used                                                                                  |
|       | with DllAnalogOkIgnore; if DllAnalogOkIgnore is set, the turning on of DLL circuit after cold reset is delayed by a timer specified by this field, encoded as follows.          |
|       | Bits Definition                                                                                                                                                                 |
|       | 00b Delay=1.25us.                                                                                                                                                               |
|       | 01b Delay=0.625us.                                                                                                                                                              |
|       | 10b Delay=2.5us.                                                                                                                                                                |
|       | 11b Delay=0.3125us.                                                                                                                                                             |
|       | BIOS should program this field to 10b.                                                                                                                                          |
| 12:11 | Reserved.                                                                                                                                                                       |
| 10    | DllAnalogOkIgnore: DLL analog start signal ignore. Read-write. Cold reset: 0. 1=The delay of                                                                                    |
|       | turning on of DLL circuit after reset is controlled purely by a timer specified by AnalogWaitTime. See                                                                          |
|       | AnalogWaitTime for more information. 0=DLL is turned on after reset by a signal automatically                                                                                   |
|       | generated based on the status of internal supply voltage level. BIOS should set this bit to 1b.                                                                                 |
| 9:8   | Reserved.                                                                                                                                                                       |
| 7     | BiasDisInLs2: bias disable in LS2 power state. Read-write. Cold reset: 0. 1=Enables lower power                                                                                 |
|       | LS2 state; current consumption is lowered by approximately 2.5mA per receive lane when compared                                                                                 |
|       | to standard LS2 power mode. Setting this bit increases the amount of T0Time needed to relock the                                                                                |
|       | DLL.Note: When this bit is set, Ls2ExitTime must be programmed to select a value that is greater                                                                                |
|       | than or equal to AnalogWaitTime. 0=Standard LS2 power mode                                                                                                                      |
| 6:5   | Reserved.                                                                                                                                                                       |
| 4     | LockDetOnLs2Exit: DLL lock detect on LS2 exit. Read-write. Cold reset: 0. This field selects the                                                                                |
|       | LS2 to L0 power state transition speed. 1=Fast transition mode selected. 0=Slow transition mode                                                                                 |
|       | selected.                                                                                                                                                                       |

| 3:1 | Reserved.                                                                                                                                                                                                                |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | <b>EnCoreLoopFirst: enable DLL core loop first on LS2 exit</b> . Read-write. Cold reset: 0. This field selects LS2 to L0 power state transition speed. 1=Fast transition mode selected. 0=Slow transition mode selected. |

## F4x1[F0:E0] P-state Specification Registers

All fields are read-only. These registers specify the reset defaults for fields in [The P-State [4:0] Registers] MSRC001\_00[68:64]. F4x1E0 corresponds to MSRC001\_0064; F4x1E4 corresponds to MSRC001\_0065; etc.

| Bits  | Description                                                                        |
|-------|------------------------------------------------------------------------------------|
| 31:28 | Reserved.                                                                          |
| 27    | PstateEn. Default for [The P-State [4:0] Registers] MSRC001_00[68:64][PstateEn].   |
| 26:25 | IddDiv. Default for [The P-State [4:0] Registers] MSRC001_00[68:64][IddDiv].       |
| 24:17 | IddValue. Default for [The P-State [4:0] Registers] MSRC001_00[68:64][IddValue].   |
| 16    | <b>NbDid</b> . Default for [The P-State [4:0] Registers] MSRC001_00[68:64][NbDid]. |
| 15:9  | CpuVid. Default for [The P-State [4:0] Registers] MSRC001_00[68:64][CpuVid].       |
| 8:6   | CpuDid. Default for [The P-State [4:0] Registers] MSRC001_00[68:64][CpuDid].       |
| 5:0   | CpuFid. Default for [The P-State [4:0] Registers] MSRC001_00[68:64][CpuFid].       |

### 3.8 APIC Registers

See section 3.1 [Register Descriptions and Mnemonics] on page 135 for a description of the register naming convention.

#### **APIC20 APIC ID Register**

| Reset: | Reset: ??00 0000h.                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 31:24  | <b>ApicId</b> . Read-write. Reset: varies based on CPU core number and node number; see MSRC001_001F[InitApicIdCpuIdLo]. See section 2.9.5.1 [ApicId Enumeration Requirements] on page 109. When F0x68[ApicExtId and ApicExtBrdCst] = 11b, all 8 bits of this field are used; if either of these bits is low, then bits[3:0] of this field are used and bits[7:4] are reserved. See also section 2.9.2 [CPU Cores and Downcoring] on page 107. |  |
| 23:0   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |

#### **APIC30 APIC Version Register**

Reset: 80?? 0010h.

|   | Bits  | Description                                                                                                                                                 |
|---|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       | <b>ExtApicSpace: extended APIC register space present</b> . Read-only. This bit indicates the presence of extended APIC register space starting at APIC400. |
| Ī | 30:24 | Reserved.                                                                                                                                                   |

|      | <b>MaxLvtEntry</b> . Read-only. Reset state varies by product. This field specifies the number of entries in the local vector table minus one. |
|------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | Reserved.                                                                                                                                      |
| 7:0  | <b>Version</b> . Read-only. This field indicates the version number of this APIC implementation.                                               |

# **APIC80 Task Priority Register**

Reset: 0000 0000h.

| Bits | Description                                                                                                                        |
|------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved.                                                                                                                          |
| 7:0  | <b>Priority</b> . Read-write. This field is assigned by software to set a threshold priority at which the CPU core is interrupted. |

## **APIC90 Arbitration Priority Register**

Reset: 0000 0000h.

| Bits | Description                                                                                                                                                                                                                                                                |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved.                                                                                                                                                                                                                                                                  |
|      | <b>Priority</b> . Read-only. This field indicates the current priority for a pending interrupt, or a task or interrupt being serviced by the CPU core. The priority is used to arbitrate between CPU cores to determine which accepts a lowest-priority interrupt request. |

## **APICA0 Processor Priority Register**

Reset: 0000 0000h.

| Bits | Description                                                                                                                                                                                                                                                                             |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved.                                                                                                                                                                                                                                                                               |
|      | <b>Priority</b> . Read-only. This field indicates the CPU core's current priority servicing a task or interrupt, and is used to determine if any pending interrupts should be serviced. It is the higher value of the task priority value and the current highest in-service interrupt. |

## **APICB0 End of Interrupt Register**

This register is written by the software interrupt handler to indicate the servicing of the current interrupt is complete.

| Bits | Description                                        |
|------|----------------------------------------------------|
| 31:0 | Reserved. Write only. Reads return undefined data. |

## **APICCO Remote Read Register**

Reset: 0000 0000h.

| Bits | Description |
|------|-------------|

| 31:0 | <b>RemoteReadData</b> . Read-only. This field contains the data resulting from a valid completion of a |
|------|--------------------------------------------------------------------------------------------------------|
|      | remote read inter-processor interrupt.                                                                 |

#### **APICD0 Logical Destination Register**

Reset: 0000 0000h.

| Bits | Description                                                                                                                                                       |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <b>Destination</b> . Read-write. This field contains this APIC's destination identification. This field is used to determine which interrupts should be accepted. |
| 23:0 | Reserved.                                                                                                                                                         |

#### **APICE0 Destination Format Register**

Reset: FFFF FFFFh.

| Bits  | Description                                                                                                  |
|-------|--------------------------------------------------------------------------------------------------------------|
| 31:28 | <b>Format</b> . Read-write. This field controls which format to use when accepting interrupts with a logical |
|       | destination mode. The allowed values are:  • 0h = Cluster destinations are used.                             |
|       | • Fh = Flat destinations are used.                                                                           |
| 27:0  | Reserved.                                                                                                    |

## **APICF0 Spurious Interrupt Vector Register**

Reset: 0000 00FFh.

| Bits  | Description                                                                                                                                                                                                                                                                                                                         |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Reserved.                                                                                                                                                                                                                                                                                                                           |
| 9     | <b>FocusDisable</b> . Read-write. 1=Disable focus CPU core checking during lowest-priority arbitrated interrupts.                                                                                                                                                                                                                   |
| 8     | <b>APICSWEn: APIC software enable</b> . Read-write. 0=SMI, NMI, INIT, Startup, Remote Read, and LINT interrupts may be accepted; pending interrupts in APIC[170:100] and APIC[270:200] are held, but further fixed, lowest-priority, and ExtInt interrupts are not accepted. All LVT entry mask bits are set and cannot be cleared. |
| 7:0   | <b>Vector</b> . Read-write. This field contains the vector that is sent to the CPU core in the event of a spurious interrupt. The behavior of bits 3:0 are controlled as specified by [The Link Transaction Control Register] F0x68[ApicExtSpur].                                                                                   |

## APIC[170:100] In-Service Registers

Reset: 0000 0000h. The in-service registers provide a bit per interrupt to indicate that the corresponding interrupt is being serviced by the CPU core. APIC100[15:0] are reserved. Interrupts are mapped as follows:

| 1 0             | •                |
|-----------------|------------------|
| <u>Register</u> | Interrupt Number |
| APIC100         | 31-16            |
| APIC110         | 63-32            |
| APIC120         | 95-64            |
| APIC130         | 127-96           |

| 31116 F | Rev 3.00 - | September | 07, | 2007 |
|---------|------------|-----------|-----|------|
|---------|------------|-----------|-----|------|

APIC140 159-128 APIC150 191-160 APIC160 223-192 APIC170 255-224

| Bits | Description                                                                                                              |
|------|--------------------------------------------------------------------------------------------------------------------------|
|      | <b>InServiceBits</b> . Read-only. These bits are set when the corresponding interrupt is being serviced by the CPU core. |

#### APIC[1F0:180] Trigger Mode Registers

Reset: 0000 0000h. The trigger mode registers provide a bit per interrupt to indicate that the assertion mode of each interrupt. APIC180[15:0] are reserved. Interrupts are mapped as follows:

| <u>Register</u> | Interrupt Number |
|-----------------|------------------|
| APIC180         | 31-16            |
| APIC190         | 63-32            |
| APIC1A0         | 95-64            |
| APIC1B0         | 127-96           |
| APIC1C0         | 159-128          |
| APIC1D0         | 191-160          |
| APIC1E0         | 223-192          |
| APIC1F0         | 255-224          |

| Bits | Description                                                                                                                                                             |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <b>TriggerModeBits</b> . Read-only. The corresponding trigger mode bit is updated when an interrupt enters servicing. The values are:  • 0b = edge-triggered interrupt. |
|      | • 1b = level-triggered interrupt.                                                                                                                                       |

#### APIC[270:200] Interrupt Request Registers

Reset: 0000 0000h. The interrupt request registers provide a bit per interrupt to indicate that the corresponding interrupt has been accepted by the APIC. APIC200[15:0] are reserved. Interrupts are mapped as follows:

| Register | Interrupt Number |
|----------|------------------|
| APIC200  | 31-16            |
| APIC210  | 63-32            |
| APIC220  | 95-64            |
| APIC230  | 127-96           |
| APIC240  | 159-128          |
| APIC250  | 191-160          |
| APIC260  | 223-192          |
| APIC270  | 255-224          |
|          |                  |

| Bits | Description                                                                                                         |
|------|---------------------------------------------------------------------------------------------------------------------|
| 31:0 | <b>RequestBits</b> . Read-only. The corresponding request bit is set when the an interrupt is accepted by the APIC. |

#### **APIC280 Error Status Register**

Reset: 0000 0000h. Writes to this register trigger an update of the register state. The value written by software

is arbitrary. Each write causes the internal error state to be loaded into this register, clearing the internal error state. Consequently, a second write prior to the occurrence of another error causes the register to be overwritten with cleared data.

| Bits | Description                                                                                                                                                                                           |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved.                                                                                                                                                                                             |
| 7    | <b>IllegalRegAddr: illegal register address</b> . Read-write. This bit indicates that an access to a nonexistent register location within this APIC was attempted.                                    |
| 6    | <b>RcvdIllegalVector:</b> received illegal vector. Read-write. This bit indicates that this APIC has received a message with an illegal vector (00h to 0Fh for fixed and lowest priority interrupts). |
| 5    | <b>SentIllegalVector</b> . Read-write. This bit indicates that this APIC attempted to send a message with an illegal vector (00h to 0Fh for fixed and lowest priority interrupts).                    |
| 4    | Reserved.                                                                                                                                                                                             |
| 3    | <b>RcvAcceptError: receive accept error</b> . Read-write. This bit indicates that a message received by this APIC was not accepted by this or any other APIC.                                         |
| 2    | <b>SendAcceptError</b> . Read-write. This bit indicates that a message sent by this APIC was not accepted by any APIC.                                                                                |
| 1:0  | Reserved.                                                                                                                                                                                             |

## **APIC300 Interrupt Command Register Low**

Reset: 0000 0000h. Not all combinations of ICR fields are valid. Only the following combinations are valid:

**Table 62: Valid ICR field combinations** 

| Message Type          | Trigger Mode | Level  | <b>Destination Shorthand</b>       |
|-----------------------|--------------|--------|------------------------------------|
| Fixed                 | Edge         | X      | x                                  |
| rixed                 | Level        | Assert | x                                  |
| Lowest Priority, SMI, | Edge         | х      | Destination or all excluding self. |
| NMI, INIT             | Level        | Assert | Destination or all excluding self  |
| Startup               | х            | X      | Destination or all excluding self  |

Note: x indicates a don't care.

| Bits  | Description                                                                                                                                                                                  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | Reserved.                                                                                                                                                                                    |
| 19:18 | <b>DestShrthnd: destination shorthand</b> . Read-write. This field provides a quick way to specify a desti-                                                                                  |
|       | nation for a message. The valid encodings are as follows:                                                                                                                                    |
|       | • 00b = Destination field                                                                                                                                                                    |
|       | • $01b = Self$                                                                                                                                                                               |
|       | • 10b = All including self                                                                                                                                                                   |
|       | • 11b = All excluding self (Note that this sends a message with a destination encoding of all 1s, so if lowest priority is used the message could end up being reflected back to this APIC.) |
|       | If all including self or all excluding self is used, then destination mode is ignored and physical is automatically used.                                                                    |

|       | 1                                                                                                              |
|-------|----------------------------------------------------------------------------------------------------------------|
| 17:16 | <b>RemoteRdStat: remote read status</b> . Read-only. The encoding for this field is as follows:                |
|       | • 00b = Read was invalid                                                                                       |
|       | • 01b = Delivery pending                                                                                       |
|       | • 10b = Delivery done and access was valid                                                                     |
|       | • 11b = Reserved                                                                                               |
| 15    | TM: trigger mode. Read-write. This bit indicates how this interrupt is triggered. It is defined as fol-        |
|       | lows:                                                                                                          |
|       | • 0 = Edge triggered                                                                                           |
|       | • 1 = Level triggered                                                                                          |
| 14    | Level. Read-write. The values for this bit are as follows:                                                     |
|       | • 0 = Deasserted                                                                                               |
|       | • 1 = Asserted                                                                                                 |
| 13    | Reserved.                                                                                                      |
| 12    | <b>DlvryStat: delivery status</b> . Read-only. This bit is set to indicate that the interrupt has not yet been |
|       | accepted by the destination CPU core(s).                                                                       |
| 11    | <b>DM: destination mode</b> . Read-write. The values for this bit are as follows:                              |
|       | • 0 = Physical                                                                                                 |
|       | • 1 = Logical                                                                                                  |
| 10:8  | MsgType. Read-write. The message types are encoded as follows:                                                 |
|       | • 000b = Fixed                                                                                                 |
|       | • 001b = Lowest Priority                                                                                       |
|       | • 010b = SMI                                                                                                   |
|       | • 011b = Remote read                                                                                           |
|       | • 100b = NMI                                                                                                   |
|       | • 101b = INIT                                                                                                  |
|       | • 110b = Startup                                                                                               |
|       | • 111b = External interrupt                                                                                    |
| 7:0   | Vector. This field contains the vector that is sent for this interrupt source.                                 |

# **APIC310 Interrupt Command Register High**

Reset: 0000 0000h.

| Bits  | Description                                                                                                               |  |
|-------|---------------------------------------------------------------------------------------------------------------------------|--|
| 31:24 | <b>DestinationField</b> . Read-write. This field contains the destination encoding used when APIC300[DestShrthnd] is 00b. |  |
| 23:0  | Reserved.                                                                                                                 |  |

# **APIC320 Timer Local Vector Table Entry**

Reset: 0001 0000h.

| Bits  | Description                                                                                                               |
|-------|---------------------------------------------------------------------------------------------------------------------------|
| 31:18 | Reserved.                                                                                                                 |
|       | <ul> <li>Mode. Read-write. The values for this bit are as follows:</li> <li>0 = One-shot</li> <li>1 = Periodic</li> </ul> |

| 16    | Mask. Read-write. If this bit is set, this local vector table entry does not generate interrupts.                                                            |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15:13 | Reserved.                                                                                                                                                    |  |
|       | <b>DlvryStat: delivery status</b> . Read-only. This bit is set to indicate that the interrupt has not yet been accepted by the CPU core.                     |  |
| 11    | Reserved.                                                                                                                                                    |  |
| 10:8  | <b>MsgType: message type</b> . Write only. Read always returns 000b. See 2.14.1.10 [Generalized Local Vector Table] on page 124 for supported message types. |  |
| 7:0   | <b>Vector</b> . Read-write. This field contains the vector that is sent for this interrupt source.                                                           |  |

## **APIC330 Thermal Local Vector Table Entry**

Reset: 0001 0000h. Interrupts for this local vector table are caused by transitions in and out of an STC thermal zone as described in 2.10.3.2 [Software Thermal Control (STC)] on page 111, changes in [The P-State Current Limit Register] MSRC001\_0061[CurPstateLimit] due to HTC, or STC.

| Bits  | Description                                                                                                                              |
|-------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved.                                                                                                                                |
| 16    | Mask. Read-write. If this bit is set, this local vector table entry does not generate interrupts.                                        |
| 15:13 | Reserved.                                                                                                                                |
| 12    | <b>DlvryStat: delivery status</b> . Read-only. This bit is set to indicate that the interrupt has not yet been accepted by the CPU core. |
| 11    | Reserved.                                                                                                                                |
| 10:8  | <b>MsgType: message type</b> . Read-write. See 2.14.1.10 [Generalized Local Vector Table] on page 124 for supported message types.       |
| 7:0   | <b>Vector</b> . Read-write. This field contains the vector that is sent for this interrupt source.                                       |

## **APIC340 Performance Counter Vector Table Entry**

Reset: 0001 0000h. Interrupts for this local vector table are caused by overflows of [The Performance Event Counter Registers (PERF\_CTR[3:0])] MSRC001\_00[07:04].

| Bits  | Description                                                                                                                              |
|-------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | Reserved.                                                                                                                                |
| 16    | Mask. Read-write. If this bit is set, this local vector table entry does not generate interrupts.                                        |
| 15:13 | Reserved.                                                                                                                                |
| 12    | <b>DlvryStat: delivery status</b> . Read-only. This bit is set to indicate that the interrupt has not yet been accepted by the CPU core. |
| 11    | Reserved.                                                                                                                                |
| 10:8  | <b>MsgType: message type</b> . Read-write. See 2.14.1.10 [Generalized Local Vector Table] on page 124 for supported message types.       |
| 7:0   | <b>Vector</b> . Read-write. This field contains the vector that is sent for this interrupt source.                                       |

## APIC350 Local Interrupt 0 (Legacy INTR) Local Vector Table Entry

Reset: 0001 0000h.

| Bits  | Description                                                                                                                                                                              |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:17 | Reserved.                                                                                                                                                                                |  |
| 16    | Mask. Read-write. If this bit is set, this local vector table entry does not generate interrupts.                                                                                        |  |
| 15    | <ul> <li>TM: trigger mode. Read-write. This bit indicates how this interrupt is triggered. It is defined as follows:</li> <li>0 = Edge triggered</li> <li>1 = Level triggered</li> </ul> |  |
| 14    | <b>RmtIRR</b> . Read-only. If trigger mode is level, remote IRR is set when the interrupt has begun service. Remote IRR is cleared when the end of interrupt has occurred.               |  |
| 13    | <b>PinPol: pin polarity</b> . Read-write. This bit is not used because LINT interrupts are delivered by HyperTransport <sup>TM</sup> messages instead of individual pins.                |  |
| 12    | <b>DlvryStat: delivery status</b> . Read-only. This bit is set to indicate that the interrupt has not yet been accepted by the CPU core.                                                 |  |
| 11    | Reserved.                                                                                                                                                                                |  |
| 10:8  | <b>MsgType: message type</b> . Read-write. See 2.14.1.10 [Generalized Local Vector Table] on page 124 for supported message types.                                                       |  |
| 7:0   | <b>Vector</b> . Read-write. This field contains the vector that is sent for this interrupt source.                                                                                       |  |

# APIC360 Local Interrupt 1(Legacy NMI) Local Vector Table Entry

Reset: 0001 0000h.

| Bits | Description  |
|------|--------------|
| 31:0 | See APIC350. |

# **APIC370 Error Local Vector Table Entry**

Reset: 0001 0000h.

| Bits  | Description                                                                                                                                                |  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:17 | Reserved.                                                                                                                                                  |  |
| 16    | Mask. Read-write. If this bit is set, this local vector table entry does not generate interrupts.                                                          |  |
| 15:13 | Reserved.                                                                                                                                                  |  |
| 12    | <b>DlvryStat: delivery status</b> . Read only. This bit is set to indicate that the interrupt has not yet been accepted by the CPU core.                   |  |
| 11    | Reserved.                                                                                                                                                  |  |
| 10:8  | <b>MsgType: message type</b> . Write only. Read always returns 0h. See 2.14.1.10 [Generalized Local Vector Table] on page 124 for supported message types. |  |
| 7:0   | <b>Vector</b> . Read-write. This field contains the vector that is sent for this interrupt source.                                                         |  |

# **APIC380 Timer Initial Count Register**

Reset: 0000 0000h.

| Bits Description |
|------------------|
|------------------|

31:0 **Count**. Read-write. This field contains the value copied into the current count register when the timer is loaded or reloaded.

# **APIC390 Timer Current Count Register**

Reset: 0000 0000h.

| Bits | Description                                                             |
|------|-------------------------------------------------------------------------|
| 31:0 | Count. Read only. This field contains the current value of the counter. |

## **APIC3E0 Timer Divide Configuration Register**

Reset: 0000 0000h. The Div bits are encoded as follows:

| Div[3] | Div[1:0] | Resulting Timer Divide |
|--------|----------|------------------------|
| 0      | 00b      | 2                      |
| 0      | 01b      | 4                      |
| 0      | 10b      | 8                      |
| 0      | 11b      | 16                     |
| 1      | 00b      | 32                     |
| 1      | 01b      | 64                     |
| 1      | 10b      | 128                    |
| 1      | 11b      | 1                      |

| Bits | Description           |
|------|-----------------------|
| 31:4 | Reserved.             |
| 3    | Div[3]. Read-write.   |
| 2    | Reserved.             |
| 1:0  | Div[1:0]. Read-write. |

## **APIC400 Extended APIC Feature Register**

| Bits  | Description                                                                                                                                                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Reserved.                                                                                                                                                                                                                                     |
| 23:16 | <b>ExtLvtCount: extended local vector table count</b> . Read-only, 04h. This specifies the number of extended LVT registers in the local APIC. These registers are [The Extended Interrupt [3:0] Local Vector Table Registers] APIC[530:500]. |
| 15:3  | Reserved.                                                                                                                                                                                                                                     |
| 2     | <b>ExtApicIdCap: extended APIC ID capable</b> . Read-only, 1. Indicates that the processor is capable of supporting an 8-bit APIC ID, controlled by APIC410[ExtApicIdEn].                                                                     |

| 1 | <b>SeioCap: specific end of interrupt capable</b> . Read-only, 1. This bit indicates that the [The Specific |
|---|-------------------------------------------------------------------------------------------------------------|
|   | End Of Interrupt Register] APIC420 is present.                                                              |
| 0 | <b>IerCap:</b> interrupt enable register capable. Read-only, 1. This bit indicates that the [The Interrupt  |
|   | Enable Registers] APIC[4F0:480] are present. See 2.14.1.5 [Interrupt Masking] on page 122.                  |

# APIC410 Extended APIC Control Register

Reset: 0000 0000h

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2    | <b>ExtApicIdEn:</b> extended APIC ID enable. Read-write. 1=Enable 8-bit APIC ID; APIC20[ApicId] supports an 8-bit value; an interrupt broadcast in physical destination mode requires that the IntDest[7:0]=1111_1111 (instead of xxxx_1111); a match in physical destination mode occurs when (IntDest[7:0] == ApicId[7:0]) instead of (IntDest[3:0] == ApicId[3:0]). Extended APIC ID can also be enabled by writing F0x68[ApicExtId] and F0x68[ApicExtBrdCst]. |
| 1    | <b>SeoiEn</b> . Read-write. This bit enables SEOI generation when a write to the specific end of interrupt register is received.                                                                                                                                                                                                                                                                                                                                  |
| 0    | IerEn. Read-write. This bit enables writes to the interrupt enable registers.                                                                                                                                                                                                                                                                                                                                                                                     |

# APIC420 Specific End Of Interrupt Register

Reset: 0000 0000h

| Bits | Description                                                                                               |  |
|------|-----------------------------------------------------------------------------------------------------------|--|
| 31:8 | Reserved.                                                                                                 |  |
|      | EoiVec: end of interrupt vector. Read-write. A write to this field causes an end of interrupt cycle to    |  |
|      | be performed for the vector specified in this field. The behavior is undefined if no interrupt is pending |  |
|      | for the specified interrupt vector.                                                                       |  |

# APIC[4F0:480] Interrupt Enable Registers

Reset: FFFF FFFFh

| Bits | Description                                                                                      |                                                      |  |  |
|------|--------------------------------------------------------------------------------------------------|------------------------------------------------------|--|--|
| 31:0 | InterruptEnableBits. Read-write. The interrupt enable bits can be used to enable each of the 256 |                                                      |  |  |
|      | interrupts. In                                                                                   | interrupts. Interrupt enables are mapped as follows: |  |  |
|      | Register                                                                                         | Interrupt Number                                     |  |  |
|      | APIC480                                                                                          | 31-0                                                 |  |  |
|      | APIC490                                                                                          | 63-32                                                |  |  |
|      | APIC4A0                                                                                          | 95-64                                                |  |  |
|      | APIC4B0                                                                                          | 127-96                                               |  |  |
|      | APIC4C0                                                                                          | 159-128                                              |  |  |
|      | APIC4D0                                                                                          | 191-160                                              |  |  |
|      | APIC4E0                                                                                          | 223-192                                              |  |  |
|      | APIC4F0                                                                                          | 255-224                                              |  |  |

#### APIC[530:500] Extended Interrupt [3:0] Local Vector Table Registers

Reset: 0000 0000h. These registers provide additional local vector table entries for selected internal interrupt sources, including those found in: F3x1[78, 70, 68, 60] and F3xB0.

| Bits  | Description                                                                                                                                                                                  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:17 | Reserved.                                                                                                                                                                                    |  |
| 16    | Mask. Read-write. 1=This LVT entry does not generate interrupts.                                                                                                                             |  |
| 15:13 | Reserved.                                                                                                                                                                                    |  |
| 12    | <b>DlvryStat: delivery status</b> . Read-only. 1=The interrupt has not yet been accepted by the CPU.                                                                                         |  |
| 11    | Reserved.                                                                                                                                                                                    |  |
| 10:8  | <b>MsgType: message type</b> . Read-write. Specifies the interrupt type generated by this LVT entry. See 2.14.1.10 [Generalized Local Vector Table] on page 124 for supported message types. |  |
| 7:0   | <b>Vector</b> . Read-write. This field contains the vector generated by this LVT entry.                                                                                                      |  |

#### 3.9 CPUID Instruction Registers

Processor feature capabilities and configuration information are provided through the CPUID instruction. Different information is accessed by (1) setting EAX as an index to the registers to be read, (2) executing the CPUID instruction, and (3) reading the results in EAX, EBX, ECX, and EDX. The phrase *CPUID function X* or *CPUID FnX* refers to the CPUID instruction when EAX is preloaded with X. Undefined function numbers return 0's in all 4 registers. See section 2.16 [CPUID Instruction] on page 133 also.

The following provides AMD family 10h processor specific details about CPUID. See the *CPUID Specification* for further information. Unless otherwise specified, single-bit feature fields are encoded as 1=Feature is supported by the processor; 0=Feature is not supported by the processor.

#### CPUID Fn[8000 0000, 0000 0000] AMD Authentic Identifier

| Register            | Bits | Description                                                                                                                                                                                                                                                                                                                                     |
|---------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EAX                 |      | LFuncStd: largest standard function. Function 0000_0000h returns the largest CPUID standard-function input value supported by the processor implementation: 0000_0005h. LFuncExt: largest extended function. Function 8000_0000h returns the largest CPUID extended-function input value supported by the processor implementation: 8000_001Ah. |
| EBX,<br>ECX,<br>EDX | 31:0 | <b>Vendor: vendor</b> . The 12 8-bit ASCII character codes to create the string "AuthenticAMD". EBX=6874_7541h "h t u A", ECX=444D_4163h "D M A c", EDX=6974_6E65h "i t n e".                                                                                                                                                                   |

#### CPUID Fn[8000\_0001, 0000\_0001]\_EAX Family, Model, Stepping Identifiers

This register provides identical information to F3xFC.

**Family** is an 8-bit value and is defined as: **Family[7:0]** = ({0000b,BaseFamily[3:0]} + ExtendedFamily[7:0]). E.g. If BaseFamily[3:0]=Fh and ExtendedFamily[7:0]=01h, then Family[7:0]=10h. This document applies only to family 10h processors.

**Model** is an 8-bit value and is defined as: **Model[7:0]** = {ExtendedModel[3:0], BaseModel[3:0]}. E.g. If

ExtendedModel[3:0]=Eh and BaseModel[3:0]=8h, then Model[7:0] = E8h. Model numbers vary with product.

| Bits  | Description                                                   |
|-------|---------------------------------------------------------------|
| 31:28 | Reserved.                                                     |
| 27:20 | ExtendedFamily: 01h.                                          |
| 19:16 | ExtendedModel.                                                |
| 15:12 | Reserved.                                                     |
| 11:8  | BaseFamily: Fh.                                               |
| 7:4   | BaseModel.                                                    |
| 3:0   | Stepping: processor stepping (revision) for a specific model. |

## CPUID Fn0000\_0001\_EBX LocalApicId, LogicalProcessorCount, CLFlush, 8BitBrandId

| Bits  | Description                                                                                                                                                                                                                                                                       |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | <b>LocalApicId</b> : initial local APIC physical ID. Provides the initial APIC20[ApicId] value. After F0x60[NodeId] as been initialized, changes to APIC20[ApicId] do not effect the value of this CPUID register. See also section 2.9.2 [CPU Cores and Downcoring] on page 107. |
| 23:16 | <b>LogicalProcessorCount</b> : If CPUID Fn[8000_0001, 0000_0001]_EDX[HTT] = 1, then this field indicates the number of CPU cores in the processor as CPUID Fn8000_0008[NC] + 1. Otherwise, this field is reserved.                                                                |
| 15:8  | <b>CLFlush</b> : CLFLUSH size in quadwords = 08h.                                                                                                                                                                                                                                 |
| 7:0   | <b>8BitBrandId</b> : 8 bit brand ID = 00h. Indicates that the brand ID is in CPUID Fn8000_0001_EBX.                                                                                                                                                                               |

## CPUID Fn8000\_0001\_EBX BrandId Identifier

| Bits  | Description                                                                                                      |                                                                                                    |
|-------|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|
| 31:28 | PkgType: package type. Specifies the p<br>0000b: Fr2(1207) or Fr4(1207).<br>0010b: Reserved.<br>01xxb: Reserved. | processor package type. This field is encoded as follows: 0001b: AM2r2. 0011b: G3. 1xxxb: Reserved |
| 27:16 | Reserved.                                                                                                        |                                                                                                    |
| 15:0  | <b>BrandId</b> : brand ID. This is identical to                                                                  | F3x1F0[BrandId].                                                                                   |

## **CPUID Fn0000\_0001\_ECX Feature Identifiers**

| Bits  | Description                             |
|-------|-----------------------------------------|
| 31:24 | Reserved.                               |
| 23    | <b>POPCNT</b> : POPCNT instruction = 1. |
| 22:14 | Reserved.                               |
| 13    | CMPXCHG16B: CMPXCHG16B instruction = 1. |
| 12:4  | Reserved.                               |

| Bits | Description                                                                                                                                           |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <b>Monitor</b> : Monitor/Mwait instructions = 1. This can be disabled through [The Hardware Configuration Register (HWCR)] MSRC001_0015[MonMwaitDis]. |
| 2:1  | Reserved.                                                                                                                                             |
| 0    | SSE3: SSE3 extensions = 1; may be overridden by MSRC001_0015[SseDis].                                                                                 |

# CPUID Fn8000\_0001\_ECX Feature Identifiers

| Bits  | Description                                                                                                                                                                             |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | Reserved.                                                                                                                                                                               |
| 10    | IBS: Instruction Based Sampling = 1.                                                                                                                                                    |
| 9     | <b>OSVW</b> : OS Visible Work-around support = 1.                                                                                                                                       |
| 8     | <b>3DNowPrefetch</b> : Prefetch and PrefetchW instructions = 1.                                                                                                                         |
| 7     | <b>MisAlignSse</b> : Misaligned SSE Mode = (setting varies by product); may be overridden by MSRC001_0015[MisAlignSseDis].                                                              |
| 6     | <b>SSE4A</b> : EXTRQ, INSERTQ, MOVNTSS, and MOVNTSD instruction support = 1; may be overridden by MSRC001_0015[SseDis].                                                                 |
| 5     | ABM: advanced bit manipulation. LZCNT instruction support (setting varies by product).                                                                                                  |
| 4     | AltMovCr8: LOCK MOV CR0 means MOV CR8 = 1.                                                                                                                                              |
| 3     | ExtApicSpace: extended APIC register space = 1.                                                                                                                                         |
| 2     | SVM: Secure Virtual Mode feature (setting varies by product).                                                                                                                           |
| 1     | CmpLegacy: core multi-processing legacy mode (setting varies by product). 1=Multi CPU core product (CPUID Fn8000_0008[NC] != 0). 0=Single CPU core product (CPUID Fn8000_0008[NC] = 0). |
| 0     | LahfSahf: LAHF/SAHF instructions =1.                                                                                                                                                    |

# $CPUID\ Fn[8000\_0001,0000\_0001]\_EDX\ \ Feature\ Identifiers$

| The value returned | l in EDX ma | y be identical or different | for Fn0000 0001 an | d Fn8000 0001, as indicated. |
|--------------------|-------------|-----------------------------|--------------------|------------------------------|
|                    |             |                             |                    |                              |

| Bits | Function   | Description                                                                                                                                                                                                                                                        |  |  |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31   | 0000_0001h | Reserved.                                                                                                                                                                                                                                                          |  |  |
|      | 8000_0001h | <b>3DNow</b> : 3DNow! <sup>TM</sup> instructions = 1.                                                                                                                                                                                                              |  |  |
| 30   | 0000_0001h | Reserved.                                                                                                                                                                                                                                                          |  |  |
| 30   | 8000_0001h | <b>3DNowExt</b> : AMD extensions to 3DNow! <sup>TM</sup> instructions = 1.                                                                                                                                                                                         |  |  |
| 29   | 0000_0001h | Reserved.                                                                                                                                                                                                                                                          |  |  |
| 29   | 8000_0001h | LM: long mode (may vary by product).                                                                                                                                                                                                                               |  |  |
| 28   | 0000_0001h | <b>HTT</b> : hyper-threading technology (setting varies by product). This bit qualifies the meaning of CPUID Fn0000_0001_EBX[LogicalProcessorCount]. 1=Multi CPU core product (CPUID Fn8000_0008[NC] != 0). 0=Single CPU core product (CPUID Fn8000_0008[NC] = 0). |  |  |
|      | 8000_0001h | Reserved.                                                                                                                                                                                                                                                          |  |  |

| Bits | Function   | Description                                                                                                                                                                     |  |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 27   | 0000_0001h | Reserved.                                                                                                                                                                       |  |
| 27   | 8000_0001h | <b>RDTSCP</b> : RDTSCP instruction = 1.                                                                                                                                         |  |
| 26   | 0000_0001h | SSE2: SSE2 extensions = 1; may be overridden by MSRC001_0015[SseDis].                                                                                                           |  |
|      | 8000_0001h | Page1GB: 1 GB large page support = 1.                                                                                                                                           |  |
| 25   | 0000_0001h | SSE: SSE extensions = 1; may be overridden by MSRC001_0015[SseDis].                                                                                                             |  |
| 23   | 8000_0001h | <b>FFXSR</b> : FXSAVE and FXRSTOR instruction optimizations = 1.                                                                                                                |  |
| 24   | both       | <b>FXSR</b> : FXSAVE and FXRSTOR instructions = 1.                                                                                                                              |  |
| 23   | both       | MMX: MMX <sup>TM</sup> instructions = 1.                                                                                                                                        |  |
| 22   | 0000_0001h | Reserved.                                                                                                                                                                       |  |
| 22   | 8000_0001h | <b>MmxExt</b> : AMD extensions to MMX <sup>TM</sup> instructions = 1.                                                                                                           |  |
| 21   | Both       | Reserved.                                                                                                                                                                       |  |
| 20   | 0000_0001h | Reserved.                                                                                                                                                                       |  |
| 20   | 8000_0001h | <b>NX</b> : no-execute page protection = 1.                                                                                                                                     |  |
| 10   | 0000_0001h | CLFSH: CLFLUSH instruction = 1.                                                                                                                                                 |  |
| 19   | 8000_0001h | Reserved.                                                                                                                                                                       |  |
| 18   | Both       | Reserved.                                                                                                                                                                       |  |
| 17   | both       | <b>PSE36</b> : page-size extensions = 1.                                                                                                                                        |  |
| 16   | both       | <b>PAT</b> : page attribute table = 1.                                                                                                                                          |  |
| 15   | both       | <b>CMOV</b> : conditional move instructions, CMOV, FCOMI, FCMOV = 1.                                                                                                            |  |
| 14   | both       | MCA: machine check architecture, MCG_CAP = 1.                                                                                                                                   |  |
| 13   | both       | <b>PGE</b> : page global extension, CR4.PGE = 1.                                                                                                                                |  |
| 12   | both       | MTRR: memory-type range registers = 1.                                                                                                                                          |  |
| 11   | 0000_0001h | SysEnterSysExit: SYSENTER and SYSEXIT instructions = 1.                                                                                                                         |  |
| 11   | 8000_0001h | SysCallSysRet: SYSCALL and SYSRET instructions = 1.                                                                                                                             |  |
| 10   | both       | Reserved.                                                                                                                                                                       |  |
| 9    | both       | APIC: advanced programmable interrupt controller (APIC) exists and is enabled. This bit reflects the state of [The APIC Base Address Register (APIC_BAR)] MSR0000_001B[ApicEn]. |  |
| 8    | both       | CMPXCHG8B: CMPXCHG8B instruction = 1.                                                                                                                                           |  |
| 7    | both       | MCE: machine check exception, CR4.MCE = 1.                                                                                                                                      |  |
| 6    | both       | <b>PAE</b> : physical-address extensions (PAE) = 1.                                                                                                                             |  |
| 5    | both       | <b>MSR</b> : AMD model-specific registers (MSRs), with RDMSR and WRMSR instructions = 1.                                                                                        |  |
| 4    | both       | <b>TSC</b> : time stamp counter, RDTSC/RDTSCP instructions, CR4.TSD = 1.                                                                                                        |  |
| 3    | both       | <b>PSE</b> : page-size extensions (4 MB pages) = 1.                                                                                                                             |  |
| 2    | both       | <b>DE</b> : debugging extensions, IO breakpoints, CR4.DE = 1.                                                                                                                   |  |
| 1    | both       | $\mathbf{VME}$ : virtual-mode enhancements = 1.                                                                                                                                 |  |
| 0    | both       | <b>FPU</b> : x87 floating point unit on-chip = 1.                                                                                                                               |  |

#### CPUID Fn0000\_000[4, 3, 2] Reserved.

#### CPUID Fn8000\_000[4, 3, 2] Processor Name String Identifier

These return the ASCII string corresponding to the processor name, stored in [The Processor Name String Registers] MSRC001\_00[35:30]. The MSRs are mapped to these registers as follows:

```
Function 8000_0002: {EDX, ECX, EBX, EAX} == {MSRC001_0031, MSRC001_0030}; Function 8000_0003: {EDX, ECX, EBX, EAX} == {MSRC001_0033, MSRC001_0032}; Function 8000_0004: {EDX, ECX, EBX, EAX} == {MSRC001_0035, MSRC001_0034};
```

#### CPUID Fn0000 0005 Monitor/MWait

| Register | Bits  | Description                                         |
|----------|-------|-----------------------------------------------------|
| EAX      | 31:16 | Reserved.                                           |
| EAX      | 15:0  | Smallest monitor-line size in bytes = 40h.          |
| EBX      | 31:16 | Reserved.                                           |
| EBX      | 15:0  | Largest monitor-line size in bytes = 40h.           |
| ECX      | 31:2  | Reserved.                                           |
| ECX      | 1     | <b>IBE</b> : Interrupt break-event = 1.             |
| ECX      | 0     | <b>EMX:</b> Enumerate MONITOR/MWAIT extensions = 1. |
| EDX      | 31:0  | Reserved.                                           |

#### CPUID Fn8000 0005 TLB and L1 Cache Identifiers

This provides the processor's first level cache and TLB characteristics for each CPU core. The *associativity* fields returned are encoded as follows:

00h Reserved.

01h Direct mapped.

02h - FEh Specifies the associativity; e.g., 04h would indicate a 4-way associativity.

FFh Fully associative.

| Register | Bits  | Description                                                                                                                                                                                                                                                                      |
|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EAX      | 31:24 | Data TLB associativity for 2 MB and 4 MB pages = FFh.                                                                                                                                                                                                                            |
| EAX      | 23:16 | Data TLB number of entries for 2 MB and 4 MB pages = 48. The value returned is for the number of entries available for the 2 MB page size; 4 MB pages require two 2 MB entries, so the number of entries available for the 4 MB page size is one-half the returned value.        |
| EAX      | 15:8  | Instruction TLB associativity for 2 MB and 4 MB pages = FFh.                                                                                                                                                                                                                     |
| EAX      | 7:0   | Instruction TLB number of entries for 2 MB and 4 MB pages = 16. The value returned is for the number of entries available for the 2 MB page size; 4 MB pages require two 2 MB entries, so the number of entries available for the 4 MB page size is one-half the returned value. |
| EBX      | 31:24 | Data TLB associativity for 4 KB pages = FFh.                                                                                                                                                                                                                                     |
| EBX      | 23:16 | Data TLB number of entries for 4 KB pages = 48.                                                                                                                                                                                                                                  |
| EBX      | 15:8  | Instruction TLB associativity for 4 KB pages = FFh.                                                                                                                                                                                                                              |
| EBX      | 7:0   | Instruction TLB number of entries for 4 KB pages = 32.                                                                                                                                                                                                                           |

| Register | Bits  | Description                                   |
|----------|-------|-----------------------------------------------|
| ECX      | 31:24 | L1 data cache size in KB = 64.                |
| ECX      | 23:16 | L1 data cache associativity = 2.              |
| ECX      | 15:8  | L1 data cache lines per tag = $1$ .           |
| ECX      | 7:0   | L1 data cache line size in bytes = 64.        |
| EDX      | 31:24 | L1 instruction cache size KB = 64.            |
| EDX      | 23:16 | L1 instruction cache associativity = 2.       |
| EDX      | 15:8  | L1 instruction cache lines per tag = $1$ .    |
| EDX      | 7:0   | L1 instruction cache line size in bytes = 64. |

#### CPUID Fn8000\_0006 L2/L3 Cache and L2 TLB Identifiers

This provides the processor's second level cache and TLB characteristics for each CPU core and the processor's third level cache characteristics shared by all CPU cores.

The presence of a unified L2 TLB is indicated by a value of 0000h in the upper 16 bits of the EAX and EBX registers. The unified L2 TLB information is contained in the lower 16 bits of these registers.

The associativity fields are encoded as follows:

0h: The L2 cache or TLB is disabled.Ah: 32-way associative.1h: Direct mapped.Bh: 48-way associative.2h: 2-way associative.Ch: 64-way associative.4h: 4-way associative.Dh: 96-way associative.6h: 8-way associative.Eh: 128-way associative.8h: 16-way associative.Fh: Fully associative.

All other encodings are reserved.

| Register | Bits  | Description                                                                                                                                                                                                                                                                                             |
|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EAX      | 31:28 | <b>L2DTlb2and4MAssoc</b> . L2 data TLB associativity for 2 MB and 4 MB pages = 2.                                                                                                                                                                                                                       |
| EAX      | 27:16 | <b>L2DTlb2and4MSize</b> . L2 data TLB number of entries for 2 MB and 4 MB pages = 128. The value returned is for the number of entries available for the 2 MB page size; 4 MB pages require two 2 MB entries, so the number of entries available for the 4 MB page size is one-half the returned value. |
| EAX      | 15:12 | <b>L2ITlb2and4MAssoc</b> . L2 instruction TLB associativity for 2 MB and 4 MB pages = 0.                                                                                                                                                                                                                |
| EAX      | 11:0  | <b>L2ITlb2and4MSize</b> . L2 instruction TLB number of entries for 2 MB and 4 MB pages = 0.                                                                                                                                                                                                             |
| EBX      | 31:28 | L2DTlb4KAssoc. L2 data TLB associativity for 4 KB pages = 4.                                                                                                                                                                                                                                            |
| EBX      | 27:16 | <b>L2DTlb4KSize</b> . L2 data TLB number of entries for 4 KB pages = 512.                                                                                                                                                                                                                               |
| EBX      | 15:12 | <b>L2ITlb4KAssoc</b> . L2 instruction TLB associativity for 4 KB pages = 4.                                                                                                                                                                                                                             |
| EBX      | 11:0  | <b>L2ITlb4KSize</b> . L2 instruction TLB number of entries for 4 KB pages = 512.                                                                                                                                                                                                                        |
| ECX      | 31:16 | L2Size. L2 cache size in KB (varies with product). May be one of 128, 256, 512, or 1024.                                                                                                                                                                                                                |
| ECX      | 15:12 | <b>L2Assoc</b> . L2 cache associativity = 8.                                                                                                                                                                                                                                                            |
| ECX      | 11:8  | <b>L2LinesPerTag</b> . L2 cache lines per tag = 1.                                                                                                                                                                                                                                                      |
| ECX      | 7:0   | <b>L2LineSize</b> . L2 cache line size in bytes = 64.                                                                                                                                                                                                                                                   |

| Register | Bits  | Description                                                                                                                                        |
|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| EDX      | 31:18 | <b>L3Size</b> . L3 cache size (varies with product). L3 cache size is at least (L3Size[31:18] * 512KB) and less than ((L3Size[31:18] +1) * 512KB). |
| EDX      | 17:16 | Reserved.                                                                                                                                          |
| EDX      | 15:12 | <b>L3Assoc</b> . L3 cache associativity = (varies with product); supported values are 16, 32, 48, and 64.                                          |
| EDX      | 11:8  | <b>L3LinesPerTag</b> . L3 cache lines per tag = 1.                                                                                                 |
| EDX      | 7:0   | <b>L3LineSize</b> . L3 cache line size in bytes = 64.                                                                                              |

## CPUID Fn8000\_0007 Advanced Power Management Information

This function provides advanced power management feature identifiers.

| Register  | Bits | Description                                                                                                                                                                                                       |
|-----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EAX, EBX, | 31:0 | Reserved.                                                                                                                                                                                                         |
| ECX       |      |                                                                                                                                                                                                                   |
| EDX       | 31:9 | Reserved.                                                                                                                                                                                                         |
| EDX       | 8    | <b>TscInvariant</b> : TSC rate is invariant = 1.                                                                                                                                                                  |
| EDX       | 7    | <b>HwPstate</b> : hardware P-state control is supported = 1. [The P-State Current Limit Register] MSRC001_0061, [The P-State Control Register] MSRC001_0062 and [The P-State Status Register] MSRC001_0063 exist. |
| EDX       | 6    | <b>100MHzSteps</b> : 100 MHz multiplier Control = 1.                                                                                                                                                              |
| EDX       | 5    | STC: software thermal control (STC) is supported (support may vary by product).                                                                                                                                   |
| EDX       | 4    | TM: hardware thermal control (HTC) is supported (support may vary by product).                                                                                                                                    |
| EDX       | 3    | <b>TTP</b> : THERMTRIP is supported = 1.                                                                                                                                                                          |
| EDX       | 2    | <b>VID</b> : Voltage ID control is supported = 0 (function replaced by HwPstate).                                                                                                                                 |
| EDX       | 1    | <b>FID</b> : Frequency ID control is supported = 0 (function replaced by HwPstate).                                                                                                                               |
| EDX       | 0    | <b>TS</b> : Temperature sensor = 1.                                                                                                                                                                               |

# CPUID Fn8000\_0008 Address Size And Physical Core Count Information

This provides information about the number of physical CPU cores and the maximum physical and linear address width supported by the processor.

| Register | Bits  | Description                                                                                                                                                    |
|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EAX      | 31:16 | Reserved.                                                                                                                                                      |
| EAX      | 15:8  | Maximum linear byte address size in bits. If the processor supports long mode (see CPUID Fn[8000_0001, 0000_0001]_EDX[LM]) then this is 30h; else this is 20h. |
| EAX      | 7:0   | Maximum physical byte address size in bits = 30h.                                                                                                              |
| EBX      | 31:0  | Reserved.                                                                                                                                                      |
| ECX      | 31:16 | Reserved.                                                                                                                                                      |
| ECX      | 15:12 | <b>ApicIdCoreIdSize[3:0]</b> . The number of bits in the initial APIC20[ApicId] value that indicate CPU core ID within a processor = 2h.                       |

| Register | Bits | Description                                                                                                                                                                                                                                    |
|----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ECX      | 11:8 | Reserved.                                                                                                                                                                                                                                      |
| ECX      |      | NC: number of physical CPU cores - 1. The number of CPU cores in the processor is NC+1 (e.g., if NC=0, then there is one CPU core). This value is affected by F3x190[Dis-Core]. See also section 2.9.2 [CPU Cores and Downcoring] on page 107. |
| EDX      | 31:0 | Reserved.                                                                                                                                                                                                                                      |

## CPUID Fn8000\_0009 Reserved

# CPUID Fn8000\_000A SVM Revision and Feature Identification

This provides SVM revision and feature information. If CPUID Fn8000\_0001\_ECX[SVM]=0 then CPUID Fn8000\_000A is reserved.

| Register | Bits | Description                                                      |
|----------|------|------------------------------------------------------------------|
| EAX      | 31:8 | Reserved.                                                        |
| EAX      | 7:0  | SvmRev: SVM revision = 01h.                                      |
| EBX      | 31:0 | <b>NASID</b> : number of address space identifiers (ASID) = 40h. |
| ECX      | 31:0 | Reserved.                                                        |
| EDX      | 31:4 | Reserved.                                                        |
| EDX      | 3    | NRIPS: NRIP Save= 0.                                             |
| EDX      | 2    | SVML: SVM lock = 1.                                              |
| EDX      | 1    | <b>LbrVirt</b> : LBR virtualization = 1.                         |
| EDX      | 0    | <b>NP</b> : Nested Paging = 1.                                   |

## CPUID Fn8000\_00[18:0B] Reserved

## CPUID Fn8000\_0019 TLB 1GB Page Identifiers

This provides 1 GB paging information. The associativity fields are defined by CPUID Fn8000\_0006.

| Register | Bits  | Description                                              |
|----------|-------|----------------------------------------------------------|
| EAX      | 31:28 | L1 data TLB associativity for 1 GB pages = Fh.           |
| EAX      | 27:16 | L1 data TLB number of entries for 1 GB pages = 48.       |
| EAX      | 15:12 | L1 instruction TLB associativity for 1 GB pages = 0.     |
| EAX      | 11:0  | L1 instruction TLB number of entries for 1 GB pages = 0. |
| EBX      | 31:28 | L2 data TLB associativity for 1 GB pages = 0.            |
| EBX      | 27:16 | L2 data TLB number of entries for 1 GB pages = 0.        |
| EBX      | 15:12 | L2 instruction TLB associativity for 1 GB pages = 0.     |
| EBX      | 11:0  | L2 instruction TLB number of entries for 1 GB pages = 0. |
| ECX      | 31:0  | Reserved.                                                |
| EDX      | 31:0  | Reserved.                                                |

#### **CPUID Fn8000\_001A Performance Optimization Identifiers**

This function returns performance related information.

| Register | Bits | Description |
|----------|------|-------------|
| EAX      | 31:2 | Reserved.   |
| EAX      | 1    | MOVU.       |
| EAX      | 0    | FP128.      |
| EBX      | 31:0 | Reserved.   |
| ECX      | 31:0 | Reserved.   |
| EDX      | 31:0 | Reserved.   |

## 3.10 MSRs - MSR0000\_xxxx

See section 3.1 [Register Descriptions and Mnemonics] on page 135 for a description of the register naming convention. MSRs are accessed through x86 WRMSR and RDMSR instructions.

#### MSR0000\_0000 Load-Store MCA Address Register

This is an alias of MSR0000\_040E.

## MSR0000\_0001 Load-Store MCA Status Register

This is an alias of MSR0000\_040D.

#### MSR0000\_0010 Time Stamp Counter Register (TSC)

| R | Reset: 0000 0000 0000 0000h. |                                                                                                  |  |
|---|------------------------------|--------------------------------------------------------------------------------------------------|--|
| F | Bits                         | Description                                                                                      |  |
| 6 |                              | TSC: time stamp counter. Read-write. After reset, this register increments by one for each clock |  |
|   |                              | cycle. The TSC counts at the same rate in all P-states, all C states, S0, or S1.                 |  |

# MSR0000\_001B APIC Base Address Register (APIC\_BAR)

Reset: 0000 0000 FEE0 0?00h; bits[11:9] reset to 000b; see below for bit[8].

| Bits  | Description                                                                                                                                                                                                                                                                                                                              |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:48 | MBZ.                                                                                                                                                                                                                                                                                                                                     |
|       | <b>ApicBar: APIC base address register.</b> Read-write. Specifies the base address for the APICXX register set. See section 3.8 [APIC Registers] on page 273 for details about this register set.                                                                                                                                        |
|       | <b>ApicEn: APIC enable.</b> Read-write. 1=Local APIC enabled; the APICXX register set is accessible; all interrupt types are accepted. 0=Local APIC disabled; the APICXX register set is not accessible; no local-vector-table interrupts are supported; only non-vectored interrupts are supported including NMI, SMI, INIT and ExtINT. |

| 10:9 | MBZ.                                                                                                                                     |
|------|------------------------------------------------------------------------------------------------------------------------------------------|
|      | <b>BSC: boot strap CPU core.</b> Read-write. 1=The CPU core is the boot core of the BSP. 0=The CPU core is not the boot core of the BSP. |
| 7:0  | MBZ.                                                                                                                                     |

# MSR0000\_002A Cluster ID Register (EBL\_CR\_POWERON)

Reset: 0000 0000 0000 0000h. Attempted writes to this register result in general protection faults with error code 0.

| Bits  | Description                                                                     |
|-------|---------------------------------------------------------------------------------|
| 63:18 | MBZ.                                                                            |
| 17:16 | ClusterID. Read-only. This is normally 00b; the value does not affect hardware. |
| 15:0  | MBZ.                                                                            |

## MSR0000\_00FE MTRR Capabilities Register (MTRRcap)

| Reset: | Reset: 0000 0000 0000 0508h.                                                                                      |  |  |
|--------|-------------------------------------------------------------------------------------------------------------------|--|--|
| Bits   | Description                                                                                                       |  |  |
| 63:11  | Reserved.                                                                                                         |  |  |
| 10     | <b>MtrrCapWc: write-combining memory type</b> . Read-only. 1=The write combining memory type is supported.        |  |  |
| 9      | Reserved.                                                                                                         |  |  |
| 8      | MtrrCapFix: fixed range register. Read-only. 1=Fixed MTRRs are supported.                                         |  |  |
| 7:0    | <b>MtrrCapVCnt: variable range registers count</b> . Read-only. Specifies the number of variable MTRRs supported. |  |  |

# MSR0000\_0174 SYSENTER CS Register (SYSENTER\_CS)

Reset: 0000 0000 0000 0000h.

| Bits  | Description                                                                           |
|-------|---------------------------------------------------------------------------------------|
| 63:32 | RAZ.                                                                                  |
| 31:16 | SBZ.                                                                                  |
| 15:0  | SYSENTER_CS: SYSENTER target CS. Read-write. Holds the called procedure code segment. |

# MSR0000\_0175 SYSENTER ESP Register (SYSENTER\_ESP)

Reset: 0000 0000 0000 0000h.

| Bits  | Description                                                                             |
|-------|-----------------------------------------------------------------------------------------|
| 63:32 | Reserved.                                                                               |
| 31:0  | SYSENTER_ESP: SYSENTER target SP. Read-write. Holds the called procedure stack pointer. |

# MSR0000\_0176 SYSENTER EIP Register (SYSENTER\_EIP)

Reset: 0000 0000 0000 0000h.

| Bits  | Description                                                                          |
|-------|--------------------------------------------------------------------------------------|
| 63:32 | Reserved.                                                                            |
| 31:0  | SYSENTER_EIP: SYSENTER target IP. Read-write. Holds the called procedure instruction |
|       | pointer.                                                                             |

# MSR0000\_0179 Global Machine Check Capabilities Register (MCG\_CAP)

| Reset: | Reset: 0000 0000 0106h.                                                                           |  |
|--------|---------------------------------------------------------------------------------------------------|--|
| Bits   | Description                                                                                       |  |
| 63:9   | Reserved                                                                                          |  |
| 8      | MCG_CTL_P: MCG_CTL register present. Read-only. 1=The machine check control registers             |  |
|        | (MCi_CTL; see section 2.13.1 [Machine Check Architecture] on page 113) are present.               |  |
| 7:0    | <b>Count</b> . Read-only. Indicates the number of error-reporting banks visible to each CPU core. |  |

# MSR0000\_017A Global Machine Check Status Register (MCG\_STAT)

| Reset: | Reset: 0000 0000 0000 0000h. See also 2.13.1 [Machine Check Architecture] on page 113.                                                                                                                                                         |  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits   | Description                                                                                                                                                                                                                                    |  |
| 63:3   | Reserved.                                                                                                                                                                                                                                      |  |
| 2      | MCIP: machine check in progress. Read-write; set-by-hardware. 1=A machine check is in progress.                                                                                                                                                |  |
|        | <b>EIPV: error instruction pointer valid</b> . Read-write; set-or-cleared-by-hardware. 1=The instruction pointer that was pushed onto the stack by the machine check mechanism references the instruction that caused the machine check error. |  |
|        | <b>RIPV: restart instruction pointer valid</b> . Read-write; set-or-cleared-by-hardware. 1=Program execution can be reliably restarted at the EIP address on the stack.                                                                        |  |

# MSR0000\_017B Global Machine Check Exception Reporting Control Register (MCG\_CTL)

Reset: 0000 0000 0000 0000h. See also 2.13.1 [Machine Check Architecture] on page 113. It is expected that this register is programmed to the same value in all nodes.

| Bits | Description                                                                                                                                        |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:6 | Reserved                                                                                                                                           |
| 5    | <b>FRE: fixed issue reorder buffer register bank enable</b> . Read-write. 1=The fixed-issue reorder buffer machine check register bank is enabled. |
| 4    | <b>NBE:</b> Northbridge register bank enable. Read-write. 1=The Northbridge machine check register bank is enabled.                                |
| 3    | <b>LSE: load-store register bank enable</b> . Read-write. 1=The load/store machine check register bank is enabled.                                 |
| 2    | <b>BUE:</b> bus unit register bank enable. Read-write. 1=The bus unit machine check register bank is enabled.                                      |
| 1    | <b>ICE:</b> instruction cache register bank enable. Read-write. 1=The instruction cache machine check register bank is enabled.                    |
| 0    | <b>DCE:</b> data cache register bank enable. Read-write. 1=The data cache machine check register bank is enabled.                                  |

#### MSR0000\_01D9 Debug Control Register (DBG\_CTL\_MSR)

| Reset: 0000 0000 0000 0000h. |                                                                                                    |
|------------------------------|----------------------------------------------------------------------------------------------------|
| Bits                         | Description                                                                                        |
| 63:7                         | Reserved.                                                                                          |
| 6                            | MBZ.                                                                                               |
| 5:2                          | <b>PB: performance monitor pin control</b> . Read-write. This field does not control any hardware. |
| 1                            | <b>BTF</b> . Read-write. 1=Enable branch single step.                                              |
| 0                            | LBR. Read-write. 1=Enable last branch record.                                                      |

## MSR0000\_01DB Last Branch From IP Register (BR\_FROM)

| Bits | Description                                                                                    |
|------|------------------------------------------------------------------------------------------------|
| 63:0 | <b>LastBranchFromIP</b> . Read-only. Loaded with the segment offset of the branch instruction. |

### MSR0000\_01DC Last Branch To IP Register (BR\_TO)

| Bits | Description                                                                                                  |
|------|--------------------------------------------------------------------------------------------------------------|
| 63:0 | <b>LastBranchToIP</b> . Read-only. Holds the target RIP of the last branch that occurred before an exception |
|      | or interrupt.                                                                                                |

## MSR0000\_01DD Last Exception From IP Register

| Bits | Description                                                                                                  |
|------|--------------------------------------------------------------------------------------------------------------|
| 63:0 | <b>LastIntFromIP</b> . Read-only. Holds the source RIP of the last branch that occurred before the exception |
|      | or interrupt.                                                                                                |

#### MSR0000 01DE Last Exception To IP Register

| Bits | Description                                                                                                   |
|------|---------------------------------------------------------------------------------------------------------------|
| 63:0 | <b>LastIntToIP</b> . Read-only. Holds the target RIP of the last branch that occurred before the exception or |
|      | interrupt.                                                                                                    |

#### MSR0000\_02[0F:00] Variable-Size MTRRs (MTRRphysBasen and MTRRphysMaskn)

Reset: xxxx xxxx xxxx xxxxh. Each MTRR ([The Variable-Size MTRRs (MTRRphysBasen and MTRRphys-Maskn)] MSR0000\_02[0F:00], [The Fixed-Size MTRRs (MTRRfixn)] MSR0000\_02[6F:68, 59, 58, 50], or [The MTRR Default Memory Type Register (MTRRdefType)] MSR0000\_02FF) specifies a physical address range and a corresponding memory type (MemType) associated with that range. Each 8-bit MemType field may include the following sub-fields:

- Bits[7:5]: reserved.
- Bit[4]: RdDram. 0=Read accesses to the range are marked as MMIO. 1=Read accesses to the range are

marked as destined for DRAM. See also section 2.9.3 [Access Type Determination] on page 107. This bit can be enabled for fixed MTRR ranges only (see MSRC001\_0010[MtrrFixDramEn, MtrrFixDramModEn]); not variable-size MTRRs.

- Bit[3]: WrDram. 0=Write accesses to the range are marked as MMIO. 1=Write accesses to the range are marked as destined for DRAM. See also section 2.9.3 [Access Type Determination] on page 107. This bit can be enabled for fixed MTRR ranges only (see [The System Configuration Register (SYS\_CFG)] MSRC001 0010); not variable-size MTRRs.
- Bits[2:0]: Memory type. The encodings for these are:

0h = UC or uncacheable.5h = WP or write protect.1h = WC or write combining.6h = WB or write back.4h = WT or write through.All other values are reserved.

Setting MemType to an unsupported value results in a #GP(0).

The variable-size MTRRs come in pairs of base and mask registers (MSR0000\_0200 and MSR0000\_0201 are the first pair, etc.). Variables MTRRs are enabled through [The MTRR Default Memory Type Register (MTR-RdefType)] MSR0000\_02FF[MtrrDefTypeEn]. A CPU access--with address CPUAddr--is determined to be within the address range of a variable-size MTRR if the following equation is true:

CPUAddr[47:12] & PhyMask[47:12] == PhyBase[47:12] & PhyMask[47:12].

For example, if the variable MTRR spans 256K bytes and starts at the 1M byte address. The PhyBase would be set to 00\_0010\_0000h and the PhyMask to FF\_FFFC\_0000h (with zeros filling in for bits[11:0]). This results in a range from 00\_0010\_0000h to 00\_0013\_FFFFh.

#### MSR0000 020[E, C, A, 8, 6, 4, 2, 0] (MTRRphysBasen)

| Bits  | Description                        |
|-------|------------------------------------|
| 63:48 | MBZ.                               |
| 47:12 | PhyBase: base address. Read-write. |
| 11:8  | MBZ.                               |
| 7:0   | MemType: memory type. Read-write.  |

#### MSR0000 020[F, D, B, 9, 7, 5, 3, 1] (MTRRphysMask*n*)

| Bits  | Description                                                  |
|-------|--------------------------------------------------------------|
| 63:48 | MBZ.                                                         |
| 47:12 | PhyMask: address mask. Read-write.                           |
| 11    | Valid. Read-write. 1=The variable-size MTRR pair is enabled. |
| 10:0  | MBZ.                                                         |

### MSR0000\_02[6F:68, 59, 58, 50] Fixed-Size MTRRs (MTRRfixn)

Reset: xxxx xxxx xxxx xxxxh. See MSR0000\_02[0F:00] for general MTRR information. Fixed MTRRs are enabled through MSR0000\_02FF[MtrrDefTypeFixEn and MtrrDefTypeEn].

### MSR0000\_0250 (MTRRfix64K\_00000)

| Bits  | Description                                                            |
|-------|------------------------------------------------------------------------|
| 63:56 | MemType: memory type. Read-write. Address range from 7_0000 to 7_FFFF. |

| 55:48 | MemType: memory type. Read-write. Address range from 6_0000 to 6_FFFF. |
|-------|------------------------------------------------------------------------|
| 47:40 | MemType: memory type. Read-write. Address range from 5_0000 to 5_FFFF. |
| 39:32 | MemType: memory type. Read-write. Address range from 4_0000 to 4_FFFF. |
| 31:24 | MemType: memory type. Read-write. Address range from 3_0000 to 3_FFFF. |
| 23:16 | MemType: memory type. Read-write. Address range from 2_0000 to 2_FFFF. |
| 15:8  | MemType: memory type. Read-write. Address range from 1_0000 to 1_FFFF. |
| 7:0   | MemType: memory type. Read-write. Address range from 0_0000 to 0_FFFF. |

MSR0000\_0258 (MTRRfix16K\_80000) and MSR0000\_0259 (MTRRfix16K\_A0000)

The ranges specified below are described as offsets from the base address.

- The base address for MSR0000 0258 = 8 0000h.
- The base address for MSR0000\_0259 = A\_0000h.

| Bits  | Description                                                                                    |
|-------|------------------------------------------------------------------------------------------------|
| 63:56 | MemType: memory type. Read-write. Address range from 1_C000 to 1_FFFF (plus the base).         |
| 55:48 | MemType: memory type. Read-write. Address range from 1_8000 to 1_BFFF (plus the base).         |
| 47:40 | <b>MemType: memory type</b> . Read-write. Address range from 1_4000 to 1_7FFF (plus the base). |
| 39:32 | <b>MemType: memory type</b> . Read-write. Address range from 1_0000 to 1_3FFF (plus the base). |
| 31:24 | <b>MemType: memory type</b> . Read-write. Address range from 0_C000 to 0_FFFF (plus the base). |
| 23:16 | <b>MemType: memory type</b> . Read-write. Address range from 0_8000 to 0_BFFF (plus the base). |
| 15:8  | <b>MemType: memory type</b> . Read-write. Address range from 0_4000 to 0_7FFF (plus the base). |
| 7:0   | <b>MemType: memory type</b> . Read-write. Address range from 0_0000 to 0_3FFF (plus the base). |

MSR0000\_02[6F:68] (MTRRfix4K\_xxxxx)

The ranges specified below are described as offsets from the base address.

- The base address for MSR0000\_0268 = C\_0000h.
- The base address for MSR0000\_0269 = C\_8000h.
- The base address for MSR0000 026A = D 0000h.
- The base address for  $MSR0000\_026B = D\_8000h$ .
- The base address for  $MSR0000\_026C = E\_0000h$ .
- The base address for MSR0000 026D = E 8000h.
- The base address for  $MSR0000\_026E = F\_0000h$ .
- The base address for  $MSR0000\_026F = F\_8000h$ .

| Bits  | Description                                                                                    |
|-------|------------------------------------------------------------------------------------------------|
| 63:56 | <b>MemType:</b> memory type. Read-write. Address range from 0_7000 to 0_7FFF (plus the base).  |
| 55:48 | <b>MemType: memory type</b> . Read-write. Address range from 0_6000 to 0_6FFF (plus the base). |
| 47:40 | <b>MemType: memory type</b> . Read-write. Address range from 0_5000 to 0_5FFF (plus the base). |
| 39:32 | <b>MemType: memory type</b> . Read-write. Address range from 0_4000 to 0_4FFF (plus the base). |
| 31:24 | <b>MemType:</b> memory type. Read-write. Address range from 0_3000 to 0_3FFF (plus the base).  |

| 23:16 | MemType: memory type. Read-write. Address range from 0_2000 to 0_2FFF (plus the base). |
|-------|----------------------------------------------------------------------------------------|
| 15:8  | MemType: memory type. Read-write. Address range from 0_1000 to 0_1FFF (plus the base). |
| 7:0   | MemType: memory type. Read-write. Address range from 0_0000 to 0_0FFF (plus the base). |

## MSR0000\_0277 Page Attribute Table Register (PAT)

Reset: 0007 0406 0007 0406h. This register specifies the memory type based on the PAT, PCD, and PWT bits in the virtual address page tables. The encodings for PA[7:0] is:

0h = UC or uncacheable. 5h = WP or write protect. 1h = WC or write combining. 6h = WB or write back.

4h = WT or write through. 7h = UC- or uncacheable (overridden by MTRR)

All other values result in a #GP(0). WC state)

| Bits  | Description                                                                    |
|-------|--------------------------------------------------------------------------------|
| 63:59 | MBZ.                                                                           |
| 58:56 | PA7 MemType. Read-write. Default UC. MemType for {PAT, PCD, PWT} = 7h.         |
| 55:51 | MBZ.                                                                           |
| 50:48 | <b>PA6 MemType</b> . Read-write. Default UC MemType for {PAT, PCD, PWT} = 6h.  |
| 47:43 | MBZ.                                                                           |
| 42:40 | PA5 MemType. Read-write. Default WT. MemType for {PAT, PCD, PWT} = 5h.         |
| 39:35 | MBZ.                                                                           |
| 34:32 | <b>PA4 MemType</b> . Read-write. Default WB. MemType for {PAT, PCD, PWT} = 4h. |
| 31:27 | MBZ.                                                                           |
| 26:24 | <b>PA3 MemType</b> . Read-write. Default UC. MemType for {PAT, PCD, PWT} = 3h. |
| 23:19 | MBZ.                                                                           |
| 18:16 | <b>PA2 MemType</b> . Read-write. Default UC MemType for {PAT, PCD, PWT} = 2h.  |
| 15:11 | MBZ.                                                                           |
| 10:8  | <b>PA1 MemType</b> . Read-write. Default WT. MemType for {PAT, PCD, PWT} = 1h. |
| 7:3   | MBZ.                                                                           |
| 2:0   | <b>PA0 MemType</b> . Read-write. Default WB. MemType for {PAT, PCD, PWT} = 0h. |

# MSR0000\_02FF MTRR Default Memory Type Register (MTRRdefType)

| Reset: | 0000 0000 0000 0000h. See MSR0000_02[0F:00] for general MTRR information.                                                                                                                                                                                                 |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits   | Description                                                                                                                                                                                                                                                               |
| 63:12  | MBZ.                                                                                                                                                                                                                                                                      |
|        | MtrrDefTypeEn: variable and fixed MTRR enable. Read-write. 1=[The Variable-Size MTRRs (MTRRphysBasen and MTRRphysMaskn)] MSR0000_02[0F:00], and [The Fixed-Size MTRRs (MTRRfixn)] MSR0000_02[6F:68, 59, 58, 50], are enabled. 0=Fixed and variable MTRRs are not enabled. |
|        | MtrrDefTypeFixEn: fixed MTRR enable. 1=[The Fixed-Size MTRRs (MTRRfixn)] MSR0000_02[6F:68, 59, 58, 50], are enabled. This field is ignored (and the fixed MTRRs are not enabled) if MSR0000_02FF[MtrrDefTypeEn]=0.                                                        |

| 9:8 | MBZ.                                                                                                                                                                                                                                                          |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | <b>MemType:</b> memory type. Read-write. Specifies the memory type for space not mapped to enabled [The Variable-Size MTRRs (MTRRphysBasen and MTRRphysMaskn)] MSR0000_02[0F:00], or enabled [The Fixed-Size MTRRs (MTRRfixn)] MSR0000_02[6F:68, 59, 58, 50]. |

## MSR0000\_0400 DC Machine Check Control Register (MC0\_CTL)

Reset: 0000 0000 0000 0000h. All defined bits are read-write.

See section 2.13.1 [Machine Check Architecture] on page 113. For all bits, 1=Enable the specified reporting mechanism.

| Bits | Enable                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:7 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6    | L2TP: L2 TLB parity errors. Report data cache L2 TLB parity errors.                                                                                                                                                                                                                                                                                                                                                           |
| 5    | L1TP: L1 TLB parity errors. Report data cache L1 TLB parity errors.                                                                                                                                                                                                                                                                                                                                                           |
| 4    | <b>DSTP: snoop tag array parity errors</b> . Report data cache snoop tag array parity errors.                                                                                                                                                                                                                                                                                                                                 |
| 3    | <b>DMTP: main tag array parity errors</b> . Report data cache main tag array parity errors.                                                                                                                                                                                                                                                                                                                                   |
| 2    | <b>DECC:</b> data array ECC errors. Report data cache data array ECC errors. If not set, ECC errors in the cache are detected and logged, but not reported. If masked (see MSRC001_00[49:44]), ECC errors in the cache are undetected.                                                                                                                                                                                        |
| 1    | ECCM: multi-bit ECC data errors. Report multi-bit ECC data errors during data cache line fills from the internal L2 or the system. If masked (see MSRC001_00[49:44]), multi-bit ECC errors on line fills may be detected and logged as single-bit errors unless single-bit ECC data errors are also masked (ECCI). If masking all line fill data errors is desired, all ECC data error mask bits (ECCI and ECCM) must be set. |
| 0    | <b>ECCI:</b> single-bit ECC data errors. Report single-bit ECC data errors during data cache line fills from the internal L2 or the system. If masked (see MSRC001_00[49:44]), multi-bit ECC errors on line fills may also be masked. If masking all line fill data errors is desired, all ECC data error mask bits (ECCI and ECCM) must be set.                                                                              |

## MSR0000\_0401 DC Machine Check Status Register (MC0\_STATUS)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. Each of the MCi\_STATUS registers hold information identifying the last error logged in each bank. Software is normally only allowed to write 0's to these registers to clear the fields so subsequent errors may be logged. See also MSRC001\_0015[McStatusWrEn]. The following field definitions apply to all MCi\_STATUS registers, except as noted.

| Bits | Description                                                                                                                                                                                                                                                                                                                                             |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63   | <b>Val:</b> valid. Read-write; set-by-hardware. 1=A valid error has been detected (whether it is enabled or not). This bit should be cleared to 0 by software after the register has been read.                                                                                                                                                         |
| 62   | Over: error overflow. Read-write; set-by-hardware. 1=An error was detected while the valid bit (Val) of this register was set; at least one error was not logged. The machine check mechanism handles the contents of MCi_STATUS during overflow as outlined in section 2.13.1.2.2 [Machine Check Error Logging Overwrite During Overflow] on page 116. |

| 61                      | <b>UC: error uncorrected</b> . Read-write; set-or-cleared-by-hardware. 1=The error was not corrected by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 60                      | <b>En: error enable</b> . Read-write; set-or-cleared-by-hardware. 1=MCA error reporting is enabled for this error in MCi_CTL.                                                                                                                                                                                                                                                                                                                                                                                                                |
| 59                      | <b>MiscV: miscellaneous error register valid.</b> Read-only. 1=MCi_MISC contains valid information for this error. This bit is always 0, except in the case of [The NB Machine Check Misc (Thresholding) Register (MC4_MISC0)] MSR0000_0413 and [The FR Machine Check Miscellaneous Register (MC5_MISC)] MSR0000_0417.                                                                                                                                                                                                                       |
| 58                      | <b>AddrV: error address valid</b> . Read-write; set-or-cleared-by-hardware. 1=The address saved in MCi_ADDR is the address where the error occurred.                                                                                                                                                                                                                                                                                                                                                                                         |
| 57                      | <b>PCC:</b> processor context corrupt. Read-write; set-or-cleared-by-hardware. 1=The state of the processor may have been corrupted by the error condition. Restart may not be reliable.                                                                                                                                                                                                                                                                                                                                                     |
| 56:55                   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 54:47                   | <ul> <li>Syndrome[7:0]. Read-write.</li> <li>MC0_STATUS (DC): The lower eight syndrome bits when an ECC error is detected. See Table 39 for the mappings that show which bit errors result in which syndrome values.</li> <li>MC[3:1]_STATUS (LS, BU, IC): Reserved.</li> </ul>                                                                                                                                                                                                                                                              |
| 46                      | <b>CECC: correctable ECC error</b> . Read-write; set-or-cleared-by-hardware. 1=The error was a correctable ECC error.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 45                      | <b>UECC: uncorrectable ECC error</b> . Read-write; set-or-cleared-by-hardware. 1=The error was an uncorrectable ECC error.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 44:41                   | n1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 44:41                   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 44:41                   | Scrub: error detected on a scrub. Read-write; set-or-cleared-by-hardware.  • MC0_STATUS (DC), MC2_STATUS (BU): 1=The error was detected on a scrub.  • MC1_STATUS (IC), MC3_STATUS (LS), MC5_STATUS (FR): Reserved.                                                                                                                                                                                                                                                                                                                          |
|                         | Scrub: error detected on a scrub. Read-write; set-or-cleared-by-hardware.  • MC0_STATUS (DC), MC2_STATUS (BU): 1=The error was detected on a scrub.                                                                                                                                                                                                                                                                                                                                                                                          |
| 40<br>39:32             | Scrub: error detected on a scrub. Read-write; set-or-cleared-by-hardware.  • MC0_STATUS (DC), MC2_STATUS (BU): 1=The error was detected on a scrub.  • MC1_STATUS (IC), MC3_STATUS (LS), MC5_STATUS (FR): Reserved.  Reserved.                                                                                                                                                                                                                                                                                                               |
| 39:32<br>31:24          | <ul> <li>Scrub: error detected on a scrub. Read-write; set-or-cleared-by-hardware.</li> <li>MC0_STATUS (DC), MC2_STATUS (BU): 1=The error was detected on a scrub.</li> <li>MC1_STATUS (IC), MC3_STATUS (LS), MC5_STATUS (FR): Reserved.</li> <li>Reserved.</li> <li>Syndrome[15:8]. Read-write.</li> <li>MC0_STATUS (DC): The upper eight syndrome bits when an ECC error is detected. See Table 39 for the mappings that show which bit errors result in which syndrome values.</li> </ul>                                                 |
| 39:32<br>31:24<br>23:20 | <ul> <li>Scrub: error detected on a scrub. Read-write; set-or-cleared-by-hardware.</li> <li>MC0_STATUS (DC), MC2_STATUS (BU): 1=The error was detected on a scrub.</li> <li>MC1_STATUS (IC), MC3_STATUS (LS), MC5_STATUS (FR): Reserved.</li> <li>Reserved.</li> <li>Syndrome[15:8]. Read-write.</li> <li>MC0_STATUS (DC): The upper eight syndrome bits when an ECC error is detected. See Table 39 for the mappings that show which bit errors result in which syndrome values.</li> <li>MC[3:1]_STATUS (LS, BU, IC): Reserved.</li> </ul> |

This register reports these DC errors:

**Table 63: DC error descriptions** 

| Error Type                               | Description                                                 | Enablers (MSR0000_0400<br>Control Bits) |
|------------------------------------------|-------------------------------------------------------------|-----------------------------------------|
| L2 Cache Line<br>Fill                    | An error occurred during an L1 line fill from the L2 cache. | ECC1, ECCM.                             |
| Data Load/<br>Store/<br>Victim/<br>Snoop | A data error occurred while accessing or managing data.     | DECC                                    |
| Data Scrub                               | An error was detected during a scrub of cache data.         | DECC                                    |
| Tag Snoop/<br>Victim                     | A tag error was encountered during snoop or victimization.  | DSTP                                    |
| Tag Load/Store                           | A tag error was encountered during load or store.           |                                         |
| L1 TLB                                   | Parity error in L1 TLB.                                     | L1TP                                    |
| L1 TLB Multi-<br>match                   | Hit multiple entries.                                       | LITP                                    |
| L2 TLB                                   | Parity error in L2 TLB.                                     | L2TP                                    |
| L2 TLB Multi-<br>match                   | Hit multiple entries.                                       | L2TP                                    |

**Table 64: DC error signatures** 

| Error                                    | [19:16]           | Error | · Code     | (see I | 3x48 <b>for</b>                 | encodi       | ng)       | [61]             | [58]       | [57] | [54:47]       | [46]              | [45]             | [44]         | [43]         | [40]  |
|------------------------------------------|-------------------|-------|------------|--------|---------------------------------|--------------|-----------|------------------|------------|------|---------------|-------------------|------------------|--------------|--------------|-------|
| Туре                                     | Error-<br>CodeExt | Type  | 10:9<br>PP | 8<br>T | 7:4<br>RRRR                     | 3:2<br>II/TT | 1:0<br>LL |                  | ADD-<br>RV | PCC  | Synd<br>Valid | CECC              | UECC             | Reser<br>ved | Reser<br>ved | Scrub |
| L2 Cache<br>Line Fill                    | 0000              | Mem   | i          | ı      | DRD                             | Data         | L2        | If multi-<br>bit | 1          | 1/0  | Y             | If single-<br>bit | If multi-<br>bit |              |              | 0     |
| Data Load/<br>Store/<br>Victim/<br>Snoop | 0000              | Mem   | -          | 1      | DRD/<br>DWR/<br>Evict/<br>Snoop | Data         | L1        | If multi-<br>bit | 1/0        | 1/0  | Y             | If single-<br>bit | If multi-<br>bit |              |              | 0     |
| Data Scrub                               | 0000              | Mem   | -          | -      | GEN                             | Data         | L1        | If multi-<br>bit | 1          | 0    | Y             | If single-<br>bit | If multi-<br>bit |              |              | 1     |
| Tag Snoop/<br>Victim                     | 0000              | Mem   | -          | -      | Snoop/<br>Evict                 | Data         | L1        | 1                | 1/0        | 1    | N             | 0                 | 0                |              |              | 0     |
| Tag Load/<br>Store                       | 0000              | Mem   | -          | -      | DRD/<br>DWR                     | Data         | L1        | 1                | 1          | 1    | N             | 0                 | 0                |              |              | 0     |
| L1 TLB                                   | 0000              | TLB   | -          | -      | -                               | Data         | L1        | 1                | 1          | 1    | N             | 0                 | 0                |              |              | 0     |
| L1 TLB<br>Multimatch                     | 0001              | TLB   | -          | -      | -                               | Data         | L1        | 1                | 1          | 1    | N             | 0                 | 0                |              |              | 0     |
| L2 TLB                                   | 0000              | TLB   | -          | -      | -                               | Data         | L2        | 1                | 1          | 1    | N             | 0                 | 0                |              |              | 0     |
| L2 TLB<br>Multimatch                     | 0001              | TLB   | -          | -      | -                               | Data         | L2        | 1                | 1          | 1    | N             | 0                 | 0                |              |              | 0     |

# MSR0000\_0402 DC Machine Check Address Register (MC0\_ADDR)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. Each of the MCi\_ADDR registers are written to by hardware and read-write accessible by software. MCi\_ADDR registers contains valid data if indicated by MCi\_STATUS[AddrV]. Table 65 defines the address register as a function

of error type.

Table 65: DC error data; address register

| Error Type             | Memory<br>Transaction<br>Type (RRRR;<br>Table 49) | Address Register Bits | Description      |  |  |
|------------------------|---------------------------------------------------|-----------------------|------------------|--|--|
| L2 Cache Line<br>Fill  | DRD                                               | 47:6                  | Physical address |  |  |
| Data Load/             | DRD                                               | 47:4 <sup>1</sup>     | Physical address |  |  |
| Store/                 | DWR                                               |                       |                  |  |  |
| Victim/<br>Snoop       | Evict                                             | 11:6                  | Physical address |  |  |
| Sпоор                  | Snoop                                             |                       |                  |  |  |
| Data Scrub             | GEN                                               | 11:4                  | Physical address |  |  |
| Tag Snoop/             | Snoop                                             | 11:6                  | Physical address |  |  |
| Victim                 | Evict                                             |                       |                  |  |  |
| Tag Load/              | DRD                                               | 11:6 <sup>2</sup>     | Physical address |  |  |
| Store                  | DWR                                               |                       |                  |  |  |
| L1 TLB                 | -                                                 | 47:12                 | Linear address   |  |  |
| L1 TLB Multi-<br>match |                                                   |                       |                  |  |  |
| L2 TLB                 |                                                   |                       |                  |  |  |
| L2 TLB Multi-<br>match |                                                   |                       |                  |  |  |

- 1. For Data Store (DWR), address bits shown are present only if error was reported (MSR0000\_0401[UC] is set and MSR0000\_0400[DECC] is enabled and not masked). If not reported, then valid address register bits are the linear address in 14:4.
- 2. The entire address from the TLB may be stored, but that address may only be incidentally related to the tag error; only the indicated bits are valid for this type of error.

## MSR0000\_0403 DC Machine Check Miscellaneous Register (MC0\_MISC)

This register is read-only, reset: 0000 0000 0000 0000h.

# MSR0000\_0404 IC Machine Check Control Register (MC1\_CTL)

Reset: 0000 0000 0000 0000h. All defined bits are read-write.

See section 2.13.1 [Machine Check Architecture] on page 113. For all bits, 1=Enable the specified reporting mechanism.

| Bits  | Enable                                                                                                                                                                         |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:10 | Reserved.                                                                                                                                                                      |
|       | <b>RDDE: read data errors</b> . Report system read data errors for an instruction cache fetch if [The BU Machine Check Control Register (MC2_CTL)] MSR0000_0408[SRDE_ALL] = 1. |
| 8:7   | Reserved.                                                                                                                                                                      |

| Bits | Enable                                                                                                                                                             |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | L2TP: L2 TLB parity errors. Report instruction cache L2 TLB parity errors.                                                                                         |
| 5    | L1TP: L1 TLB parity errors. Report instruction cache L1 TLB parity errors.                                                                                         |
| 4    | <b>ISTP: snoop tag array parity errors</b> . Report instruction cache snoop tag array parity errors.                                                               |
| 3    | IMTP: main tag array parity errors. Report instruction cache main tag array parity errors.                                                                         |
| 2    | IDP: data array parity errors. Report instruction cache data array parity errors.                                                                                  |
| 1    | <b>ECCM:</b> multi-bit ECC data errors. Report multi-bit ECC data errors during instruction cache line fills or TLB reloads from the internal L2 or the system.    |
| 0    | <b>ECCI: single-bit ECC data errors</b> . Report single-bit ECC data errors during instruction cache line fills or TLB reloads from the internal L2 or the system. |

# MSR0000\_0405 IC Machine Check Status Register (MC1\_STATUS)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. See also MSR0000\_0401 for the information about all of the MCi\_STATUS registers. See also MSRC001\_0015[McStatusWrEn]. This register reports these IC errors:

# **Table 66: IC error descriptions**

| Error Type                | Description                                                                                                                                                      | Enablers (MSR0000_0404 Control Bits) |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| System Data<br>Read Error | An error occurred during an attempted read of data from the NB. Possible reasons include master abort, target abort.                                             | RDDE                                 |
| L2 Cache Line<br>Fill     | An error occurred during a line fill from the L2 cache.                                                                                                          | ECCM                                 |
| IC Data Load<br>(Parity)  | A parity error occurred during load of data from the IC. This may be either a data error or a tag error. The data is discarded from the IC and can be refetched. | IDP, IMTP                            |
| Tag Snoop                 | A tag error was encountered during snoop or victimization.                                                                                                       | ISTP                                 |
| Copyback parity           | A copyback parity error occurred.                                                                                                                                | IMTP                                 |
| L1 TLB                    | Parity error in L1 TLB.                                                                                                                                          | LITP                                 |
| L1 TLB Multi-<br>match    | Hit multiple entries.                                                                                                                                            | L1TP                                 |
| L2 TLB                    | Parity error in L2 TLB.                                                                                                                                          | L2TP                                 |
| L2 TLB Multi-<br>match    | Hit multiple entries.                                                                                                                                            | L2TP                                 |

| Error                        | [19:16]           | Erro        | · Code     | (see ] | F3x48 for   | encodi       | ng)       | [61]  | [58]       | [57] | [54:47]       | [46]    | [45] | [44]         | [43]         | [40]  |
|------------------------------|-------------------|-------------|------------|--------|-------------|--------------|-----------|-------|------------|------|---------------|---------|------|--------------|--------------|-------|
| Туре                         | Error-<br>CodeExt | Type        | 10:9<br>PP | 8<br>T | 7:4<br>RRRR | 3:2<br>II/TT | 1:0<br>LL | UC    | ADD-<br>RV | PCC  | Synd<br>Valid | CECC    | UECC | Reser<br>ved | Reser<br>ved | Scrub |
| System<br>Data Read<br>Error | 0000              | BUS         | SRC        | 0      | IRD         | MEM          | LG        | 1     | 0          | 0    | N             | 0       | 0    |              |              | 0     |
| L2 Cache<br>Line Fill        | 0000              | Mem-<br>ory | 1          | -      | IRD         | Instr        | L2        | $0^1$ | 1          | 0    | N             | $0^{2}$ | 1    |              |              | 0     |
| IC Data<br>Load<br>(Parity)  | 0000              | Mem-<br>ory | 1          | -      | IRD         | Instr        | L1        | 0     | 1          | 0    | N             | 0       | 0    |              |              | 0     |
| Tag Snoop                    | 0000              | Mem-<br>ory | -          | -      | Snoop       | Instr        | L1        | 1     | 1          | 1    | N             | 0       | 0    |              |              | 0     |
| Copyback parity              | 0000              | Mem-<br>ory | -          | -      | Evict       | Instr        | L1        | 0     | 0          | 0    | N             | 0       | 0    |              |              | 0     |
| L1 TLB                       | 0000              | TLB         | -          | -      | -           | Instr        | L1        | 0     | 1          | 0    | N             | 0       | 0    |              |              | 0     |
| L1 TLB<br>Multimatch         | 0001              | TLB         | -          | -      | -           | Instr        | L1        | 0     | 1          | 0    | N             | 0       | 0    |              |              | 0     |
| L2 TLB                       | 0000              | TLB         | -          | -      | -           | Instr        | L2        | 0     | 1          | 0    | N             | 0       | 0    |              |              | 0     |
| L2 TLB<br>Multimatch         | 0001              | TLB         | -          | -      | -           | Instr        | L2        | 0     | 1          | 0    | N             | 0       | 0    |              |              | 0     |

<sup>1.</sup> Line refetched from memory. (Automatically purged from L2 during fill.)

# MSR0000\_0406 IC Machine Check Address Register (MC1\_ADDR)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. Each of the MCi\_ADDR registers are written to by hardware and read-write accessible by software. MCi\_ADDR registers contains valid data if indicated by MCi\_STATUS[AddrV]. Table 68 defines the address register as a function of error type.

Table 68: IC error data; address register

| Error Type             | Address Register Bits  | Description      |
|------------------------|------------------------|------------------|
| L2 Cache Line<br>Fill  | 47:6                   | Physical address |
| IC Data Load           | 47:4                   | Linear address   |
| Tag Snoop              | 47:6                   | Physical address |
|                        | 47:12 for 4-Kbyte page | Linear address   |
| L1 TLB Multi-<br>match | 47:20 for 2-Mbyte page |                  |
| L2 TLB                 | 47:12 for 4-Kbyte page | Linear address   |
| L2 TLB Multi-<br>match |                        |                  |

## MSR0000\_0407 IC Machine Check Miscellaneous Register (MC1\_MISC)

This register is read-only, reset: 0000 0000 0000 0000h.

<sup>2.</sup> Single bit errors are detected as parity errors.

## MSR0000\_0408 BU Machine Check Control Register (MC2\_CTL)

Reset: 0000 0000 0000 0000h. All defined bits are read-write.

See section 2.13.1 [Machine Check Architecture] on page 113. For all bits, 1=Enable the specified reporting mechanism.

| Bits  | Enable                                                                                                                                     |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 63:12 | Reserved.                                                                                                                                  |
| 11    | <b>PDC_PAR:</b> Pdc/GTLB parity errors. Report Page Descriptor Cache parity or Guest TLB table walk parity errors.                         |
| 10    | <b>VB_PAR: write/victim data buffer parity error</b> . Report write buffer or victim buffer data parity errors.                            |
| 9     | Reserved.                                                                                                                                  |
| 8     | L2D_UECC: L2 data uncorrectable ECC error. Report L2 data array uncorrectable ECC errors.                                                  |
| 7     | L2D_CECC: L2 data correctable ECC error. Report L2 data array correctable ECC errors.                                                      |
| 6     | L2D_PAR: L2 data parity errors. Report correctable and uncorrectable L2 data array parity errors.                                          |
| 5     | L2T_UECC: L2 tag uncorrectable ECC error. Report L2 tag array uncorrectable ECC errors.                                                    |
| 4     | L2T_CECC: L2 tag correctable ECC error. Report L2 tag array correctable ECC errors.                                                        |
| 3     | L2T_PAR: L2 tag parity errors. Report L2 tag array correctable and uncorrectable parity errors.                                            |
| 2     | SRDE_ALL: all system read data. Report system read data errors for any operation including a DC/IC fetch, TLB reload or hardware prefetch. |
| 1     | SRDE_TLB: system read data TLB reload. Report system read data errors for a TLB reload.                                                    |
| 0     | <b>SRDE_HP: system read data hardware prefetch</b> . Report system read data errors for a hardware prefetch.                               |

# MSR0000\_0409 BU Machine Check Status Register (MC2\_STATUS)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. See also MSR0000\_0401 for the information about all of the MCi\_STATUS registers. See also MSRC001\_0015[McStatusWrEn]. This register reports these BU errors:

## Table 69: BU error descriptions

| Error Type                | 1                                                                                                                             | Enablers (MSR0000_0408 Control Bits) |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| System Data<br>Read Error | An error occurred during an attempted read of data from<br>the NB. Possible reasons include master abort and target<br>abort. |                                      |
| L2 Cache Data             | , ,                                                                                                                           | L2D_CECC, L2D_UECC,<br>L2D_PAR       |
| Data Buffer               | An error occurred in the write or victim data buffers.                                                                        | VB_PAR                               |

## **Table 69: BU error descriptions**

| Error Type       | Description                               | Enablers (MSR0000_0408 Control Bits) |
|------------------|-------------------------------------------|--------------------------------------|
| Data<br>Copyback | An error occurred on a data copyback.     | L2D_CECC, L2D_UECC,<br>L2D_PAR       |
| Tag              | An error occurred in the L2 cache tags.   | L2T_PAR, L2T_CECC,<br>L2T_UECC       |
| PDC/GTLB Parity  | A parity error occurred in a PDC or GTLB. | PDC_PAR                              |

# **Table 70: BU error signatures**

| Error                 | Access                  | [19:16]           | Erro | Code       | (see   | F3x48 for              | encodi       | ng)       | [61] | [58]       | [57]     | [54:47]       | [46] | [45] | [44]         | [43]         | [40]  |
|-----------------------|-------------------------|-------------------|------|------------|--------|------------------------|--------------|-----------|------|------------|----------|---------------|------|------|--------------|--------------|-------|
| Туре                  | Type                    | Error-<br>CodeExt | Type | 10:9<br>PP | 8<br>T | 7:4<br>RRRR            | 3:2<br>II/TT | 1:0<br>LL | UC   | ADD-<br>RV | PCC      | Synd<br>Valid | CECC | UECC | Reserve<br>d | Reserve<br>d | Scrub |
| System<br>Data        | TLB                     | 0000              | BUS  | SRC        | 0      | RD                     | MEM/<br>IO   | LG        | 1    | 1          | 0        | N             | 0    | 0    |              |              | 0     |
| Read<br>Error         | HW<br>Prefetch          | 0000              | BUS  | SRC        | 0      | Prefetch               | MEM/<br>IO   | LG        | 1    | 0          | 0        | N             | 0    | 0    |              |              | 0     |
| L2                    | TLB                     | 0000              | Mem  | -          | -      | RD                     | Gen          | L2        | 1/0  | 1          | 0        | N             | 1/0  | 1/0  |              |              | 0     |
| Cache<br>Data         | Scrub                   | 0000              | Mem  | 1          | ı      | GEN                    | Gen          | L2        | 1/0  | 1          | 0        | N             | 1/0  | 1/0  |              |              | 1     |
| Data<br>buffer        | Victim                  | 0011              | Mem  | 1          | -      | Snoop/<br>Evict        | Gen          | LG        | 1/0  | 1/0        | If<br>UC | N             | 0    | 0    |              |              | 0     |
|                       | Write                   | 0001              | Mem  | -          | -      | WR                     | Gen          | LG        | 1/0  | 1/0        | If<br>UC | N             | 0    | 0    |              |              | 0     |
| Data<br>Copy-<br>back | Snoop/<br>Evict         | 0000              | Mem  | -          | -      | Snoop/<br>Evict        | Gen          | L2        | 1/0  | 1          | If<br>UC | N             | 1/0  | 1/0  |              |              | 0     |
| Tag                   | Instr<br>Fetch          | 0010              | Mem  | -          | -      | IRD                    | Instr        | L2        | 1/0  | 1          | If<br>UC | N             | 1/0  | 1/0  |              |              | 0     |
|                       | Data<br>Fetch           | 0010              | Mem  | -          | -      | DRD                    | Data         | L2        | 1/0  | 1          | If<br>UC | N             | 1/0  | 1/0  |              |              | 0     |
|                       | TLB/<br>Snoop/<br>Evict | 0010              | Mem  | 1          | -      | RD/<br>Snoop/<br>Evict | Gen          | L2        | 1/0  | 1          | If<br>UC | N             | 1/0  | 1/0  |              |              | 0     |
|                       | Scrub                   | 0010              | Mem  | -          | ı      | GEN                    | Gen          | L2        | 1/0  | 1          | 0        | N             | 1/0  | 1/0  |              |              | 1     |
| PDC and<br>GTLB       | Instr<br>Fetch          | 0000              | TLB  | ı          | ı      | -                      | Instr        | L1        | 1/0  | 1/0        | 1/0      | N             | 0    | 0    |              |              | 0     |
| Parity<br>Error       | Data<br>Fetch           | 0000              | TLB  | -          | -      | -                      | Data         | L1        | 1/0  | 1/0        | 1/0      | N             | 0    | 0    |              |              | 0     |

# MSR0000\_040A BU Machine Check Address Register (MC2\_ADDR)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. Each of the MCi\_ADDR registers are written to by hardware and read-write accessible by software. MCi\_ADDR registers contains valid data if indicated by MCi\_STATUS[AddrV]. Table 71 defines the address register as a function of error type

Table 71: BU error data; address register

| Error Type                 | <b>Address Register Bits</b>                                                                   | Description                          |
|----------------------------|------------------------------------------------------------------------------------------------|--------------------------------------|
| System Data Read Error     | 47:6                                                                                           | Physical address                     |
| L2 Cache Data              |                                                                                                |                                      |
| Data buffers               |                                                                                                |                                      |
| Data copyback              |                                                                                                |                                      |
| Tag                        | 3:0                                                                                            | Encoded cache way                    |
|                            | 15:6 for 1-Mbyte L2<br>14:6 for 512-Kbyte L2<br>13:6 for 256-Kbyte L2<br>12:6 for 128-Kbyte L2 | Physical address                     |
| PDC/Guest TLB parity error | 47:2                                                                                           | TLB reloader access or fetch address |

# MSR0000\_040B BU Machine Check Miscellaneous Register (MC2\_MISC)

This register is read-only, reset: 0000 0000 0000 0000h.

# MSR0000\_040C LS Machine Check Control Register (MC3\_CTL)

Reset: 0000 0000 0000 0000h. All defined bits are read-write.

See section 2.13.1 [Machine Check Architecture] on page 113. For all bits, 1=Enable the specified reporting mechanism.

| Bits | Enable                                                                                                                                                                |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:2 | Reserved.                                                                                                                                                             |
|      | <b>SRDE_S: read data errors on store</b> . Report system read data errors on a store if [The BU Machine Check Control Register (MC2_CTL)] MSR0000_0408[SRDE_ALL] = 1. |
|      | SRDE_L: read data errors on load. Report system read data errors on a load if [The BU Machine Check Control Register (MC2_CTL)] MSR0000_0408[SRDE_ALL] = 1.           |

#### MSR0000\_040D LS Machine Check Status Register (MC3\_STATUS)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. See also MSR0000\_0401 for the information about all of the MCi\_STATUS registers. See also MSRC001\_0015[McStatusWrEn]. This register reports these LS errors:

**Table 72: LS error signatures** 

| Error                 | [19:16]           |      |            |        |             |              |    |    | [58]       | [57] | [54:47]       | [46] | [45] | [44]         | [43]         | [40]  |
|-----------------------|-------------------|------|------------|--------|-------------|--------------|----|----|------------|------|---------------|------|------|--------------|--------------|-------|
| Туре                  | Error-<br>CodeExt | Type | 10:9<br>PP | 8<br>T | 7:4<br>RRRR | 3:2<br>II/TT |    | UC | ADD-<br>RV | PCC  | Synd<br>Valid | CECC | UECC | Reser<br>ved | Reser<br>ved | Scrub |
| Read Data<br>on Store | 0000              | BUS  | SRC        | 0      | DWR         | MEM          | LG | 1  | 1/0        | 1/0  | N             | 0    | 0    |              |              | 0     |
| Read Data on Load     | 0000              | BUS  | SRC        | 0      | DRD         | MEM/<br>IO   | LG | 1  | 1/0        | 1/0  | N             | 0    | 0    |              |              | 0     |

#### MSR0000\_040E LS Machine Check Address Register (MC3\_ADDR)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. Each of the MCi\_ADDR registers are written to by hardware and read-write accessible by software. MCi\_ADDR registers contains valid data if indicated by MCi\_STATUS[AddrV]. The only type of error recorded by the LS machine check mechanism is a "system address out of range" or read data error for which MC3\_ADDR[47:0] store the physical address.

#### MSR0000\_040F LS Machine Check Miscellaneous Register (MC3\_MISC)

This register is read-only, reset: 0000 0000 0000 0000h.

#### MSR0000 0410 NB Machine Check Control Register (MC4 CTL)

MSR0000\_0410[31:0] is a copy of [The MCA NB Control Register] F3x40; MSR0000\_0410[63:32] are reserved. Only one of these registers exists in multi-core devices; see section 3.1.1 [Northbridge MSRs In Multi-Core Products] on page 136.

# MSR0000\_0411 NB Machine Check Status Register (MC4\_STATUS)

See section 2.13.1 [Machine Check Architecture] on page 113. MSR0000\_0411[31:0] is a copy of [The MCA NB Status Low Register] F3x48. MSR0000\_0411[63:32] is a copy of F3x4C. Only one of these registers exists in multi-core devices; see section 3.1.1 [Northbridge MSRs In Multi-Core Products] on page 136.

#### MSR0000\_0412 NB Machine Check Address Register (MC4\_ADDR)

MSR0000\_0412[31:0] is a copy of [The MCA NB Address Low Register] F3x50 and MSR0000\_0412[63:32] is a copy of F3x54. Only one of these registers exists in multi-core devices; see section 3.1.1 [Northbridge MSRs In Multi-Core Products] on page 136.

#### MSR0000\_0413 NB Machine Check Misc (Thresholding) Register (MC4\_MISC0)

MSR0000\_0413 is the first of the NB machine check miscellaneous registers. MSR0000\_0413[31:0] is expanded below; MSR0000\_0413[63:32] is a duplicate access method to NB register F3x160[31:0] ([The NB Machine Check Misc (Thresholding) Registers] F3x1[78, 70, 68, 60]).

To see the remaining NB machine check miscellaneous registers, refer to [The Machine Check Misc 4 (Thresholding) Registers 1 to 3 (MC4\_MISC[3:1])] MSRC000\_04[0A:08].

Only one of these registers exists in multi-core devices; see section 3.1.1 [Northbridge MSRs In Multi-Core

### Products] on page 136.

| Bits  | Enable                                                                                                                                                                                                                                                                                                               |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | See F3x1[78, 70, 68, 60].                                                                                                                                                                                                                                                                                            |
| 31:24 | BlkPtr: Block pointer for additional MISC registers. Read-only. Valid only when Valid field set. When non-zero, used to calculate a pointer to the extended MISC MSR block (see Section 2.13.1.1 [Machine Check Registers] on page 114) as follows: MC4_MISC1 = (MC4_MISC[BlkPtr] shifted left 3 bits) + C000_0400h. |
| 23:0  | Reserved.                                                                                                                                                                                                                                                                                                            |

#### MSR0000\_0414 FR Machine Check Control Register (MC5\_CTL)

Reset: 0000 0000 0000 0000h. All defined bits are read-write.

See section 2.13.1 [Machine Check Architecture] on page 113. For all bits, 1=Enable the specified reporting mechanism.

| Bits | Enable                                                                               |
|------|--------------------------------------------------------------------------------------|
| 63:1 | Reserved.                                                                            |
|      | CPUWDT: CPU watchdog timer. The CPU core WDT expiration (see [The CPU Watchdog Timer |
|      | Register (CpuWdTmrCfg)] MSRC001_0074).                                               |

## MSR0000\_0415 FR Machine Check Status Register (MC5\_STATUS)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. See also MSR0000\_0401 for the information about all of the MCi\_STATUS registers. See also MSRC001\_0015[McStatusWrEn]. This register reports these FR errors:

Table 73: FR error signatures

| Error                              | [19:16]           | Erro | · Code     | (see l | 3x48 <b>for</b> |              |    |    |            | [57] | [54:47]       | [46] | [45] | [44]         | [43]         | [40]  |
|------------------------------------|-------------------|------|------------|--------|-----------------|--------------|----|----|------------|------|---------------|------|------|--------------|--------------|-------|
| Туре                               | Error-<br>CodeExt | Type | 10:9<br>PP | 8<br>T | 7:4<br>RRRR     | 3:2<br>II/TT |    | UC | ADD-<br>RV | PCC  | Synd<br>Valid | CECC | UECC | Reserve<br>d | Reserve<br>d | Scrub |
| CPU<br>watchdog<br>timer<br>expire |                   | Bus  | Gen        | 1      | GEN             | Gen          | LG | 1  | 1          | 1    | No            | 0    | 0    |              |              | 0     |

#### MSR0000\_0416 FR Machine Check Address Register (MC5\_ADDR)

Cold Reset: xxxx xxxx xxxx xxxx xxxxh. See section 2.13.1 [Machine Check Architecture] on page 113. Each of the MCi\_ADDR registers are written to by hardware and read-write accessible by software. MCi\_ADDR registers contains valid data if indicated by MCi\_STATUS[AddrV]. The only type of error recorded by the FR machine check mechanism results in a load of the logical address of the next instruction after the last instruction retired in MC5\_ADDR[47:0].

#### MSR0000\_0417 FR Machine Check Miscellaneous Register (MC5\_MISC)

This register records unspecified, implementation-specific status bits when an FR machine check error is logged.

# 3.11 MSRs - MSRC000\_0xxx

# MSRC000\_0080 Extended Feature Enable Register (EFER)

Reset: 0000 0000 0000 0000h.

SKINIT Execution: 0000 0000 0000 0000h.

| Bits  | Description                                                                                                                                                                                                                                                                                                                |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:15 | MBZ.                                                                                                                                                                                                                                                                                                                       |
| 14    | <b>FFXSE:</b> fast FXSAVE/FRSTOR enable. Read-write. 1=Enables the fast FXSAVE/FRSTOR mechanism. A 64-bit operating system uses CPUID Fn[8000_0001, 0000_0001]_EDX[24] to determine the presence of this feature before enabling it. This bit is set once by the operating system and its value is not changed afterwards. |
| 13    | <b>LMSLE: long mode segment limit enable</b> . Read-write. 1=Enables the long mode segment limit check mechanism.                                                                                                                                                                                                          |
| 12    | SVME: secure virtual machine (SVM) enable. Read-write. 1=SVM features are enabled.                                                                                                                                                                                                                                         |
| 11    | <b>NXE: no-execute page enable</b> . Read-write. 1=The no-execute page protection feature is enabled.                                                                                                                                                                                                                      |
| 10    | LMA: long mode active. Read-only. 1=Indicates that long mode is active.                                                                                                                                                                                                                                                    |
| 9     | MBZ.                                                                                                                                                                                                                                                                                                                       |
| 8     | LME: long mode enable. Read-write. 1=Long mode is enabled.                                                                                                                                                                                                                                                                 |
| 7:1   | RAZ.                                                                                                                                                                                                                                                                                                                       |
| 0     | <b>SYSCALL:</b> system call extension enable. Read-write. 1=SYSCALL and SYSRET instructions are enabled. This adds the SYSCALL and SYSRET instructions which can be used in flat addressed operating systems as low latency system calls and returns.                                                                      |

# MSRC000\_0081 SYSCALL Target Address Register (STAR)

Reset: X. This register holds the target address used by the SYSCALL instruction and the code and stack segment selector bases used by the SYSCALL and SYSRET instructions.

| Bits  | Description                                 |
|-------|---------------------------------------------|
| 63:48 | SysRetSel: SYSRET CS and SS. Read-write.    |
| 47:32 | SysCallSel: SYSCALL CS and SS. Read-write.  |
| 31:0  | Target: SYSCALL target address. Read-write. |

# MSRC000\_0082 Long Mode SYSCALL Target Address Register (STAR64)

| R | acat. | $\mathbf{v}$ |
|---|-------|--------------|
| к | eset: | Х            |

| Bits | Description                                                                                           |
|------|-------------------------------------------------------------------------------------------------------|
| 63:0 | <b>LSTAR:</b> long mode target address. Read-write. Target address for 64-bit mode calling programs.  |
|      | The address stored in this register must be in canonical form (if not canonical, a #GP fault occurs). |

# MSRC000\_0083 Compatibility Mode SYSCALL Target Address Register (STARCOMPAT)

Reset: X.

| Bits | Description                                                                                           |
|------|-------------------------------------------------------------------------------------------------------|
| 63:0 | CSTAR: compatibility mode target address. Read-write. Target address for compatibility mode.          |
|      | The address stored in this register must be in canonical form (if not canonical, a #GP fault occurs). |

# MSRC000\_0084 SYSCALL Flag Mask Register (SYSCALL\_FLAG\_MASK)

Reset: X.

| Bits  | Description                                                                                                                                                                            |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RAZ.                                                                                                                                                                                   |
|       | MASK: SYSCALL flag mask. Read-write. This register holds the EFLAGS mask used by the SYSCALL instruction. 1=Clear the corresponding EFLAGS bit when executing the SYSCALL instruction. |

## MSRC000\_0100 FS Base Register (FS\_BASE)

Reset: X.

| Bits | Description                                                                                                                                                                                                                                   |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <b>FS_BASE:</b> expanded <b>FS</b> segment base. Read-write. This register provides access to the expanded 64-bit FS segment base. The address stored in this register must be in canonical form (if not canonical, a #GP fault fill occurs). |

# MSRC000\_0101 GS Base Register (GS\_BASE)

Reset: X.

| Bits | Description                                                                                           |
|------|-------------------------------------------------------------------------------------------------------|
| 63:0 | GS_BASE: expanded GS segment base. Read-write. This register provides access to the expanded          |
|      | 64-bit GS segment base. The address stored in this register must be in canonical form (if not canoni- |
|      | cal, a #GP fault fill occurs).                                                                        |

# MSRC000\_0102 Kernel GS Base Register (KernelGSbase)

Reset: X.

| Bits | Description                                                                                         |
|------|-----------------------------------------------------------------------------------------------------|
| 63:0 | KernelGSBase: kernel data structure pointer. Read-write. This register holds the kernel data struc- |
|      | ture pointer which can be swapped with the GS_BASE register using the SwapGS instruction. The       |
|      | address stored in this register must be in canonical form (if not canonical, a #GP fault occurs).   |

# MSRC000\_0103 Auxiliary Time Stamp Counter Register (TSC\_AUX)

| Reset: 0000 0000 0000 0000h. |                                                                                                                                                                                                                                |  |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits                         | Description                                                                                                                                                                                                                    |  |
| 63:32                        | Reserved.                                                                                                                                                                                                                      |  |
|                              | <b>TscAux: auxiliary time stamp counter data</b> . Read-write. It is expected that this is initialized by privileged software to a meaningful value, such as a processor ID. This value is returned in the RDTSCP instruction. |  |

#### MSRC000 04[0A:08] Machine Check Misc 4 (Thresholding) Registers 1 to 3 (MC4 MISC[3:1])

MSRC000\_04[0A:08] are the block of extended NB machine check miscellaneous registers.

MSRC000\_04[0A:08][31:0] are mapped identically to MSR0000\_0413[31:0]; MSRC000\_04[0A:08][63:32] are duplicate access methods to the corresponding registers of F3x1[78, 70, 68, 60][31:0].

Only one of these register blocks exists in multi-core devices; see section 3.1.1 [Northbridge MSRs In Multi-Core Products] on page 136.

| Bits  | Description                     |
|-------|---------------------------------|
| 63:32 | See F3x1[78, 70, 68, 60][31:0]. |
| 31:0  | See MSR0000_0413[31:0].         |

#### 3.12 MSRs - MSRC001\_0xxx

# MSRC001\_00[03:00] Performance Event Select Register (PERF\_CTL[3:0])

Reset: xxxx xxxx xxxx xxxxh. PERF\_CTL[3:0] are used to specify the events counted by the [The Performance Event Counter Registers (PERF\_CTR[3:0])] MSRC001\_00[07:04] and to control other aspects of their operation. Each performance counter supported has a corresponding event-select register that controls its operation. Section 3.14 [Performance Counter Events] on page 337 shows the events and unit masks supported by the processor.

To accurately start counting with the write that enables the counter, disable the counter when changing the event and then enable the counter with a second MSR write.

The edge count mode increments the counter when a transition happens on the monitored event. If the event selected is changed without disabling the counter, an extra edge is falsely detected when the first event is a static 0 and the second event is a static one. To avoid this false edge detection, disable the counter when changing the event and then enable the counter with a second MSR write.

The performance counter registers can be used to track events in the Northbridge. Northbridge events include all memory controller events, crossbar events, and HyperTransport<sup>TM</sup> interface events as documented in 3.14.7, 3.14.8, and 3.14.9. Monitoring of Northbridge events should only be performed by one core. If a Northbridge event is selected using one of the Performance Event-Select registers in any core of a multi-core processor, then a Northbridge performance event cannot be selected in the same Performance Event Select register of any other core.

Care must be taken when measuring Northbridge or other non-processor-specific events under conditions where the processor may go into halt mode during the measurement period. For instance, one may wish to monitor DRAM traffic due to DMA activity from a disk or graphics adaptor. This entails running some event counter monitoring code on the processor, where such code accesses the counters at the beginning and end of the measurement period, or may even sample them periodically throughout the measurement period. Such code typically gives up the processor during each measurement interval. If there is nothing else for the OS to run on that particular processor at that time, it may halt the processor until it is needed. Under these circumstances, the clock for the counter logic may be stopped, hence the counters would not count the events of interest. To prevent this, simply run a low-priority background process that keeps the processor busy during the period of interest.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 63:42 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 41    | <b>HostOnly: host only counter.</b> Read-write. 1=Events are only counted when the processor is in host mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 40    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 40    | <b>GuestOnly: guest only counter.</b> Read-write. 1=Events are only counted when the processor is in guest mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 39:36 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 35:32 | EventSelect[11:8]: performance event select. Read-write. See EventSelect[7:0].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:24 | CntMask: counter mask. Read-write. Controls the number of events counted per clock cycle.  Oh The corresponding PERF_CTR[3:0] register is incremented by the number of events occurring in a clock cycle. Maximum number of events in one cycle is 3.  Olh-O3h When Inv = 0, the corresponding PERF_CTR[3:0] register is incremented by 1, if the number of events occurring in a clock cycle is greater than or equal to the CntMask value. When Inv = 1, the corresponding PERF_CTR[3:0] register is incremented by 1, if the number of events occurring in a clock cycle is less than CntMask value.  O4h-FFh Reserved. |
| 23    | Inv: invert counter mask. Read-write. See CntMask.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 22    | En: enable performance counter. Read-write. 1= Performance event counter is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 21    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 20    | <b>Int: enable APIC interrupt.</b> Read-write. 1=APIC performance counter LVT interrupt is enabled to generate an interrupt when the performance counter overflows.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 19    | Must be low. Read-write.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 18    | Edge: edge detect. Read-write. 0=Level detect. 1=Edge detect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 17    | <b>OS: OS mode.</b> Read-write. 1=Events are only counted when CPL=0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 16    | User: user mode. Read-write. 1=Events only counted when CPL>0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| 15:8 | UnitMask: event qualification. Read-write. Each UnitMask bit further specifies or qualifies the       |
|------|-------------------------------------------------------------------------------------------------------|
|      | event specified by EventSelect. All events selected by UnitMask are simultaneously monitored.         |
|      | Unless otherwise stated, the UnitMask values shown may be combined (logically ORed) to select any     |
|      | desired combination of the sub-events for a given event. In some cases, certain combinations can      |
|      | result in misleading counts, or the UnitMask value is an ordinal rather than a bit mask. These situa- |
|      | tions are described where applicable, or should be obvious from the event descriptions. For events    |
|      | where no UnitMask table is shown, the UnitMask is not applicable and may be set to zeros.             |
| 7:0  | EventSelect[7:0]: event select. Read-write. This field, along with EventSelect[11:8] above, com-      |
|      | bine to form the 12-bit event select field, EventSelect[11:0]. EventSelect specifies the              |
|      | event or event duration in a processor unit to be counted by the corresponding                        |
|      | PERF_CTR[3:0] register. The events are specified in section 3.14 [Performance Counter                 |
|      | Events] on page 337. Some events are reserved; when a reserved event is selected, the                 |
|      | results are undefined.                                                                                |
|      |                                                                                                       |

### MSRC001\_00[07:04] Performance Event Counter Registers (PERF\_CTR[3:0])

Reset: 0000 xxxx xxxx xxxxh. The processor provides four 48-bit performance counters. Each counter can monitor a different event specified by [The Performance Event Select Register (PERF\_CTL[3:0])] MSRC001\_00[03:00]. The accuracy of the counters is not ensured.

Performance counters are used to count specific processor events, such as data-cache misses, or the duration of events, such as the number of clocks it takes to return data from memory after a cache miss. During event counting, the processor increments the counter when it detects an occurrence of the event. During duration measurement, the processor counts the number of processor clocks it takes to complete an event. Each performance counter can be used to count one event, or measure the duration of one event at a time.

In addition to the RDMSR instruction, the PERF\_CTR[3:0] registers can be read using a special read performance-monitoring counter instruction, RDPMC. The RDPMC instruction loads the contents of the PERF\_CTR[3:0] register specified by the ECX register, into the EDX register and the EAX register.

Writing the performance counters can be useful if there is an intention for software to count a specific number of events, and then trigger an interrupt when that count is reached. An interrupt can be triggered when a performance counter overflows. Software should use the WRMSR instruction to load the count as a two's-complement negative number into the performance counter. This causes the counter to overflow after counting the appropriate number of times.

The performance counters are not assured of producing identical measurements each time they are used to measure a particular instruction sequence, and they should not be used to take measurements of very small instruction sequences. The RDPMC instruction is not serializing, and it can be executed out-of-order with respect to other instructions around it. Even when bound by serializing instructions, the system environment at the time the instruction is executed can cause events to be counted before the counter value is loaded into EDX:EAX.

| Bits  | Description                                                                                |
|-------|--------------------------------------------------------------------------------------------|
| 63:48 | RAZ.                                                                                       |
| 47:0  | CTR: performance counter value. Read-only. Returns the current value of the event counter. |

# MSRC001\_0010 System Configuration Register (SYS\_CFG)

|                              | 001_0010 System 0 0111-guarden 110guarden (8 1 % _ 0 1 0 )                                                                                                                                                                                                                                                                                                                                                |  |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Reset: 0000 0000 0002 0600h. |                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| Bits                         | Description                                                                                                                                                                                                                                                                                                                                                                                               |  |
| 63:23                        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 22                           | <b>Tom2ForceMemTypeWB: top of memory 2 memory type write back</b> . Read-write. 1=The default memory type of memory between 4GB and TOM2 is write back instead of the memory type defined by [The MTRR Default Memory Type Register (MTRRdefType)] MSR0000_02FF[MemType]. For this bit to have any effect, MSR0000_02FF[MtrrDefTypeEn] must be 1. MTRRs and PAT can be used to override this memory type. |  |
| 21                           | MtrrTom2En: MTRR top of memory 2 enable. Read-write. 0=[The Top Of Memory 2 Register (TOM2)] MSRC001_001D is disabled. 1=This register is enabled.                                                                                                                                                                                                                                                        |  |
| 20                           | MtrrVarDramEn: MTRR variable DRAM enable. Read-write. 0=[The Top Of Memory Register (TOP_MEM)] MSRC001_001A and IORRs are disabled. 1=These registers are enabled. This bit should be set by BIOS.                                                                                                                                                                                                        |  |
| 19                           | MtrrFixDramModEn: MTRR fixed RdDram and WrDram modification enable. Read-write. 0=Reads from the RdDram and WrDram bits of [The Fixed-Size MTRRs (MTRRfixn)] MSR0000_02[6F:68, 59, 58, 50] return 00b and writes of those bits are ignored. 1=These bits are read-write accessible. This bit should be set to 1 during BIOS initialization of the fixed MTRRs, then cleared to 0 for operation.           |  |
| 18                           | MtrrFixDramEn: MTRR fixed RdDram and WrDram attributes enable. Read-write. 1=Enables the RdDram and WrDram attributes in [The Fixed-Size MTRRs (MTRRfixn)] MSR0000_02[6F:68, 59, 58, 50]. This bit should be set by BIOS.                                                                                                                                                                                 |  |
| 17                           | <b>SysUcLockEn:</b> system lock command enable. Read-write. 1=Transactions to the coherent fabric support the lock command. This is normally enabled in multi-core systems and disabled in single core systems.                                                                                                                                                                                           |  |
| 16                           | <b>ChxToDirtyDis:</b> change to dirty disable. Read-write. 1=Disables change-to-dirty commands, evicts line from DC instead.                                                                                                                                                                                                                                                                              |  |
| 15:11                        | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 10                           | <b>SetDirtyEnO: clean-to-dirty command for O-&gt;M state transition enable</b> . Read-write. 1=Enables generating write probes when transitioning a cache line from Owned to Modified.                                                                                                                                                                                                                    |  |
| 9                            | <b>SetDirtyEnS: shared-to-dirty command for S-&gt;M state transition enable</b> . Read-write. 1=Enables generating write probes when transitioning a cache line from Shared to Modified.                                                                                                                                                                                                                  |  |
| 8                            | <b>SetDirtyEnE:</b> shared-to-dirty command for E->M state transition enable. Read-write. 1=Enables generating write probes when transitioning a cache line from Exclusive to Modified.                                                                                                                                                                                                                   |  |
| 7:0                          | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |  |

# MSRC001\_0015 Hardware Configuration Register (HWCR)

|   | Reset: 0000 0000 0000 0010h. |             |
|---|------------------------------|-------------|
|   | Bits                         | Description |
| Ī | 63:25                        | Reserved.   |

| 24 | <b>TscFreqSel: TSC frequency select</b> . Read-write. 0=The TSC increments at the rate of the NCLK frequency. 1=The TSC increments at the rate of the core P-state 0 COF specified by MSRC001_0064 at the time this bit is set by software. Changing the state of this bit after setting it results in undefined behaviour from the TSC. Changing the state of MSRC001_0064 after setting this bit has no effect on the TSC rate. BIOS should program this bit to 1.                                                                                                                                                                       |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 | <b>ForceUsRdWrSzPrb:</b> force probes for upstream RdSized and WrSized. Read-write. 1=Forces probes on all upstream read-sized and write-sized transactions except for display refresh transactions. This bit is shared between all cores in a node.                                                                                                                                                                                                                                                                                                                                                                                       |
| 22 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 21 | <b>MisAlignSseDis: misaligned SSE mode disable</b> . Read-write. 1=Disables misaligned SSE mode. If this is set, then CPUID Fn8000_0001_ECX[MisAlignSse] is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 20 | <b>IoCfgGpFault: IO-space configuration causes a GP fault</b> . Read-write. 1=IO-space accesses to configuration space cause a GP fault. The fault is triggered if any part of the IO read/write address range is between CF8h and CFFh, inclusive. These faults only result from single IO instructions, not to string and REP IO instructions. This fault takes priority over the IO trap mechanism described by [The IO Trap Control Register (SMI_ON_IO_TRAP_CTL_STS)] MSRC001_0054.                                                                                                                                                   |
| 19 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 18 | McStatusWrEn: machine check status write enable. Read-write. 1=Writes by software to MCi_STATUS (see section 2.13.1 [Machine Check Architecture] on page 113) do not cause general protection faults; such writes update all implemented bits in these registers. 0=Writing a non-zero pattern to these registers causes a general protection fault. This also affects bits in [The NB Machine Check Misc (Thresholding) Registers] F3x1[78, 70, 68, 60].                                                                                                                                                                                  |
|    | McStatusWrEn can be used to debug machine check interrupt handlers. When McStatusWrEn is set, privileged software can write non-zero values to the specified registers without generating exceptions, and then simulate a machine check using the "int 18" instruction. Setting a reserved bit in these registers does not generate an exception when this mode is enabled. However, setting a reserved bit may result in undefined behavior.                                                                                                                                                                                              |
| 17 | Wrap32Dis: 32-bit address wrap disable. Read-write. 1=Disable 32-bit address wrapping. Software can use Wrap32Dis to access physical memory above 4 Gbytes without switching into 64-bit mode. To do so, software should write a greater-than 4 Gbyte address to [The FS Base Register (FS_BASE)] MSRC000_0100 and [The GS Base Register (GS_BASE)] MSRC000_0101. Then it would address ±2 Gbytes from one of those bases using normal memory reference instructions with a FS or GS override prefix. However, the INVLPG, FST, and SSE store instructions generate 32-bit addresses in legacy mode, regardless of the state of Wrap32Dis. |
| 16 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15 | SseDis: SSE instructions disable. Read-write. 1=Disables SSE instructions. If this is set, then CPUID Fn[8000_0001, 0000_0001]_EDX[SSE, SSE2], CPUID Fn0000_0001_ECX[SSE3], and CPUID Fn8000_0001_ECX[SSE4A] are 0.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 14 | <b>RsmSpCycDis: RSM special bus cycle disable</b> . Read-write; read-only if SmmLock=1. 0=A link special bus cycle, SMIACK, is generated on a resume from SMI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13 | SmiSpCycDis: SMI special bus cycle disable. Read-write; read-only if SmmLock=1. 0=A link special bus cycle, SMIACK, is generated when an SMI interrupt is taken.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 12 | HltXSpCycEn: halt-exit special bus cycle enable. Read-write. 1=A link special bus cycle is generated when exiting from the halt state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| 11  | LimitCpuidStdMaxVal. Read-write. 1=Limit CPUID standard maximum value, returned by CPUID Fn0000_0000_EAX (see CPUID Fn[8000_0000, 0000_0000]), to 1.                                                                                                                                                                                               |  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 10  | MonMwaitUserEn: MONITOR/MWAIT user mode enable. Read-write. 1=The MONITOR and MWAIT instructions are supported in all privilege levels. 0=The MONITOR and MWAIT instructions are supported only in privilege level 0; these instructions in privilege levels 1 to 3 cause a #UD exception. The state of this bit is ignored if MonMwaitDis is set. |  |
| 9   | <b>MonMwaitDis: MONITOR and MWAIT disable</b> . Read-write. 1=The MONITOR and MWAIT opcodes become invalid. This affects what is reported back through CPUID Fn0000_0001_ECX[Monitor].                                                                                                                                                             |  |
| 8   | IgnneEm: IGNNE port emulation enable. Read-write. 1=Enable emulation of IGNNE port.                                                                                                                                                                                                                                                                |  |
| 7:5 | Reserved.                                                                                                                                                                                                                                                                                                                                          |  |
| 4   | <b>INVD_WBINVD: INVD to WBINVD conversion</b> . Read-write. 1=Convert INVD to WBINVD. This bit is required to be set when the L3 cache is enabled.                                                                                                                                                                                                 |  |
| 3   | <b>TlbCacheDis: cacheable memory disable</b> . Read-write. 1=Disable performance improvement that assumes that the PML4, PDP, PDE and PTE entries are in cacheable memory. Operating systems that maintain page tables in uncacheable memory (UC memory type) must set the TlbCacheDis bit to insure proper operation.                             |  |
| 2   | SBZ.                                                                                                                                                                                                                                                                                                                                               |  |
| 1   | SlowFence: slow SFENCE enable. Read-write. 1=Enable slow sfence.                                                                                                                                                                                                                                                                                   |  |
| 0   | SmmLock: SMM code lock. Read; write-1-only. 1=SMM configuration registers SMM_BASE, SMMAddr, SMMMask (all except for SMMMask[TClose:AClose]), and SMM_CTL are read-only and SMI interrupts are not intercepted in SVM.                                                                                                                             |  |

# MSRC001\_00[18, 16] IO Range Registers Base (IORR\_BASE[1:0])

Reset: X. MSRC001\_0016 and MSRC001\_0017 combine to specify the first IORR range and MSRC001\_0018 and MSRC001\_0019 combine to specify the second IORR range. A CPU access--with address CPUAddr--is determined to be within IORR address range if the following equation is true: CPUAddr[47:12] & PhyMask[47:12] == PhyBase[47:12] & PhyMask[47:12].

| Bits  | Description                                                                                                                                                |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:48 | RAZ.                                                                                                                                                       |
| 47:12 | PhyBase: physical base address. Read-write.                                                                                                                |
| 11:5  | RAZ.                                                                                                                                                       |
| 4     | <b>RdMem: read from memory</b> . Read-write. 1=Read accesses to the range are directed to system memory. 0=Read accesses to the range are directed to IO.  |
| 3     | <b>WrMem: write to memory</b> . Read-write. 1=Write accesses to the range are directed to system memory. 0=Write accesses to the range are directed to IO. |
| 2:0   | RAZ.                                                                                                                                                       |

## MSRC001\_00[19, 17] IO Range Registers Mask (IORR\_MASK[1:0])

| Reset: X. See MSRC001_00[18, 16]. |                                                                                   |  |
|-----------------------------------|-----------------------------------------------------------------------------------|--|
| Bits                              | Description                                                                       |  |
| 63:48                             | RAZ.                                                                              |  |
| 47:12                             | PhyMask: physical address mask. Read-write.                                       |  |
| 11                                | Valid. Read-write. 1=The pair of registers that specifies an IORR range is valid. |  |
| 10:0                              | RAZ.                                                                              |  |

# MSRC001\_001A Top Of Memory Register (TOP\_MEM)

| Reset: X. |                                                                                                                                                                                                                                                        |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits      | Description                                                                                                                                                                                                                                            |
| 63:48     | RAZ.                                                                                                                                                                                                                                                   |
|           | <b>TOM[47:23]: top of memory</b> . Read-write. Specifies the address that divides between MMIO and DRAM. This value is normally placed below 4G. From TOM to 4G is MMIO; below TOM is DRAM. See section 2.9.3 [Access Type Determination] on page 107. |
| 22:0      | RAZ.                                                                                                                                                                                                                                                   |

# MSRC001\_001D Top Of Memory 2 Register (TOM2)

| Reset: X. |                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits      | Description                                                                                                                                                                                                                                                                                                                                                             |
| 63:48     | RAZ.                                                                                                                                                                                                                                                                                                                                                                    |
|           | <b>TOM2[47:23]: second top of memory</b> . Read-write. Specifies the address divides between MMIO and DRAM. This value is normally placed above 4G. From 4G to TOM2 - 1 is DRAM; TOM2 and above is MMIO. See section 2.9.3 [Access Type Determination] on page 107. This register is enabled by [The System Configuration Register (SYS_CFG)] MSRC001_0010[MtrrTom2En]. |
| 22:0      | RAZ.                                                                                                                                                                                                                                                                                                                                                                    |

## MSRC001\_001F Northbridge Configuration Register (NB\_CFG)

Reset: 0000 0000 0000 0008h. Software is required to perform a read-modify-write in order to change any of the values in this register. This register is accessible through F3x[8C:88] as well. Only one of these registers exists in multi-core devices; see section 3.1.1 [Northbridge MSRs In Multi-Core Products] on page 136.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:55 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                           |
| 54    | InitApicIdCpuIdLo. Read-write. 0=Initial value of APIC20[ApicId[7:0]] is {CpuCoreNum[1:0], 000b, F0x60[NodeId[2:0]]}. 1=Initial value of APIC20[ApicId[7:0]] is {000b, F0x60[NodeId[2:0]], CpuCoreNum[1:0]}. See section 2.9.2 [CPU Cores and Downcoring] on page 107 for information about CpuCoreNum. This bit should always be set by BIOS; it should be set before F0x60[NodeId] is programmed. |
| 53:51 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                           |
| 50    | <b>DisOrderRdRsp</b> . Read-write. 1=Disables ordered responses to IO link read requests. See section 2.7.8 [Response Ordering] on page 59.                                                                                                                                                                                                                                                         |

| 49:47                                                                                                                                                                                                                                                             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 46                                                                                                                                                                                                                                                                | EnableCf8ExtCfg: enable CF8 extended configuration cycles. Read-write. 1=Allows the IO configuration space access method, IOCF8 and IOCFC, to be used to generate extended configuration cycles by enabling IOCF8[27:24].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| DisUsSysMgtReqToNcHt: disable upstream system management request to link. Read 1=Disables downstream reflection of upstream STPCLK and x86 legacy input system manacommands (in order to work around potential deadlock scenarios related to reflection regions). |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 44:37                                                                                                                                                                                                                                                             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 36                                                                                                                                                                                                                                                                | <b>DisDatMsk: disable data mask</b> . Read-write. 1=Disables DRAM data masking function; all write requests that are less than one cacheline, a DRAM read is performed before writing the data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 35:32                                                                                                                                                                                                                                                             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31                                                                                                                                                                                                                                                                | <b>DisCohLdtCfg: disable coherent link configuration accesses</b> . Read-write. 1=Disables automatic routing of PCI configuration accesses to the processor configuration registers; PCI configuration space accesses which fall within the hard-coded range reserved for processor configuration-space registers are instead routed to the IO link specified by [The Configuration Map Registers] F1x[EC:E0]. This can be used to effectively hide the configuration registers from software. It can also be used to provide a means for an external chip to route processor configuration accesses according to a scheme other than the hard-coded version. When used, this bit needs to be set on all processors in a system. PCI configuration accesses should not be generated if this bit is not set on all processors. |
| 30:10                                                                                                                                                                                                                                                             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9                                                                                                                                                                                                                                                                 | <b>DisRefUseFreeBuf:</b> disable display refresh to use free list buffers. Read-write. 1=In non-IFCM disable display refresh requests from using free list buffers and in IFCM disable isochronous requests from using free list buffers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8:0                                                                                                                                                                                                                                                               | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

# MSRC001\_0022 Machine Check Exception Redirection Register

Reset: 0000 0000 0000 0000h. This register can be used to redirect machine check exceptions (MCEs) to SMIs or vectored interrupts. If both RedirSmiEn and RedirVecEn are set, then undefined behavior results.

| Bits  | Description                                                                                                                                                                              |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:10 | Reserved.                                                                                                                                                                                |
| 9     | <b>RedirSmiEn</b> . Read-write. 1=Redirect MCEs (that are directed to this CPU core) to generate an SMI-trigger IO cycle via MSRC001_0056. The status is stored in SMMFEC4[MceRedirSts]. |
| 8     | <b>RedirVecEn</b> . Read-write. 1=Redirect MCEs (that are directed to this CPU core) to generate a vectored interrupt, using the interrupt vector specified in RedirVector.              |
| 7:0   | RedirVector. Read-write. See RedirVecEn.                                                                                                                                                 |

### MSRC001\_00[35:30] Processor Name String Registers

Reset: 0000 0000 0000 0000h. These registers holds the CPUID name string in ASCII. The state of these registers are returned by CPUID instructions, CPUID Fn8000\_000[4, 3, 2]. BIOS should set these registers to the product name for the processor as provided by AMD. Each register contains a block of 8 ASCII characters; the least byte corresponds to the first ASCII character of the block; the most-significant byte corresponds to the last character of the block. MSRC001\_0030 contains the first block of the name string; MSRC001\_0035 contains the last block of the name string.

| В  | Bits | Description                |
|----|------|----------------------------|
| 6. | 3:0  | CpuNameString. Read-write. |

#### MSRC001 00[49:44] Machine Check Control Mask Registers (MCi CTL MASK)

| Reset: | MSRC001_0044: 0000 0000 0000 0080h. | MSRC001_0047: 0000 0000 0000 0000h. |
|--------|-------------------------------------|-------------------------------------|
|        | MSRC001_0045: 0000 0000 0000 0080h. | MSRC001_0048: 0000 0000 0000 0000h. |
|        | MSRC001_0046: 0000 0000 0000 0200h. | MSRC001_0049: 0000 0000 0000 0000h. |

Regarding MSRC001\_0048, only one of these registers exists in multi-core devices; see section 3.1.1 [Northbridge MSRs In Multi-Core Products] on page 136. BIOS is recommended to mask HT retries (F3x40[RtryHt3En, RtryHt1En, RtryHt0En]) if the OS is not capable of distinguishing that HT retries are normal operation.

These mask registers should be set up prior to enabling errors in MCi\_CTL registers. BIOS must not clear MSK bits that are reset to 1.

|   | Bits | Description                                                                                           |
|---|------|-------------------------------------------------------------------------------------------------------|
| Ī | 63:0 | MSK: Control Register Masks. Bits are read-only or read-write, corresponding to the attribute of      |
|   |      | the same bit in MCi_CTL. 1=Disable error logging in MCi_STATUS and MCi_ADDR for errors rep-           |
|   |      | resented by the corresponding bit in MCi_CTL. See section 2.13.1 [Machine Check Architecture] on      |
|   |      | page 113. Disabling logging is equivalent to disabling error detection, and prevents error responses. |

### MSRC001\_00[53:50] IO Trap Registers (SMI\_ON\_IO\_TRAP\_[3:0])

Reset: 0000 0000 0000 0000h. MSRC001\_00[53:50] and MSRC001\_0054 provide a mechanism for executing the SMI handler if a an access to one of the specified addresses is detected. Access address and access type checking is done before IO instruction execution. If the access address and access type match one of the specified IO address and access types, then: (1) the IO instruction is not executed; (2) any breakpoint, other than the single-step breakpoint, set on the IO instruction is not taken (the single-step breakpoint is taken after resuming from SMM); and (3) the SMI-trigger IO cycle specified by MSRC001\_0056. The status is stored in SMMFEC4[IoTrapSts].

IO-space configuration accesses are special IO accesses. An IO access is defined as an IO-space configuration access when IO instruction address bits[31:0] are CFCh, CFDh, CFEh, or CFFh when IO-space configuration is enabled (IOCF8[ConfigEn]). The access address for a configuration space access is the current value of IOCF8[BusNo, Device, Function, RegNo]. The access address for an IO access that is not a configuration access is equivalent to the IO instruction address, bits[31:0].

The access address is compared with SmiAddr, and the instruction access type is compared with the enabled access types defined by ConfigSMI, SmiOnRdEn, and SmiOnWrEn. Access address bits[23:0] can be masked with SmiMask.

IO and configuration space trapping to SMI applies only to single IO instructions; it does not apply to string and REP IO instructions.

| Bits  | Description                                                                                      |  |
|-------|--------------------------------------------------------------------------------------------------|--|
| 63    | SmiOnRdEn: enable SMI on IO read. Read-write. 1=Enables SMI generation on a read access.         |  |
| 62    | SmiOnWrEn: enable SMI on IO write. Read-write. 1=Enables SMI generation on a write access.       |  |
| 61    | ConfigSmi: configuration space SMI. Read-write. 1=Configuration access. 0=IO access (that is not |  |
|       | an IO-space configuration access).                                                               |  |
| 60:56 | SBZ.                                                                                             |  |
| 55:32 | SmiMask[23:0]. Read-write. SMI IO trap mask. 0=Mask address bit. 1=Do not mask address bit.      |  |
| 31:0  | SmiAddr[31:0]. Read-write. SMI IO trap address.                                                  |  |

# MSRC001\_0054 IO Trap Control Register (SMI\_ON\_IO\_TRAP\_CTL\_STS)

Reset: 0000 0000 0000 0000h. For each of the SmiEn bits below, 1=The trap specified by the corresponding MSR is enabled. See also MSRC001\_00[53:50].

| Bits  | Description                                                                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RAZ.                                                                                                                                        |
| 31:16 | SBZ.                                                                                                                                        |
| 15    | <b>IoTrapEn: IO trap enable</b> . Read-write. 1=Enable IO and configuration space trapping specified by MSRC001_00[53:50] and MSRC001_0054. |
| 14:8  | SBZ.                                                                                                                                        |
| 7     | SmiEn_3: SMI enable for the trap specified by MSRC001_0053. Read-write.                                                                     |
| 6     | SBZ.                                                                                                                                        |
| 5     | SmiEn_2: SMI enable for the trap specified by MSRC001_0052. Read-write.                                                                     |
| 4     | SBZ.                                                                                                                                        |
| 3     | SmiEn_1: SMI enable for the trap specified by MSRC001_0051. Read-write.                                                                     |
| 2     | SBZ.                                                                                                                                        |
| 1     | SmiEn_0: SMI enable for the trap specified by MSRC001_0050. Read-write.                                                                     |
| 0     | SBZ.                                                                                                                                        |

#### MSRC001\_0055 Interrupt Pending and CMP-Halt Register

Reset: 0000 0000 0000 0000h. This register is used to specify messages that the processor generates under certain conditions, that target the IO Hub. One purpose is to ensure that the IO Hub can wake the processor out of the stop-grant state when there is a pending interrupt. Otherwise, it is possible for the processor to remain in the stop-grant state while an interrupt is pending in the processor. This is accomplished by sending a message to the IO hub to indicate that the interrupt is pending. There are two message types: a programmable IO-space message and the link INT\_PENDING message defined by the link specification.

If the IO hub does not support the INT\_PENDING message, the IO space message should be selected by IntP-ndMsg. When this is enabled, the check for a pending interrupt is performed at the end of each IO instruction. If there is a pending interrupt and STPCLK is asserted, the processor executes a byte-size IO access as specified by IORd, IOMsgAddr, and IOMsgData.

If the IO hub supports the INT\_PENDING message, it should be selected by IntPndMsg. The check for a pending interrupt is performed while in the stop-grant state or when entering the stop-grant state. If there is a pending interrupt, the processor broadcasts the INT\_PENDING message. An INT\_PENDING message may not be generated for arbitrated interrupts in multi-node systems.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 63:32 | RAZ.                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 31:28 | SBZ.                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 27    | SmiOnCmpHalt: SMI on CPU-core multi-processing halt. Read-write. 1=When all CPU cores of the processor have entered the halt state, the processor generates an SMI-trigger IO cycle as specified by IORd, IOMsgData, and IOMsgAddr. When this bit is set C1eOnCmpHalt and IntPndMsg must be 0, otherwise the behavior is undefined. The status is stored in SMMFEC4[SmiOnCmpHaltSts]. |  |  |
| 26    | IORd: IO Read. Read-write. 1=IO read; 0=IO write.                                                                                                                                                                                                                                                                                                                                     |  |  |
| 25    | <b>IntrPndMsg: interrupt pending message</b> . Read-write. Selects the interrupt pending message type. 0=Link-defined INT_PENDING message; 1=Programmable SMI-trigger IO-space message. The status is stored in SMMFEC4[IntPendSmiSts].                                                                                                                                               |  |  |
| 24    | <b>IntrPndMsgDis: interrupt pending message disable</b> . Read-write. Disable generating the interrupt pending message specified by IntrPndMsg.                                                                                                                                                                                                                                       |  |  |
| 23:16 | <b>IOMsgData: IO message data</b> . Read-write. IO write message data. This field is only used if IORd specifies an IO write message.                                                                                                                                                                                                                                                 |  |  |
| 15:0  | IOMsgAddr: IO message address. Read-write. IO space message address.                                                                                                                                                                                                                                                                                                                  |  |  |

## MSRC001\_0056 SMI Trigger IO Cycle Register

Reset: 0000 0000 0000 0000h. See section 2.14.2.3 [SMI Sources And Delivery] on page 125. This register specifies an IO cycle that may be generated when a local SMI trigger event occurs. If IoCycleEn is set and there is a local SMI trigger event, then the IO cycle generated is a byte read or write, based on IoRd, to address IoPortAddress. If the cycle is a write, then IoData contains the data written. If the cycle is a read, the value read is discarded. If IoCycleEn is clear and a local SMI trigger event occurs, then undefined behavior results.

| Bits  | Description                                                                                    |  |  |
|-------|------------------------------------------------------------------------------------------------|--|--|
| 63:27 | Reserved.                                                                                      |  |  |
| 26    | oRd: IO Read. Read-write. 1=IO read; 0=IO write.                                               |  |  |
| 25    | IoCycleEn: IO cycle enable. Read-write. 1=The SMI trigger IO cycle is enabled to be generated. |  |  |
| 24    | Reserved.                                                                                      |  |  |
| 23:16 | IoData. Read-write.                                                                            |  |  |
| 15:0  | IoPortAddress. Read-write.                                                                     |  |  |

#### MSRC001\_0058 MMIO Configuration Base Address Register

Reset: xxxx xxxx xxxx xxx0h. See section 2.11 [Configuration Space] on page 112 for a description of MMIO configuration space. All CPU cores of all processors should be programmed with the same value of this register.

| Bits  | Description |
|-------|-------------|
| 63:48 | RAZ.        |

| 47:20 | MmioCfgBaseAddr[47:20]: MMIO configuration base address bits[47:20]. Read-write. Specifies the base address of the MMIO configuration range. The size of the MMIO configuration-space address range is specified by BusRange.                |       |             |          |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------|----------|
| 19:6  | RAZ.                                                                                                                                                                                                                                         |       |             |          |
| 5:2   | :2 <b>BusRange:bus range identifier</b> . Read-write. This specifies the number of busses in the MMIC configuration space range. The size of the MMIO configuration space is 1 Mbyte times the num busses. This field is encoded as follows: |       |             | _        |
|       | Bits                                                                                                                                                                                                                                         | Buses | <b>Bits</b> | Buses    |
|       | 0h                                                                                                                                                                                                                                           | 1     | 8h          | 256      |
|       | 1h                                                                                                                                                                                                                                           | 2     | 9h          | Reserved |
|       | 2h                                                                                                                                                                                                                                           | 4     | Ah          | Reserved |
|       | 3h                                                                                                                                                                                                                                           | 8     | Bh          | Reserved |
|       | 4h                                                                                                                                                                                                                                           | 16    | Ch          | Reserved |
|       | 5h                                                                                                                                                                                                                                           | 32    | Dh          | Reserved |
|       | 6h                                                                                                                                                                                                                                           | 64    | Eh          | Reserved |
|       | 7h                                                                                                                                                                                                                                           | 128   | Fh          | Reserved |
| 1     | <b>TrapAccess</b> . Read-write. 1=MMIO configuration space SMI traps specified by MSRC001_0059 and MSRC001_00[5D:5A] are enabled.                                                                                                            |       |             |          |
| 0     | Enable. 1=MMIO configuration space is enabled.                                                                                                                                                                                               |       |             |          |

# MSRC001\_0059 MMIO Configuration Trap Control Register

Reset: 0000 0000 0000 0000h. See MSRC001\_00[5D:5A] for details about this function.

| Bits  | Description                                                                                                |  |  |  |
|-------|------------------------------------------------------------------------------------------------------------|--|--|--|
| 63:32 | RAZ.                                                                                                       |  |  |  |
| 31:8  | SBZ.                                                                                                       |  |  |  |
| 7     | McWrSmiEn3: MMIO configuration write SMI enable for trap specified by MSRC001_005D. Read-write. 1=Enabled. |  |  |  |
| 6     | McRdSmiEn3: MMIO configuration read SMI enable for trap specified by MSRC001_005D. Read-write. 1=Enabled.  |  |  |  |
| 5     | McWrSmiEn2: MMIO configuration write SMI enable for trap specified by MSRC001_005C. Read-write. 1=Enabled. |  |  |  |
| 4     | McRdSmiEn2: MMIO configuration read SMI enable for trap specified by MSRC001_005C. Read-write. 1=Enabled.  |  |  |  |
| 3     | McWrSmiEn1: MMIO configuration write SMI enable for trap specified by MSRC001_005B. Read-write. 1=Enabled. |  |  |  |
| 2     | McRdSmiEn1: MMIO configuration read SMI enable for trap specified by MSRC001_005B. Read-write. 1=Enabled.  |  |  |  |
| 1     | McWrSmiEn0: MMIO configuration write SMI enable for trap specified by MSRC001_005A. Read-write. 1=Enabled. |  |  |  |
| 0     | McRdSmiEn0: MMIO configuration read SMI enable for trap specified by MSRC001_005A. Read-write. 1=Enabled.  |  |  |  |

# MSRC001\_00[5D:5A] MMIO Configuration Trap Address Registers

Reset: 0000 0000 0000 0000h. MSRC001\_0059 and MSRC001\_00[5D:5A] provide a mechanism for execut-

ing the SMI handler if a an access to one of the specified addresses in MMIO configuration space is detected. If the MMIO configuration access address and access type match one of the specified address and access types, then (1) the processor completes the configuration cycle and (2) the SMI-trigger IO cycle specified by MSRC001\_0056; this is done such that the processor enters SMM immediately after the instruction that generated the MMIO configuration cycle. The status is stored in SMMFEC4[MmioCfgTrapSts]. Note: Breakpoint Exceptions cannot be generated on addresses that are programmed for these MMIO traps; in single-step mode, the CPU executes both the instruction that generates this trap and the one following (after returning from SMM) as one step.

The SMI trap is taken if a CPU access to address CpuAddr is within the MMIO configuration-space address range (see MSRC001\_0058[MmioCfgBaseAddr]), if CpuAddr matches the offset within the MMIO configuration range specified by MSRC001\_00[5D:5A], and if the access type (read or write) is enabled in MSRC001\_0059.

| Bits  | Description                                                                                                   |
|-------|---------------------------------------------------------------------------------------------------------------|
|       | McSmiMask[31:2]. Read-write. MMIO configuration SMI trap mask. 0=Mask address bit. 1=Do not mask address bit. |
| 33:32 | SBZ.                                                                                                          |
| 31:2  | McSmiAddr[31:2]. Read-write. MMIO configuration SMI trap address.                                             |
| 1:0   | SBZ                                                                                                           |

#### MSRC001\_0061 P-State Current Limit Register

See also section 2.4.2 [P-states] on page 31. Writes to this register cause a #GP.

|      | to a man and the first term of |  |  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 63:7 | RAZ.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 6:4  | <b>PstateMaxVal: P-state maximum value</b> . Read-only. Specifies the lowest performance P-state (highest value) supported by the hardware. The state of this field is controlled through [The Clock Power/Timing Control 2 Register] F3xDC[PstateMaxVal].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 3    | RAZ.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 2:0  | CurPstateLimit: current P-state limit. Read-only. Provides the lowest-performance P-state limit (highest value) from [The Hardware Thermal Control (HTC) Register] F3x64[HtcPstateLimit], and [The Software Thermal Control (STC) Register] F3x68[StcPstateLimit].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |

#### MSRC001\_0062 P-State Control Register

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:3 | MBZ.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2:0  | <b>PstateCmd:</b> P-state change command. Read-write. Cold reset: values vary by product; after a warm reset, value initializes to the P-state the CPU core was in prior to the reset. Writes to this field cause the CPU core to change to the indicated P-state number, specified by MSRC001_00[68:64]. 0=P-state 0; 1=P-state 1; 4=P-state 4. Values of 5h through 7h are reserved. P-state limits are applied appropriately. See section 2.4.2 [P-states] on page 31. Reads from this field return the last written value, regardless of whether any limits are applied. |

#### MSRC001\_0063 P-State Status Register

| Writes to this register caus |
|------------------------------|
|------------------------------|

| Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:3 | RAZ.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2:0  | <b>CurPstate: current P-state</b> . Read-only. Cold reset: values vary by product. This field provides the frequency component of the current P-state of the CPU core (regardless of the source of the P-state change, including MSRC001_0062[PstateCmd]; see section 2.4.2.4 [P-state Transition Behavior] on page 33 for information on how these interact). 0=P-state 0; 1=P-state 1; etc. The value of this field is updated when the COF transitions to a new value associated with a P-state. See section 2.4.2 [P-states] on page 31. |

# MSRC001\_00[68:64] P-State [4:0] Registers

Reset: values vary by product as specified by F4x1[F0:E0].

Each of these registers specify the frequency and voltage associated with each of the core.

MSRC001\_0064 specifies P-state 0
 MSRC001\_0067 specifies P-state 3
 MSRC001\_0065 specifies P-state 1
 MSRC001\_0068 specifies P-state 4

• MSRC001\_0066 specifies P-state 2

The CpuVid and NbVid fields in these registers are required to be programmed to the same value in all CPU cores of a processor, but are allowed to be different between processors in a multi-processor system. All other fields in these registers are required to be programmed to the same value in each CPU core of the coherent fabric. See section 2.4.2 [P-states] on page 31 for more information about these registers.

| Bits  | Description                                                                                                                                                                                                                                                                       |                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63    | <b>PstateEn</b> . Read-write. 1=The P-state specified by this MSR is valid. 0=The P-state specified by this MSR is not valid. The purpose of this register is to indicate if the rest of the P-state information in the register is valid after a reset; it controls no hardware. |                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 62:42 | SBZ.                                                                                                                                                                                                                                                                              |                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 41:40 | IddDiv: current divisor field. Read-write. See MSRC001_00[68:64][IddValue].                                                                                                                                                                                                       |                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 39:32 | the expected cur<br>number. These v<br>2.4.2.9 [ACPI Pr<br>board Power Del<br>not intended to c<br>the Power and T                                                                                                                                                                | rent dissipation of a single<br>values are intended to be u<br>rocessor P-State Objects]<br>livery Compatibility Chec<br>convey final product power<br>thermal Datasheets. These | te. After a reset, IddDiv and IddValue combine to specify to CPU core that is in the P-state corresponding to the MSR used to create ACPI-defined _PSS objects (see section on page 44) and to perform the 2.4.2.7 [Processor-System-th] on page 36. The values are expressed in amps; they are the levels; they may not match the power levels specified in a fields, may be subsequently altered by software; they do to 255 A    O to 255 A   O to 2.55 A |

| 31:25 | <b>NbVid:</b> Northbridge VID. Read-write. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25. This field is required to be programmed as specified by MSRC001_0071[MaxVid and MinVid] (otherwise undefined behavior results). In SVI platforms, the value of this field must be the same in all MSRs in which NbDid=0; the value of this field must be the same in all MSRs in which NbDid=1. In PVI platforms, this may vary with each CPU P-state, as NbVid specifies the voltage the NB and cores. See also MSRC001_0071[NbPstateDis]. |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:23 | SBZ.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 22    | <b>NbDid:</b> Northbridge divisor ID. Read-write. Specifies the NB frequency divisor; see F3xD4[NbFid]. 0=Divisor of 1. 1=Divisor of 2. This bit must be set the same in all P-state registers.                                                                                                                                                                                                                                                                                                                                                                   |
| 21:16 | SBZ.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15:9  | <b>CpuVid: CPU core VID</b> . Read-write. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25. This field is required to be programmed as specified by MSRC001_0071[MaxVid and MinVid] (otherwise undefined behavior results).                                                                                                                                                                                                                                                                                                              |
| 8:6   | CpuDid: CPU core divisor ID. Read-write. Specifies the CPU frequency divisor; see CpuFid.  0h=Divisor of 1                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5:0   | CpuFid: CPU core frequency ID. Read-write. Specifies the CPU frequency multiplier. The CPU COF specified by CpuFid and CpuDid is: CPU COF = 100 MHz * (CpuFid + 10h) / (2^CpuDid). This field and CpuDid must be programmed to the requirements specified in MSRC001_0071[MaxCpuCof]. The value of this field must be less than or equal to 2Fh.                                                                                                                                                                                                                  |

# MSRC001\_0070 COFVID Control Register

Cold reset: values vary by product.

This register includes several fields that are identical to MSRC001\_00[68:64]. It is controlled by hardware for P-state transitions. It may also be used by software to directly control the current COF or VID. Accesses to this register that result in invalid COFs or VIDs are ignored. See also section 2.4.2 [P-states] on page 31.

| Bits  | Description                                                                                                                                                                                                                                                             |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RAZ.                                                                                                                                                                                                                                                                    |
| 31:25 | NbVid: Northbridge VID. Read-write. See MSRC001_00[68:64].                                                                                                                                                                                                              |
| 24:23 | RAZ.                                                                                                                                                                                                                                                                    |
| 22    | <b>NbDid:</b> Northbridge divisor ID. Read-write if MSRC001_0071[NbPstateDis]=0; otherwise read-only. See MSRC001_00[68:64].                                                                                                                                            |
| 21:19 | RAZ.                                                                                                                                                                                                                                                                    |
| 18:16 | <b>PstateId:</b> P-state identifier. Read-write. This field is required to provide the P-state number that is associated with the values of the other fields in this register. This value is used by the logic to determine if the P-state is increasing or decreasing. |
| 15:9  | CpuVid: CPU core VID. Read-write. See MSRC001_00[68:64].                                                                                                                                                                                                                |
| 8:6   | <b>CpuDid: CPU core divisor ID</b> . Read-write. See MSRC001_00[68:64]. The PstateId field must be updated to cause a new CpuDid value to take effect.                                                                                                                  |
| 5:0   | <b>CpuFid: CPU core frequency ID</b> . Read-write. See MSRC001_00[68:64]. The PstateId field must be updated to cause a new CpuFid value to take effect.                                                                                                                |

# MSRC001\_0071 COFVID Status Register

See section 2.4.2 [P-states] on page 31.

| Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <b>MaxNbFid:</b> maximum NB COF. Read-only. Specifies the maximum NB FID supported by the processor. The maximum frequency is 200 MHz * (MaxNbFid + 4), if MaxNbFid is greater than zero; if MaxNbFid = 00h, then there is no frequency limit. Any attempt to change the NB FID to a frequency greater than specified by this register results in no change to the NB FID.                                                |
| 58:56 | <b>CurPstateLimit:</b> current <b>P-state limit</b> . Read-only. Provides the current highest-performance P-state limit (lowest value). Identical to MSRC001_0061[CurPstateLimit].                                                                                                                                                                                                                                        |
| 55    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 54:49 | <b>MaxCpuCof:</b> maximum CPU COF. Read-only. Specifies the maximum CPU COF supported by the processor. The maximum frequency is 100 MHz * MaxCpuCof, if MaxCpuCof is greater than zero; if MaxCpuCof = 00h, then there is no frequency limit. Any attempt to change a CPU COF to a frequency greater than specified by this field is ignored.                                                                            |
| 48:42 | <b>MinVid: minimum voltage</b> . Read-only. Specifies the VID code corresponding to the minimum voltage that the processor drives. 00h indicates that no minimum VID code is specified. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25.                                                                                                                                                        |
| 41:35 | <b>MaxVid: maximum voltage</b> . Read-only. Specifies the VID code corresponding to the maximum voltage that the processor drives. 00h indicates that no maximum VID code is specified. See section 2.4.1 [Processor Power Planes And Voltage Control] on page 25.                                                                                                                                                        |
| 34:32 | <b>StartupPstate:</b> startup P-state number. Read-only. Specifies the cold reset VID, FID and DID for the NB and core based on the P-state number selected (see MSRC001_00[68:64]). If F3xA0[PviMode]=1, then NbVid of the selected P-state is applied to the PVI. Note: if F3xA0[CofVidProg]=0, then the state of this field is ignored, the VID, FID, and DID are applied to the core and NB as specified by that bit. |
| 31:25 | CurNbVid: current Northbridge VID. Read-only.                                                                                                                                                                                                                                                                                                                                                                             |
| 24:23 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 22    | CurNbDid: current Northbridge divisor ID. Read-only.                                                                                                                                                                                                                                                                                                                                                                      |
|       | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 18:16 | CurPstate: current P-state. Read-only. This is identical to MSRC001_0063[CurPstate].                                                                                                                                                                                                                                                                                                                                      |
| 15:9  | CurCpuVid: current CPU core VID. Read-only.                                                                                                                                                                                                                                                                                                                                                                               |
| 8:6   | CurCpuDid: current CPU core divisor ID. Read-only.                                                                                                                                                                                                                                                                                                                                                                        |
| 5:0   | CurCpuFid: current CPU core frequency ID. Read-only.                                                                                                                                                                                                                                                                                                                                                                      |

### MSRC001\_0074 CPU Watchdog Timer Register (CpuWdTmrCfg)

Reset: 0000 0000 0000 0000h. The CPU watchdog timer (WDT) is implemented as a counter that counts out the time periods specified. The counter starts counting when CpuWdtEn is set. The counter does not count during halt or stop-grant. It restarts the count each time an operation of an instruction completes. If no operation completes by the specified time period, then a machine check error may be recorded if enabled (see MSR0000\_0414 through MSR0000\_0417). If a watchdog timer error overflow occurs (MSR0000\_0415[OVER]), a sync flood can be generated if enabled in F3x180[SyncFloodOnCpuLeakErr].

The CPU watchdog timer must be set higher than the NB watchdog timer ([The MCA NB Configuration Register] F3x44) in order to allow remote requests to complete. The CPU watchdog timer must be set the same for

all CPUs in a system.

| Bits | Description                                                                                                  |                                                                                                    |                                                                                                                                                                                                                    |
|------|--------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:7 | Reserved.                                                                                                    |                                                                                                    |                                                                                                                                                                                                                    |
| 6:3  | Base, specifies the time period rehere times the time base specifies                                         | equired for the WDT to expire. To do by CpuWdtTimeBase. Note the ements less than the values speci | vrite. This, along with CpuWdtTime-<br>The time period is the value specified nat the actual timeout period may be fied, due to non-deterministic behav-<br>1000b = 8191 $1001b = 16383$ $1010b - 1111b Reserved.$ |
| 2:1  | CpuWdtTimeBase: CPU watc<br>timeout period specified in Cpu'<br>00b = 1 millisecond.<br>01b = 1 microsecond. | hdog timer time base. Read-wr<br>WdtCountSel.<br>10b = 5 nanoseconds.<br>11b = Reserved.           | ite. Specifies the time base for the                                                                                                                                                                               |
| 0    | CpuWdtEn: CPU watchdog ti                                                                                    | mer enable. Read-write. 1=The                                                                      | WDT is enabled.                                                                                                                                                                                                    |

### MSRC001\_0111 SMM Base Address Register (SMM\_BASE)

Reset: 0000 0000 0003 0000h. This holds the base of the SMM memory region. The value of this register is stored in the save state on entry into SMM (see section 2.14.2.5 [SMM Save State] on page 126) and it is restored on returning from SMM. The 16-bit CS (code segment) selector is loaded with SMM\_BASE[19:4] on entering SMM. SMM\_BASE[31:20] and SMM\_BASE[3:0] are required to be 0. The SMM base address can be changed in two ways:

- The SMM base address, at offset FF00h in the SMM state save area, may be changed by the SMI handler. The RSM instruction updates SMM\_BASE with the new value.
- Normal WRMSR access to this register.

| Bits  | Description                                                 |
|-------|-------------------------------------------------------------|
| 63:32 | Reserved.                                                   |
| 31:0  | SMM_BASE. Read-write; read-only if MSRC001_0015[SmmLock]=1. |

### MSRC001\_0112 SMM TSeg Base Address Register (SMMAddr)

Reset: 0000 0000 0000 0000h. See section 2.14.2 [System Management Mode (SMM)] on page 124 for information about SMM. See MSRC001\_0113 for more information about the ASeg and TSeg address ranges.

Each CPU access, directed at CPUAddr, is determined to be in the TSeg range if the following is true:

CPUAddr[47:17] & TSegMask[47:17] == TSegBase[47:17] & TSegMask[47:17].

For example, if TSeg spans 256K bytes and starts at the 1M byte address. The MSRC001\_0112[TSegBase] would be set to 0010\_0000h and the MSRC001\_0113[TSegMask] to FFFC\_0000h (with zeros filling in for

bits[16:0]). This results in a TSeg range from 0010\_0000 to 0013\_FFFFh.

| Bits  | Description                                                                                 |
|-------|---------------------------------------------------------------------------------------------|
| 63:48 | Reserved.                                                                                   |
|       | TSegBase[47:17]: TSeg address range base. Read-write; read-only if MSRC001_0015[SmmLock]=1. |
| 16:0  | Reserved.                                                                                   |

# MSRC001\_0113 SMM TSeg Mask Register (SMMMask)

Reset: 0000 0000 0000 0000h. See section 2.14.2 [System Management Mode (SMM)] on page 124 for information about SMM.

The ASeg address range is located at a fixed address from A0000h–BFFFFh. The TSeg range is located at a variable base (specified by MSRC001\_0112[TSegBase]) with a variable size (specified by MSRC001\_0113[TSegMask]). These ranges provide a safe location for SMM code and data that is not readily accessible by non-SMM applications. The SMI handler can be located in one of these two ranges, or it can be located outside these ranges. These ranges must never overlap each other.

This register specifies how accesses to the ASeg and TSeg address ranges are control as follows:

- If [A, T]Valid=0, then the address range is accessed as specified by MTRRs, regardless of whether the CPU is in SMM or not.
- If [A, T]Valid=1, then:
  - If in SMM, then:
    - If [A, T]Close=0, then the accesses are directed to DRAM with memory type as specified in [A, T]MTypeDram.
    - If [A, T]Close=1, then instruction accesses are directed to DRAM with memory type as specified in [A, T]MTypeDram and data accesses are directed at MMIO space and with attributes based on [A, T]MTypeIoWc.
  - If not in SMM, then the accesses are directed at MMIO space with attributes based on [A, T]MTypeIoWc.

| Bits  | Description                                                                                                                                                                                                                                                                    |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:48 | Reserved.                                                                                                                                                                                                                                                                      |
| 47:17 | TSegMask[47:17]: TSeg address range mask. Read-write; read-only if MSRC001_0015[SmmLock]=1. See MSRC001_0112.                                                                                                                                                                  |
| 16:15 | Reserved.                                                                                                                                                                                                                                                                      |
| 14:12 | <b>TMTypeDram: TSeg address range memory type</b> . Read-write; read-only if MSRC001_0015[SmmLock]=1. Specifies the memory type for SMM accesses to the TSeg range that are directed to DRAM. The encoding is identical to the three LSBs of the MTRRs. See MSR0000_02[0F:00]. |
| 11    | Reserved.                                                                                                                                                                                                                                                                      |
| 10:8  | <b>AMTypeDram: ASeg Range Memory Type</b> . Read-write; read-only if MSRC001_0015[SmmLock]=1. Specifies the memory type for SMM accesses to the ASeg range that are directed to DRAM. The encoding is identical to the three LSBs of the MTRRs. See MSR0000_02[0F:00].         |
| 7:6   | Reserved.                                                                                                                                                                                                                                                                      |

| 5 | TMTypeIoWc: non-SMM TSeg address range memory type. Read-write; read-only if MSRC001_0015[SmmLock]=1. Specifies the attribute of TSeg accesses that are directed to MMIO space. 0=UC (uncacheable). 1=WC (write combining).                                                                                     |
|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4 | AMTypeIoWc: non-SMM ASeg address range memory type. Read-write; read-only if MSRC001_0015[SmmLock]=1. Specifies the attribute of ASeg accesses that are directed to MMIO space. 0=UC (uncacheable). 1=WC (write combining).                                                                                     |
| 3 | TClose: send TSeg address range data accesses to MMIO. Read-write. 1=When in SMM, direct data accesses in the TSeg address range to MMIO space. See also, AClose.                                                                                                                                               |
| 2 | AClose: send ASeg address range data accesses to MMIO. Read-write. 1=When in SMM, direct data accesses in the ASeg address range to MMIO space.                                                                                                                                                                 |
|   | [A, T]Close allows the SMI handler to access the MMIO space located in the same address region as the [A, T]Seg. When the SMI handler is finished accessing the MMIO space, it must clear the bit. Failure to do so before resuming from SMM causes the CPU to erroneously read the save state from MMIO space. |
| 1 | <b>TValid:</b> enable TSeg SMM address range. Read-write; read-only if MSRC001_0015[SmmLock]=1. 1=The TSeg address range SMM enabled.                                                                                                                                                                           |
| 0 | AValid: enable ASeg SMM address range. Read-write; read-only if MSRC001_0015[SmmLock]=1. 1=The ASeg address range SMM enabled.                                                                                                                                                                                  |

# MSRC001\_0114 Virtual Machine Control Register (VM\_CR)

| Reset: ( | Reset: 0000 0000 0000 0000h.                                                                                                                                                                                                                                                                                                                                          |  |  |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits     | Description                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 63:5     | Reserved.                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 4        | <b>Syme_Disable: SVME disable</b> . See Lock. 1=MSRC000_0080[SVME] must be zero (MBZ) when writing to MSRC000_0080. Setting this bit when MSRC000_0080[SVME]=1 causes a #GP fault, regardless of the state of Lock. 0=MSRC000_0080[SVME] is read-write.                                                                                                               |  |  |
| 3        | <b>Lock: SVM lock</b> . Read-only; write-1-only; cleared-by-hardware(see MSRC001_0118). 1=Svme_Disable is read-only. 0=Svme_Disable is read-write.                                                                                                                                                                                                                    |  |  |
| 2        | <b>dis_a20m: disable A20 masking</b> . Read-write; set-by-hardware. 1=Disables A20 masking. This bit is set by hardware when the SKINIT instruction is executed.                                                                                                                                                                                                      |  |  |
| 1        | <ul> <li>r_init: intercept INIT. Read-write; set-by-hardware. This bit controls how INIT is delivered in host mode. This bit is set by hardware when the SKINIT instruction is executed.</li> <li>0 = INIT delivered normally.</li> <li>1 = INIT translated into a SX interrupt.</li> </ul>                                                                           |  |  |
| 0        | dpd: debug port disable. Read-write; set-by-hardware. This bit controls if debug facilities such as JTAG and HDT have access to the processor state information. This bit is set by hardware when the SKINIT instruction is executed.  0 = Debug port may be enabled.  1 = Debug port disabled; all mechanisms that could expose trusted code execution are disabled. |  |  |

# MSRC001\_0115 IGNNE Register (IGNNE)

| Bits | Description                                                                                                                                 |
|------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 63:1 | MBZ.                                                                                                                                        |
|      | <b>IGNNE:</b> current <b>IGNNE</b> state. Read-write. Reset: X. This bit controls the current state of the processor internal IGNNE signal. |

# MSRC001\_0116 SMM Control Register (SMM\_CTL)

Accesses to this register cause a #GP if MSRC001\_0015[SmmLock]=1. The bits in this register are processed in the order of: smm\_enter, smi\_cycle, smm\_dismiss, rsm\_cycle and smm\_exit. However, only the following combination of bits may be set in a single write (all other combinations result in undefined behavior):

- smm\_enter and smi\_cycle.
- smm\_enter and smm\_dismiss.
- smm\_enter, smi\_cycle and smm\_dismiss.
- smm\_exit and rsm\_cycle.

Software is responsible for ensuring that smm\_enter and smm\_exit operations are properly matched and are not nested.

| Bits | Description                                                                          |
|------|--------------------------------------------------------------------------------------|
| 63:5 | Reserved.                                                                            |
| 4    | rsm_cycle: send RSM special cycle. Write-only. Reset: X. 1=Send a RSM special cycle. |
| 3    | smm_exit: exit SMM. Write-only. Reset: X. 1=Exit SMM.                                |
| 2    | smi_cycle: send SMI special cycle. Write-only. Reset: X. 1=Send a SMI special cycle. |
| 1    | smm_enter: enter SMM. Write-only. Reset: X. 1=Enter SMM.                             |
| 0    | smm_dismiss: clear SMI. Write-only. Reset: X. 1=Clear the SMI pending flag.          |

### MSRC001\_0117 Virtual Machine Host Save Physical Address Register (VM\_HSAVE\_PA)

Reset: 0000 0000 0000 0000h.

| Bits | Description                                                                                              |
|------|----------------------------------------------------------------------------------------------------------|
| 63:0 | VM_HSAVE_PA: physical address of host save area. Read-write. This register contains the                  |
|      | physical address where VMRUN saves host state and where vm-exit restores host state from. Writing        |
|      | this register causes a #GP if any of the lower 12 bits are not zero or if the address written is greater |
|      | than FD_000_000h.                                                                                        |

# MSRC001\_0118 SVM Lock Key

Reset: 0000 0000 0000 0000h.

|   | Bits | Description                                                                          |
|---|------|--------------------------------------------------------------------------------------|
| ( | 63:0 | SvmLockKey: SVM lock key. RAZ, write-only. Writes to this register when              |
|   |      | MSRC001_0114[Lock]=0 write the SvmLockKey. Writes to this register when              |
|   |      | MSRC001_0114[Lock]=1 and SvmLockKey!=0 cause hardware to clear MSRC001_0114[Lock] if |
|   |      | the value written is the same as the value stored in SvmLockKey.                     |

# MSRC001\_011A Local SMI Status

Reset: 0000 0000 0000 0000h. This registers returns the same information that is returned in [The Local SMI Status] SMMFEC4 portion of the SMM save state. The information in this register is only updated when MSRC001\_0116[smm\_dismiss] is set by software.

| Bits  | Description                         |
|-------|-------------------------------------|
| 63:32 | Reserved.                           |
| 31:0  | See [The Local SMI Status] SMMFEC4. |

# MSRC001\_0140 OS Visible Work-around MSR0 (OSVW\_ID\_Length)

Reset: 0000 0000 0000 0000h.

| Bits  | Description                                                                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:16 | Reserved.                                                                                                                                                   |
|       | OSVW_ID_Length: OS visible work-around ID length. Read-write. See the <i>Revision Guide for AMD Family 10h Processors</i> for the definition of this field. |

### MSRC001\_0141 OS Visible Work-around MSR1 (OSVW Status)

Reset: 0000 0000 0000 0000h.

| Bits | Description                                                                                                                                                   |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | OsvwStatusBits: OS visible work-around status bits. Read-write. See the <i>Revision Guide for AMD Family 10h Processors</i> for the definition of this field. |

### 3.13 MSRs - MSRC001\_1xxx

# MSRC001\_1022 Data Cache Configuration Register (DC\_CFG)

All defined fields are read-write.

| Bits  | Description                                                                                                                                                                                                       |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:36 | Reserved.                                                                                                                                                                                                         |
|       | <b>REQ_CTR</b> . Reset: 11b. Initial number of requests (1 to 3) a hardware prefetch can make. Setting this field to 0 disables the hardware prefetcher. The BIOS should program this to 01b for server products. |
| 33:0  | Reserved.                                                                                                                                                                                                         |

# MSRC001\_1023 Bus Unit Configuration Register (BU\_CFG)

Revision B Reset: 0000 0000 0000 0020h. All defined fields are read-write.

| Bits  | Description |
|-------|-------------|
| 63:49 | Reserved.   |

| 48   | WbEnhWsbDis: disable multi-stream write combining. 0=The bus unit performs write combining          |
|------|-----------------------------------------------------------------------------------------------------|
|      | on up to 4 indedpendent data streams. 1=The bus unit only performs write combining on a single data |
|      | steam.                                                                                              |
| 47:0 | Reserved.                                                                                           |

# MSRC001\_102A Bus Unit Configuration 2 Register (BU\_CFG2)

Reset: 0000 0000 0100 00C0h.

| Bits  | Description                                                                                                                               |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 63:30 | Reserved.                                                                                                                                 |
| 29    | <b>Smash1GPages</b> . Read-write. 1=1G pages are smashed and installed in the TLB as 2M pages. BIOS must set this bit for revision B.     |
| 28:16 | Reserved.                                                                                                                                 |
| 15    | <b>ClLinesToNbDis.</b> Read-write. 1=Clean victims/copybacks are not sent to the NB regardless of whether the L3 cache is enabled or not. |
| 14:0  | Reserved.                                                                                                                                 |

# MSRC001\_1030 IBS Fetch Control Register (IbsFetchCtl)

The IBS fetch sampling engine selects an instruction fetch to profile when the engine's periodic fetch counter reaches IbsFetchMaxCnt. The periodic fetch counter is an internal 20 bit counter that increments after every fetch cycle that completes when IbsFetchEn=1 and IbsFetchVal=0. When the selected instruction fetch completes or is aborted, the status of the fetch is written to the IBS fetch registers (this register, MSRC001\_1031 and MSRC001\_1032) and an interrupt is generated. The interrupt service routine associated with this interrupt is responsible for saving the performance information stored in IBS fetch registers. See also section 2.17.2 [Instruction Based Sampling (IBS)] on page 133.

| Bits  | Description                                                                                                                                                                                                                                                                         |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:58 | Reserved.                                                                                                                                                                                                                                                                           |
| 57    | <b>IbsRandEn: random instruction fetch tagging enable</b> . Read-write. Reset X. 1=Bits 3:0 of the fetch counter are randomized when IbsFetchEn is set to start the fetch counter. 0=Bits 3:0 of the fetch counter are set to 0h when IbsFetchEn is set to start the fetch counter. |
| 56    | <b>IbsL2TlbMiss:</b> instruction cache <b>L2TLB miss</b> . Read-only. Reset X. 1=The instruction fetch missed in the L2 TLB.                                                                                                                                                        |
| 55    | <b>IbsL1TlbMiss: instruction cache L1TLB miss</b> . Read-only. Reset X. 1=The instruction fetch missed in the L1 TLB.                                                                                                                                                               |
| 54:53 | IbsL1TlbPgSz: instruction cache L1TLB page size. Read-only. Reset X. This field indicates the page size of the translation in the L1 TLB. This field is only valid if IbsPhyAddrValid=1.  Bits Definition 00b 4 Kbyte 01b 2 Mbyte 1Xb Reserved                                      |
| 52    | <b>IbsPhyAddrValid:</b> instruction fetch physical address valid. Read-only. Reset X. 1=The physical address in MSRC001_1032 and the IbsL1TlbPgSz field are valid for the instruction fetch.                                                                                        |
| 51    | <b>IbsIcMiss: instruction cache miss</b> . Read-only. Reset X. 1=The instruction fetch missed in the instruction cache.                                                                                                                                                             |

| 50    | <b>IbsFetchComp:</b> instruction fetch complete. Read-only. 1=The instruction fetch completed and the data is available for use by the instruction decoder.                                                                                                                                                                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 49    | <b>IbsFetchVal:</b> instruction fetch valid. Read-write; set-by-hardware. Reset 0b. 1=New instruction fetch data available. When this bit is set, the fetch counter stops counting and an interrupt is generated as specified by the APIC LVT specified by MSRC001_103A[LvtOffset]. This bit must be cleared and IbsFetchCnt must be written to 0000h for the fetch counter to start counting again.        |
| 48    | <b>IbsFetchEn: instruction fetch enable</b> . Read-write. 1=Instruction fetch sampling is enabled.                                                                                                                                                                                                                                                                                                          |
| 47:32 | <b>IbsFetchLat:</b> instruction fetch latency. Read-only. Reset X. This field indicates the number of clock cycles from when the instruction fetch was initiated to when the data was delivered to the core. If the instruction fetch is abandoned before the fetch completes, this field returns the number of clock cycles from when the instruction fetch was initiated to when the fetch was abandoned. |
| 31:16 | <b>IbsFetchCnt</b> . Read-write; controlled-by-hardware. Reset 0000h. This field returns the current value of bits 19:4 of the periodic fetch counter.                                                                                                                                                                                                                                                      |
| 15:0  | <b>IbsFetchMaxCnt</b> . Read-write. Reset 0000h. This field specifies maximum count value of the periodic fetch counter. Programming this field to 0000h and setting IbsFetchEn results in undefined behavior. Bits 19:4 of the maximum count are programmed in the field. Bits 3:0 of the maximum countare always 0000.                                                                                    |

### MSRC001 1031 IBS Fetch Linear Address Register (IbsFetchLinAd)

Reset: xxxx xxxx xxxx xxxxh.

| Bits | Description                                                                                               |
|------|-----------------------------------------------------------------------------------------------------------|
| 63:0 | <b>IbsFetchLinAd:</b> instruction fetch linear address. Read-only. This field provides the linear address |
|      | in canonical form for the tagged instruction fetch.                                                       |

### MSRC001\_1032 IBS Fetch Physical Address Register (IbsFetchPhysAd)

Reset: xxxx xxxx xxxx xxxxh.

| Bits | Description                                                                                              |
|------|----------------------------------------------------------------------------------------------------------|
| 63:0 | <b>IbsFetchPhysAd:</b> instruction fetch physical address. Read-only. This provides the physical address |
|      | in canonical form for the tagged instruction fetch. The lower 12 bits are not modified by address        |
|      | translation, so they are always the same as the linear address. This field contains valid data only if   |
|      | MSRC001_1030[IbsPhyAddrValid] is asserted.                                                               |

# MSRC001\_1033 IBS Execution Control Register (IbsOpCtl)

Reset: 0000 0000 0000 0000h. The IBS execution sampling engine tags a micro-op that will be issued in the next cycle to profile when the engine's periodic op counter reaches IbsOpMaxCnt. The periodic op counter is an internal 20 bit counter that increments every cycle when IbsOpEn=1 and IbsOpVal=0 and rolls over when the counter reaches IbsOpMaxCnt. When the periodic op counter rolls over bits 6:0 of the counter are randomized by hardware. When the micro-op is retired, the status of the operation is written to the IBS execution registers (this register, MSRC001\_1034, MSRC001\_1035, MSRC001\_1036, MSRC001\_1037, MSRC001\_1038, MSRC001\_1039) and an interrupt is generated. The interrupt service routine associated with this interrupt is responsible for saving the performance information stored in IBS execution registers. See also section 2.17.2 [Instruction Based Sampling (IBS)] on page 133.

| Bits  | Description                                                                                                                                                                                                                                                                                                  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:19 | Reserved.                                                                                                                                                                                                                                                                                                    |
| 18    | <b>IbsOpVal:</b> micro-op sample valid. Read-write; set-by-hardware. 1=New instruction execution data available. When this bit is set, the periodic op counter stops counting until software clears the bit and an interrupt is generated as specified by the APIC LVT specified by MSRC001_103A[LvtOffset]. |
|       |                                                                                                                                                                                                                                                                                                              |
| 17    | <b>IbsOpEn: micro-op sampling enable</b> . Read-write. 1=Instruction execution sampling enabled.                                                                                                                                                                                                             |
| 17    | <b>IbsOpEn: micro-op sampling enable</b> . Read-write. 1=Instruction execution sampling enabled.  Reserved.                                                                                                                                                                                                  |

# MSRC001\_1034 IBS Op Logical Address Register (IbsOpRip)

Reset: xxxx xxxx xxxx xxxxh.

|   | Bits | Description                                                                                     |
|---|------|-------------------------------------------------------------------------------------------------|
| Ī |      | <b>IbsOpRip: micro-op linear address</b> . Read-write. Linear address in canonical form for the |
|   |      | instruction that contains the tagged micro-op.                                                  |

# MSRC001\_1035 IBS Op Data Register (IbsOpData)

| Bits  | Description                                                                                                                                                                                                                                                     |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Reserved.                                                                                                                                                                                                                                                       |
| 37    | <b>IbsOpBrnRet: branch micro-op retired</b> . Reset X. Read-only. 1=Tagged operation was a branch that retired.                                                                                                                                                 |
| 36    | <b>IbsOpBrnMisp: mispredicted branch micro-op</b> . Read-only. Reset X. 1=Tagged operation was a branch micro-op that was mispredicted.                                                                                                                         |
| 35    | <b>IbsOpBrnTaken: taken branch micro-op</b> . Read-only. Reset X. 1=Tagged operation was a branch micro-op that was taken.                                                                                                                                      |
| 34    | <b>IbsOpReturn: return micro-op</b> . Read-only. Reset X. 1=Tagged operation was return micro-op.                                                                                                                                                               |
| 33    | <b>IbsOpMispReturn:</b> mispredicted return micro-op. Read-only. Reset X. 1=Tagged operation was a mispredicted return micro-op.                                                                                                                                |
| 32    | <b>IbsOpBrnResync: resync micro-op</b> . Read-only. Reset X. 1=Tagged operation was resync micro-op.                                                                                                                                                            |
| 31:16 | <b>IbsTagToRetCtr: micro-op tag to retire count</b> . Read-only. Reset X. This field returns the number of cycles from when the micro-op was tagged to when the micro-op was retired. This field is equal to IbsCompToRetCtr when the tagged micro-op is a NOP. |
| 15:0  | <b>IbsCompToRetCtr:</b> micro-op completion to retire count. Read-only. Reset X. This field returns the number of cycles from when the micro-op was completed to when the micro-op was retired.                                                                 |

# MSRC001\_1036 IBS Op Data 2 Register (IbsOpData2)

Reset: 0000 0000h. Northbridge data is only valid for load operations that miss both the L1 data cache and the L2 cache. If a load operation crosses a cache line boundary, the data returned in this register is the data for the access to the lower cache line.

| 63:6 | Reserved.                                                                                                                                                                     |                                                    |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| 5    | <b>NbIbsReqCacheHitSt</b> : <b>IBS L3 cache state</b> . Read-write; controlled-by-hardware. Valid when the data source type is Cache(2h). $0 = $ 'M' State. $1 = $ 'O' State. |                                                    |
| 4    | <b>NbIbsReqDstProc</b> : <b>IBS request destination processor</b> . Reac request is serviced from the local processor. 1=The request is                                       | •                                                  |
| 3    | Reserved.                                                                                                                                                                     |                                                    |
| 2:0  | 2:0 NbIbsReqSrc: Northbridge IBS request data source. Read-write.                                                                                                             |                                                    |
|      | 0h=No valid status.                                                                                                                                                           | 4h=Reserved for remote cache.                      |
|      | 1h=L3: data returned from local L3 cache.                                                                                                                                     | 5h=Reserved.                                       |
|      | 2h=Cache: data returned from a CPU cache or a remote L3.                                                                                                                      | 6h=Reserved.                                       |
|      | 3h=DRAM: data returned from DRAM.                                                                                                                                             | 7h=Other: data returned from MMIO/Config/PCI/APIC. |

# MSRC001\_1037 IBS Op Data 3 Register (IbsOpData3)

If a load or store operation crosses a 128-bit boundary, the data returned in this register is the data for the access to the data below the 128-bit boundary.

| 63:48 | Reserved.                                                                                                                                                                                                                                                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 47:32 | <b>IbsDcMissLat: data cache miss latency</b> . Read-only. Reset X. This field indicates the number of clock cycles from when a miss is detected in the data cache to when the data was delivered to the core. The value returned by this counter is not valid for data cache writes.                                      |
| 31:19 | Reserved                                                                                                                                                                                                                                                                                                                  |
| 18    | <b>IbsDcPhyAddrValid:</b> data cache physical address valid. Read-only. Reset X. 1=The physical address in MSRC001_1039 is valid for the load or store operation.                                                                                                                                                         |
| 17    | <b>IbsDcLinAddrValid: data cache linear address valid</b> . Read-only. Reset X. 1=The linear address in MSRC001_1038 is valid for the load or store operation.                                                                                                                                                            |
| 16    | <b>IbsDcMabHit: MAB hit</b> . Read-only. Reset X. 1=The tagged load or store operation hit on an already allocated MAB. IBS data in MSRC001_1036 is not valid if this bit is set.                                                                                                                                         |
| 15    | <b>IbsDcLockedOp: locked operation</b> . Read-only. Reset X. 1=Tagged load or store operation is a locked operation.                                                                                                                                                                                                      |
| 14    | <b>IbsDcWcMemAcc: WC memory access</b> . Read-only. Reset X. 1=Tagged load or store operation accessed write combining memory.                                                                                                                                                                                            |
| 13    | <b>IbsDcUcMemAcc: UC memory access</b> . Read-only. Reset X. 1=Tagged load or store operation accessed uncacheable memory.                                                                                                                                                                                                |
| 12    | <b>IbsDcStToLdCan: data forwarding from store to load operation cancelled</b> . Read-only. Reset X. 1=Data forwarding from a store operation to the tagged load was cancelled.                                                                                                                                            |
| 11    | <b>IbsDcStToLdFwd:</b> data forwarded from store to load operation. Read-only. Reset X. 1=Data for tagged load operation was forwarded from a store operation. If this bit is set and IbsDcStToLdCan=1, then the data for the load operation forwarded from a store operation but the data was not forwarded immediately. |
| 10    | <b>IbsDcStBnkCon:</b> bank conflict on store operation. Read-only. Reset X. 1=A bank conflict with a store operation occurred in the data cache on the tagged load or store operation.                                                                                                                                    |
| 9     | <b>IbsDcLdBnkCon:</b> bank conflict on load operation. Read-only. Reset X. 1=A bank conflict with a load operation occurred in the data cache on the tagged load or store operation.                                                                                                                                      |

| 8 | <b>IbsDcMisAcc: misaligned access</b> . Read-only. Reset X. 1=The tagged load or store operation crosses a 128 bit address boundary.                                                                    |
|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 | <b>IbsDcMiss: data cache miss</b> . Read-only. Reset X. 1=The cache line used by the tagged load or store was not present in the data cache.                                                            |
| 6 | <b>IbsDcL2tlbHit2M:</b> data cache L2TLB hit in 2M page. Read-only. Reset X.1=The physical address for the tagged load or store operation was present in a 2M page table entry in the data cache L2TLB. |
| 5 | <b>IbsDcL1tlbHit1G:</b> data cache L1TLB hit in 1G page. Read-only. Reset X.1=The physical address for the tagged load or store operation was present in a 1G page table entry in the data cache L1TLB. |
| 4 | <b>IbsDcL1tlbHit2M:</b> data cache L1TLB hit in 2M page. Read-only. Reset X.1=The physical address for the tagged load or store operation was present in a 2M page table entry in the data cache L1TLB. |
| 3 | <b>IbsDcL2tlbMiss: data cache L2TLB miss</b> . Read-only. Reset X.1=The physical address for the tagged load or store operation was not present in the data cache L2TLB.                                |
| 2 | <b>IbsDcL1tlbMiss: data cache L1TLB miss</b> . Read-only. Reset X.1=The physical address for the tagged load or store operation was not present in the data cache L1TLB.                                |
| 1 | <b>IbsStOp: store op.</b> Read-only. Reset X.1=Tagged operation is a store operation                                                                                                                    |
| 0 | <b>IbsLdOp: load op.</b> Read-only. Reset X.1=Tagged operation is a load operation                                                                                                                      |

# MSRC001\_1038 IBS DC Linear Address Register (IbsDcLinAd)

Reset: xxxx xxxx xxxx xxxxh.

| ĺ | Bits | Description                                                                                                 |
|---|------|-------------------------------------------------------------------------------------------------------------|
|   |      | <b>IbsDcLinAd</b> . Read-only. This field provides the linear address in canonical form for the tagged load |
|   |      | or store operation. This field contains valid data only if MSRC001_1037[IbsDcLinAddrValid] is               |
|   |      | asserted.                                                                                                   |

# MSRC001\_1039 IBS DC Physical Address Register (IbsDcPhysAd)

Reset: xxxx xxxx xxxx xxxxh.

| Bits | Description                                                                                                                                                                                                                                                                                                                    |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <b>IbsDcPhysAd</b> . Read-only. This provides the physical address in canonical form for the tagged load or store operation. The lower 12 bits are not modified by address translation, so they are always the same as the linear address. This field contains valid data only if MSRC001_1037[IbsDcPhyAddrValid] is asserted. |

# MSRC001\_103A IBS Control Register

Reset: 0000 0000 0000 0000h. This register is a read-only copy of F3x1CC.

| Bits | Description                                                                                                                                                                                           |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:9 | Reserved.                                                                                                                                                                                             |
| 8    | LvtOffsetVal: local vector table offset valid. Read-only. 1=The offset in LvtOffset is valid.                                                                                                         |
| 7:4  | Reserved.                                                                                                                                                                                             |
| 3:0  | <b>LvtOffset: local vector table offset</b> . Read-only. This specifies the address of the IBS LVT entry in the APIC registers as follows: LVT address = (LvtOffset << 4) + 500h (see APIC[530:500]). |

#### 3.14 Performance Counter Events

This section provides the performance counter events that may be selected through [The Performance Event Select Register (PERF\_CTL[3:0])] MSRC001\_00[03:00][EventSelect and UnitMask]. See that register and [The Performance Event Counter Registers (PERF\_CTR[3:0])] MSRC001\_00[07:04] for details.

# 3.14.1 Floating Point Events

See the following events for additional floating point information:

- EventSelect 0CBh [Retired MMX<sup>TM</sup>/FP Instructions] on page 348.
- EventSelect 0DBh [FPU Exceptions] on page 350.

# **EventSelect 000h Dispatched FPU Operations**

The number of operations (uops) dispatched to the FPU execution pipelines. This event reflects how busy the FPU pipelines are. This includes all operations done by x87, MMX<sup>TM</sup> and SSE instructions, including moves. Each increment represents a one-cycle dispatch event; packed 128-bit SSE operations count as two ops in 64-bit FPU implementations; scalar operations count as one. This event is a speculative event. (See also Event-Select 0CBh). Note: Since this event includes non-numeric operations it is not suitable for measuring MFLOPs.

| UnitMask | Description                                           |
|----------|-------------------------------------------------------|
| 01h      | Add pipe ops excluding load ops and SSE move ops      |
| 02h      | Multiply pipe ops excluding load ops and SSE move ops |
| 04h      | Store pipe ops excluding load ops and SSE move ops    |
| 08h      | Add pipe load ops and SSE move ops                    |
| 10h      | Multiply pipe load ops and SSE move ops               |
| 20h      | Store pipe load ops and SSE move ops                  |

### EventSelect 001h Cycles in which the FPU is Empty

The number of cycles in which the FPU is empty. Invert this (MSRC001\_00[03:00][Invert]=1) to count cycles in which at least one FPU operation is present in the FPU.

#### **EventSelect 002h Dispatched Fast Flag FPU Operations**

The number of FPU operations that use the fast flag interface (e.g. FCOMI, COMISS, COMISD, UCOMISS, UCOMISD, MOVD, CVTSD2SI). This event is a speculative event.

### **EventSelect 003h Retired SSE Operations**

The number of SSE operations retired. This counter can count either FLOPS (UnitMask bit 6 = 1) or uops (UnitMask bit 6 = 0).

| UnitMask | Description                             |
|----------|-----------------------------------------|
| 01h      | Single precision add/subtract ops       |
| 02h      | Single precision multiply ops           |
| 04h      | Single precision divide/square root ops |

| 08h | Double precision add/subtract ops       |
|-----|-----------------------------------------|
| 10h | Double precision multiply ops           |
| 20h | Double precision divide/square root ops |
| 40h | Op type: 0=uops. 1=FLOPS                |

#### **EventSelect 004h Retired Move Ops**

The number of move uops retired. Merging low quadword move ops copy the lower 64 bits of a source register to the upper 64 bits of a destination register. The lower 64 bits of the destination register remain unchanged. Merging high quadword move ops copy the upper 64 bits of a source register to the lower 64 bits of a destination register. The upper 64 bits of the destination register remain unchanged.

| UnitMask | Description                     |
|----------|---------------------------------|
| 01h      | Merging low quadword move uops  |
| 02h      | Merging high quadword move uops |
| 04h      | All other merging move uops     |
| 08h      | All other move uops             |

# **EventSelect 005h Retired Serializing Ops**

The number of serializing uops retired. A bottom-executing uop is not issued until it is the oldest non-retired uop in the FPU. Bottom-executing ops are most commonly seen with FSTSW and STMXCSR instructions. A bottom-serializing uop does not issue until it is the oldest non-issued uop in the FP scheduler. Bottom-serializing uops block all subsequent uops from being issued until the uop is issued. Bottom-serializing ops are most commonly seen with FLCDW and LDMXCSR instructions.

| UnitMas | Description                         |
|---------|-------------------------------------|
| 01h     | SSE bottom-executing uops retired   |
| 02h     | SSE bottom-serializing uops retired |
| 04h     | x87 bottom-executing uops retired   |
| 08h     | x87 bottom-serializing uops retired |

# EventSelect 006h Number of Cycles that a Serializing uop is in the FP Scheduler

See EventSelect 005h for a description of bottom-executing and bottom-serializing uop.

| UnitMask | Description                                                      |
|----------|------------------------------------------------------------------|
| 01h      | Number of cycles a bottom-execute uop is in the FP scheduler     |
| 02h      | Number of cycles a bottom-serializing uop is in the FP scheduler |

### 3.14.2 Load/Store and TLB Events

See the following events for additional Load/Store and TLB information:

• EventSelect 065h [Memory Requests by Type] on page 343.

#### **EventSelect 020h Segment Register Loads**

The number of segment register loads performed.

| UnitMask | Description |
|----------|-------------|
| 01h      | ES          |
| 02h      | CS          |
| 04h      | SS          |
| 08h      | DS          |
| 10h      | FS          |
| 20h      | GS          |
| 40h      | HS          |

# **EventSelect 021h Pipeline Restart Due to Self-Modifying Code**

The number of pipeline restarts caused by self-modifying code (a store that hits any instruction that has been fetched for execution beyond the instruction doing the store).

#### **EventSelect 022h Pipeline Restart Due to Probe Hit**

The number of pipeline restarts caused by an invalidating probe hitting on a speculative out-of-order load.

# EventSelect 023h LS Buffer 2 Full

The number of cycles that the LS2 buffer is full. This buffer holds stores waiting to retire as well as requests that missed the data cache and are waiting on a refill. This condition stalls further data cache accesses, although such stalls may be overlapped by independent instruction execution.

# **EventSelect 024h Locked Operations**

This event covers locked operations performed and their execution time. The execution time represented by the cycle counts is typically overlapped to a large extent with other instructions. The non-speculative cycles event is suitable for event-based profiling of lock operations that tend to miss in the cache.

| UnitMask | Description                                                                        |
|----------|------------------------------------------------------------------------------------|
| 01h      | The number of locked instructions executed                                         |
| 02h      | The number of cycles spent in speculative phase                                    |
| 04h      | The number of cycles spent in non-speculative phase (including cache miss penalty) |
| 08h      | The number of cycles waiting for a cache hit (cache miss penalty).                 |

#### **EventSelect 026h Retired CLFLUSH Instructions**

The number of CLFLUSH instructions retired.

#### **EventSelect 027h Retired CPUID Instructions**

The number of CPUID instructions retired.

# **EventSelect 02Ah Cancelled Store to Load Forward Operations**

Counts the number store to load forward operations that are cancelled.

| UnitMask | Description                                      |
|----------|--------------------------------------------------|
| 01h      | Address mismatches (starting byte not the same). |
| 02h      | Store is smaller than load.                      |
| 04h      | Misaligned.                                      |

#### **EventSelect 02Bh SMIs Received**

Counts the number of SMIs received by the processor.

#### 3.14.3 Data Cache Events

#### **EventSelect 040h Data Cache Accesses**

The number of accesses to the data cache for load and store references. This may include certain microcode scratchpad accesses, although these are generally rare. Each increment represents an eight-byte access, although the instruction may only be accessing a portion of that. This event is a speculative event.

### **EventSelect 041h Data Cache Misses**

The number of data cache references which missed in the data cache. This event is a speculative event.

Except in the case of streaming stores, only the first miss for a given line is included - access attempts by other instructions while the refill is still pending are not included in this event. So in the absence of streaming stores, each event reflects one 64-byte cache line refill, and counts of this event are the same as, or very close to, the combined count for EventSelect 042h.

Streaming stores however cause this event for every such store, since the target memory is not refilled into the cache. Hence this event should not be used as an indication of data cache refill activity - EventSelect 042h should be used for such measurements. See EventSelect 065h for an indication of streaming store activity. A large difference between this event (with all UnitMask bits set) and EventSelect 042h would be due mainly to streaming store activity and hardware prefetch requests.

### **EventSelect 042h Data Cache Refills from L2 or Northbridge**

The number of data cache refills satisfied from the L2 cache (and/or the northbridge), per the UnitMask. Unit-Mask bits 4:1 allow a breakdown of refills from the L2 by coherency state. UnitMask bit 0 reflects refills which missed in the L2, and provides the same measure as the combined sub-events of EventSelect 043h. Each increment reflects a 64-byte transfer. This event is a speculative event.

| UnitMask | Description                  |
|----------|------------------------------|
| 01h      | Refill from the northbridge  |
| 02h      | Shared-state line from L2    |
| 04h      | Exclusive-state line from L2 |
| 08h      | Owned-state line from L2     |
| 10h      | Modified-state line from L2  |

#### EventSelect 043h Data Cache Refills from the northbridge

The number of L1 cache refills satisfied from the northbridge (DRAM, L3 or another processor's cache), as opposed to the L2. The UnitMask selects lines in one or more specific coherency states. Each increment reflects a 64-byte transfer. This event is a speculative event.

| UnitMask | Description |
|----------|-------------|
| 01h      | Invalid     |
| 02h      | Shared      |
| 04h      | Exclusive   |
| 08h      | Owned       |
| 10h      | Modified    |

#### **EventSelect 044h Data Cache Lines Evicted**

The number of L1 data cache lines written to the L2 cache or system memory, having been displaced by L1 refills. The UnitMask may be used to count only victims in specific coherency states. Each increment represents a 64-byte transfer. This event is a speculative event.

In most cases, L1 victims are moved to the L2 cache, displacing an older cache line there. Lines brought into the data cache by PrefetchNTA instructions, however, are evicted directly to system memory (if dirty) or invalidated (if clean). The Invalid case (UnitMask value 01h) reflects the replacement of lines that would have been invalidated by probes for write operations from another processor or DMA activity. UnitMask 20h and 40h count all evictions regardless of cache line state. When either UnitMask 20h or 40h is enabled all other Unit-Masks should be disabled.

| UnitMask | Description                                                                          |
|----------|--------------------------------------------------------------------------------------|
| 01h      | Invalid                                                                              |
| 02h      | Shared                                                                               |
| 04h      | Exclusive                                                                            |
| 08h      | Owned                                                                                |
| 10h      | Modified                                                                             |
| 20h      | Cache line evicted was brought into the cache with by a PrefetchNTA instruction.     |
| 40h      | Cache line evicted was not brought into the cache with by a PrefetchNTA instruction. |

### EventSelect 045h L1 DTLB Miss and L2 DTLB Hit

The number of data cache accesses that miss in the L1 DTLB and hit in the L2 DTLB. This event is a speculative event.

| UnitMask | Description   |
|----------|---------------|
| 01h      | L2 4K TLB hit |
| 02h      | L2 2M TLB hit |

### EventSelect 046h L1 DTLB and L2 DTLB Miss

The number of data cache accesses that miss in both the L1 and L2 DTLBs. This event is a speculative event.

| UnitMask | Description   |
|----------|---------------|
| 01h      | 4K TLB reload |
| 02h      | 2M TLB reload |
| 04h      | 1G TLB reload |

### **EventSelect 047h Misaligned Accesses**

The number of data cache accesses that are misaligned. These are accesses which cross a sixteen-byte boundary. They incur an extra cache access (reflected in EventSelect 040h), and an extra cycle of latency on reads. This event is a speculative event.

### **EventSelect 048h Microarchitectural Late Cancel of an Access**

# **EventSelect 049h Microarchitectural Early Cancel of an Access**

# EventSelect 04Ah Single-bit ECC Errors Recorded by Scrubber

The number of single-bit errors corrected by either of the error detection/correction mechanisms in the data cache.

| UnitMask | Description               |
|----------|---------------------------|
| 01h      | Scrubber error            |
| 02h      | Piggyback scrubber errors |
| 04h      | Load pipe error           |
| 08h      | Store write pipe error    |

# **EventSelect 04Bh Prefetch Instructions Dispatched**

The number of prefetch instructions dispatched by the decoder. Such instructions may or may not cause a cache line transfer. All Dcache and L2 accesses, hits and misses by prefetch instructions, except for prefetch instructions that collide with an outstanding hardware prefetch, are included in these events. This event is a speculative event.

| UnitMask | Description                       |
|----------|-----------------------------------|
| 01h      | Load (Prefetch, PrefetchT0/T1/T2) |
| 02h      | Store (PrefetchW)                 |
| 04h      | NTA (PrefetchNTA)                 |

### **EventSelect 04Ch DCACHE Misses by Locked Instructions**

The number of data cache misses incurred by locked instructions. (The total number of locked instructions may be obtained from EventSelect 024h.)

Such misses may be satisfied from the L2 or system memory, but there is no provision for distinguishing between the two. When used for event-based profiling, this event tends to occur very close to the offending instructions. This event is also included in the basic Dcache miss event (EventSelect 041h).

| UnitMask | Description                              |
|----------|------------------------------------------|
| 02h      | Data cache misses by locked instructions |

#### EventSelect 04Dh L1 DTLB Hit

The number of data cache accesses that hit in the L1 DTLB. This event is a speculative event.

| UnitMask | Description   |
|----------|---------------|
| 01h      | L1 4K TLB hit |
| 02h      | L1 2M TLB hit |
| 04h      | L1 1G TLB hit |

#### **EventSelect 052h Ineffective Software Prefetchs**

The number of software prefetches that did not fetch data outside of the processor core.

| UnitMask | Description                      |
|----------|----------------------------------|
| 01h      | Software prefetch hit in the L1. |
| 08h      | Software prefetch hit in L2.     |

#### **EventSelect 054h Global TLB Flushes**

This event counts TLB flushes that flush TLB entries that have the global bit set.

### 3.14.4 L2 Cache and System Interface Events

### **EventSelect 065h Memory Requests by Type**

These events reflect accesses to uncacheable (UC) or write-combining (WC) memory regions (as defined by MTRR or PAT settings) and Streaming Store activity to WB memory. Both the WC and Streaming Store events reflect Write Combining buffer flushes, not individual store instructions. WC buffer flushes which typically consist of one 64-byte write to the system for each flush (assuming software typically fills a buffer before it gets flushed). A partially-filled buffer requires two or more smaller writes to the system. The WC event reflects flushes of WC buffers that are filled by stores to WC memory or streaming stores to WB memory. The Streaming Store event reflects only flushes due to streaming stores (which are typically only to WB memory). The difference between counts of these two events reflects the true amount of write events to WC memory.

| UnitMask | Description                                                               |
|----------|---------------------------------------------------------------------------|
| 01h      | Requests to non-cacheable (UC) memory                                     |
| 02h      | Requests to write-combining (WC) memory or WC buffer flushes to WB memory |
| 80h      | Streaming store (SS) requests                                             |

### EventSelect 067h Data Prefetcher

These events reflect requests made by the data prefetcher. UnitMask bit 1 counts total prefetch requests, while bit 0 counts requests where the target block is found in the L2 or data cache. The difference between the two represents actual data read (in units of 64-byte cache lines) from the system by the prefetcher. This is also

included in the count of EventSelect 07Fh, UnitMask bit 0 (combined with other L2 fill events).

| UnitMask | Description          |
|----------|----------------------|
| 01h      | Cancelled prefetches |
| 02h      | Prefetch attempts    |

# **EventSelect 06Ch Northbridge Read Responses by Coherency State**

The number of responses from the Northbridge for cache refill requests. The UnitMask may be used to select specific cache coherency states. Each increment represents one 64-byte cache line transferred from the Northbridge (DRAM, L3, or another cache, including another core on the same node) to the data cache, instruction cache or L2 cache (for data prefetcher and TLB table walks). Modified-state responses may be for Dcache store miss refills, PrefetchW software prefetches, hardware prefetches for a store-miss stream, or Change-to-Dirty requests that get a dirty (Owned) probe hit in another cache. Exclusive responses may be for any Icache refill, Dcache load miss refill, other software prefetches, hardware prefetches for a load-miss stream, or TLB table walks that miss in the L2 cache; Shared responses may be for any of those that hit a clean line in another cache.

| UnitMask | Description |
|----------|-------------|
| 01h      | Exclusive   |
| 02h      | Modified    |
| 04h      | Shared      |
| 10h      | Data Error  |

# **EventSelect 06Dh Octwords Written to System**

The number of octword (16-byte) data transfers from the processor to the system. These may be part of a 64-byte cache line writeback or a 64-byte dirty probe hit response, each of which would cause four increments; or a partial or complete Write Combining buffer flush (Sized Write), which could cause from one to eight increments.

| UnitMask | Description            |
|----------|------------------------|
| 01h      | Octword write transfer |

#### **EventSelect 076h CPU Clocks not Halted**

The number of clocks that the CPU is not in a halted state (due to STPCLK or a HALT instruction). Note: this event allows system idle time to be automatically factored out from IPC (or CPI) measurements, providing the OS halts the CPU when going idle. If the OS goes into an idle loop rather than halting, such calculations are influenced by the IPC of the idle loop.

#### **EventSelect 07Dh Requests to L2 Cache**

The number of requests to the L2 cache for Icache or Dcache fills, or page table lookups for the TLB. These events reflect only read requests to the L2. These include some amount of retries associated with address or resource conflicts. Such retries tend to occur more as the L2 gets busier, and in certain extreme cases (such as large block moves that overflow the L2) these extra requests can dominate the event count.

These extra requests are not a direct indication of performance impact - they simply reflect opportunistic accesses that don't complete. But because of this, they are not a good indication of actual cache line movement.

The Icache and Dcache miss and refill events (81h, 82h, 83h, 41h, 42h, 43h) provide a more accurate indication of this, and are the preferred way to measure such traffic.

| UnitMask | Description                 |
|----------|-----------------------------|
| 01h      | IC fill                     |
| 02h      | DC fill                     |
| 04h      | TLB fill (page table walks) |
| 08h      | Tag snoop request           |
| 10h      | Cancelled request           |
| 20h      | Hardware prefetch from DC   |

#### **EventSelect 07Eh L2 Cache Misses**

The number of requests that miss in the L2 cache. This may include some amount of speculative activity, as well as some amount of retried requests as described in EventSelect 07Dh. The IC-fill-miss and DC-fill-miss events tend to mirror the Icache and Dcache refill-from-system events (83h and EventSelect 043h, respectively), and tend to include more speculative activity than those events.

| UnitMask | Description                                                            |
|----------|------------------------------------------------------------------------|
| 01h      | IC fill                                                                |
| 02h      | DC fill (includes possible replays, whereas EventSelect 041h does not) |
| 04h      | TLB page table walk                                                    |
| 08h      | Hardware prefetch from DC                                              |

#### EventSelect 07Fh L2 Fill/Writeback

The number of lines written into the L2 cache due to victim writebacks from the Icache or Dcache, TLB page table walks and the hardware data prefetcher (UnitMask bit 0); or writebacks of dirty lines from the L2 to the system (UnitMask bit 1). Each increment represents a 64-byte cache line transfer.

Note: Victim writebacks from the Dcache may be measured separately using EventSelect 044h. However this is not quite the same as the Dcache component of this event, the main difference being PrefetchNTA lines. When these are evicted from the Dcache due to replacement, they are written out to system memory (if dirty) or simply invalidated (if clean), rather than being moved to the L2 cache.

| 1 | UnitMask | Description                                                                 |
|---|----------|-----------------------------------------------------------------------------|
|   | 01h      | L2 fills (victims from L1 caches, TLB page table walks and data prefetches) |
|   | 02h      | L2 Writebacks to system.                                                    |

#### 3.14.5 Instruction Cache Events

Note: All instruction cache events are speculative events unless specified otherwise.

### **EventSelect 080h Instruction Cache Fetches**

The number of instruction cache accesses by the instruction fetcher. Each access is an aligned 16 byte read, from which a varying number of instructions may be decoded.

#### **EventSelect 081h Instruction Cache Misses**

The number of instruction fetches and prefetch requests that miss in the instruction cache. This is typically equal to or very close to the sum of events 82h and 83h. Each miss results in a 64-byte cache line refill.

#### **EventSelect 082h Instruction Cache Refills from L2**

The number of instruction cache refills satisfied from the L2 cache. Each increment represents one 64-byte cache line transfer.

### **EventSelect 083h Instruction Cache Refills from System**

The number of instruction cache refills from system memory (or another cache). Each increment represents one 64-byte cache line transfer.

# EventSelect 084h L1 ITLB Miss, L2 ITLB Hit

The number of instruction fetches that miss in the L1 ITLB but hit in the L2 ITLB.

## EventSelect 085h L1 ITLB Miss, L2 ITLB Miss

The number of instruction fetches that miss in both the L1 and L2 ITLBs.

| UnitMask | Description                       |
|----------|-----------------------------------|
| 01h      | Instruction fetches to a 4K page. |
| 02h      | Instruction fetches to a 2M page. |

#### **EventSelect 086h Pipeline Restart Due to Instruction Stream Probe**

The number of pipeline restarts caused by invalidating probes that hit on the instruction stream currently being executed. This would happen if the active instruction stream was being modified by another processor in an MP system - typically a highly unlikely event.

#### **EventSelect 087h Instruction Fetch Stall**

The number of cycles the instruction fetcher is stalled. This may be for a variety of reasons such as branch predictor updates, unconditional branch bubbles, far jumps and cache misses, among others. May be overlapped by instruction dispatch stalls or instruction execution, such that these stalls don't necessarily impact performance.

#### **EventSelect 088h Return Stack Hits**

The number of near return instructions (RET or RET Iw) that get their return address from the return address stack (i.e. where the stack has not gone empty). This may include cases where the address is incorrect (return mispredicts). This may also include speculatively executed false-path returns. Return mispredicts are typically caused by the return address stack underflowing, however they may also be caused by an imbalance in calls vs. returns, such as doing a call but then popping the return address off the stack.

Note: This event cannot be reliably compared with events C9h and CAh (such as to calculate percentage of return mispredicts due to an empty return address stack), since it may include speculatively executed false-path returns that are not included in those retire-time events.

#### EventSelect 089h Return Stack Overflows

The number of (near) call instructions that cause the return address stack to overflow. When this happens, the

oldest entry is discarded. This count may include speculatively executed calls.

### **EventSelect 08Bh Instruction Cache Victims**

The number of cachelines evicticed from the instruction cache to the L2.

#### **EventSelect 08Ch Instruction Cache Lines Invalidated**

The number of instruction cache lines invalidated.

| UnitMask | Description                                                     |  |
|----------|-----------------------------------------------------------------|--|
| 01h      | nvalidating probe that did not hit any in-flight instructions.  |  |
| 02h      | Invalidating probe that hit one or more in-flight instructions. |  |
| 04h      | SMC that did not hit any in-flight instructions.                |  |
| 08h      | SMC that hit one or more in-flight instructions                 |  |

#### **EventSelect 099h ITLB Reloads**

The number of ITLB reload requests.

### **EventSelect 09Ah ITLB Reloads Aborted**

The number of ITLB reloads aborted.

#### 3.14.6 Execution Unit Events

See the following events for additional execution unit information:

- EventSelect 026h [Retired CLFLUSH Instructions] on page 339.
- EventSelect 027h [Retired CPUID Instructions] on page 339.
- EventSelect 076h [CPU Clocks not Halted] on page 344.

#### **EventSelect 0C0h Retired Instructions**

The number of instructions retired (execution completed and architectural state updated). This count includes exceptions and interrupts - each exception or interrupt is counted as one instruction.

#### **EventSelect 0C1h Retired uops**

The number of micro-ops retired. This includes all processor activity (instructions, exceptions, interrupts, microcode assists, etc.).

# **EventSelect 0C2h Retired Branch Instructions**

The number of branch instructions retired. This includes all types of architectural control flow changes, including exceptions and interrupts.

# **EventSelect 0C3h Retired Mispredicted Branch Instructions**

The number of branch instructions retired, of any type, that are not correctly predicted. This includes those for which prediction is not attempted (far control transfers, exceptions and interrupts).

#### **EventSelect 0C4h Retired Taken Branch Instructions**

The number of taken branches retired. This includes all types of architectural control flow changes, including exceptions and interrupts.

#### **EventSelect 0C5h Retired Taken Branch Instructions Mispredicted**

The number of retired taken branch instructions that are mispredicted.

#### **EventSelect 0C6h Retired Far Control Transfers**

The number of far control transfers retired including far call/jump/return, IRET, SYSCALL and SYSRET, plus exceptions and interrupts. Far control transfers are not subject to branch prediction.

## **EventSelect 0C7h Retired Branch Resyncs**

The number of resync branches. These reflect pipeline restarts due to certain microcode assists and events such as writes to the active instruction stream, among other things. Each occurrence reflects a restart penalty similar to a branch mispredict. This is relatively rare.

### **EventSelect 0C8h Retired Near Returns**

The number of near return instructions (RET or RET Iw) retired.

# **EventSelect 0C9h Retired Near Returns Mispredicted**

The number of near returns retired that are not correctly predicted by the return address predictor. Each such mispredict incurs the same penalty as a mispredicted conditional branch instruction.

# **EventSelect 0CAh Retired Indirect Branches Mispredicted**

The number of indirect branch instructions retired where the target address was not correctly predicted.

### EventSelect 0CBh Retired MMX<sup>TM</sup>/FP Instructions

The number of MMX<sup>TM</sup>, SSE or X87 instructions retired. The UnitMask allows the selection of the individual classes of instructions as given in the table. Each increment represents one complete instruction.

Note: Since this event includes non-numeric instructions it is not suitable for measuring MFLOPS.

| UnitMask | Description                                             |  |
|----------|---------------------------------------------------------|--|
| 01h      | x87 instructions                                        |  |
| 02h      | MMX <sup>TM</sup> and 3DNow! <sup>TM</sup> instructions |  |
| 04h      | SSE and SSE2 instructions                               |  |

# **EventSelect 0CCh Retired Fastpath Double Op Instructions**

| UnitMask | Description               |  |
|----------|---------------------------|--|
| 01h      | With low op in position 0 |  |
| 02h      | With low op in position 1 |  |
| 04h      | With low op in position 2 |  |

# **EventSelect 0CDh Interrupts-Masked Cycles**

The number of processor cycles where interrupts are masked (EFLAGS.IF = 0). Using edge-counting with this event gives the number of times IF is cleared; dividing the cycle-count value by this value gives the average length of time that interrupts are disabled on each instance. Compare the edge count with EventSelect 0CFh to

determine how often interrupts are disabled for interrupt handling vs. other reasons (e.g. critical sections).

# **EventSelect 0CEh Interrupts-Masked Cycles with Interrupt Pending**

The number of processor cycles where interrupts are masked (EFLAGS.IF = 0) and an interrupt is pending. Using edge-counting with this event and comparing the resulting count with the edge count for EventSelect 0CDh gives the proportion of interrupts for which handling is delayed due to prior interrupts being serviced, critical sections, etc. The cycle count value gives the total amount of time for such delays. The cycle count divided by the edge count gives the average length of each such delay.

# **EventSelect 0CFh Interrupts Taken**

The number of hardware interrupts taken. This does not include software interrupts (INT n instruction).

# **EventSelect 0D0h Decoder Empty**

The number of processor cycles where the decoder has nothing to dispatch (typically waiting on an instruction fetch that missed the Icache, or for the target fetch after a branch mispredict).

# **EventSelect 0D1h Dispatch Stalls**

The number of processor cycles where the decoder is stalled for any reason (has one or more instructions ready but can't dispatch them due to resource limitations in execution). This is the combined effect of events D2h - DAh, some of which may overlap; this event reflects the net stall cycles. The more common stall conditions (events D5h, D6h, D7h, D8h, and to a lesser extent D2) may overlap considerably. The occurrence of these stalls is highly dependent on the nature of the code being executed (instruction mix, memory reference patterns, etc.).

# **EventSelect 0D2h Dispatch Stall for Branch Abort to Retire**

The number of processor cycles the decoder is stalled waiting for the pipe to drain after a mispredicted branch. This stall occurs if the corrected target instruction reaches the dispatch stage before the pipe has emptied. See also EventSelect 0D1h.

# **EventSelect 0D3h Dispatch Stall for Serialization**

The number of processor cycles the decoder is stalled due to a serializing operation, which waits for the execution pipeline to drain. Relatively rare; mainly associated with system instructions. See also EventSelect 0D1h.

### **EventSelect 0D4h Dispatch Stall for Segment Load**

The number of processor cycles the decoder is stalled due to a segment load instruction being encountered while execution of a previous segment load operation is still pending. Relatively rare except in 16-bit code. See also EventSelect 0D1h.

### **EventSelect 0D5h Dispatch Stall for Reorder Buffer Full**

The number of processor cycles the decoder is stalled because the reorder buffer is full. May occur simultaneously with certain other stall conditions; see EventSelect 0D1h.

### **EventSelect 0D6h Dispatch Stall for Reservation Station Full**

The number of processor cycles the decoder is stalled because a required integer unit reservation stations is full. May occur simultaneously with certain other stall conditions; see EventSelect 0D1h.

### **EventSelect 0D7h Dispatch Stall for FPU Full**

The number of processor cycles the decoder is stalled because the scheduler for the Floating Point Unit is full. This condition can be caused by a lack of parallelism in FP-intensive code, or by cache misses on FP operand

loads (which could also show up as EventSelect 0D8h instead, depending on the nature of the instruction sequences). May occur simultaneously with certain other stall conditions; see EventSelect 0D1h

# **EventSelect 0D8h Dispatch Stall for LS Full**

The number of processor cycles the decoder is stalled because the Load/Store Unit is full. This generally occurs due to heavy cache miss activity. May occur simultaneously with certain other stall conditions; see EventSelect 0D1h.

# EventSelect 0D9h Dispatch Stall Waiting for All Quiet

The number of processor cycles the decoder is stalled waiting for all outstanding requests to the system to be resolved. Relatively rare; associated with certain system instructions and types of interrupts. May partially overlap certain other stall conditions; see EventSelect 0D1h.

# EventSelect 0DAh Dispatch Stall for Far Transfer or Resync to Retire

The number of processor cycles the decoder is stalled waiting for the execution pipeline to drain before dispatching the target instructions of a far control transfer or a Resync (an instruction stream restart associated with certain microcode assists). Relatively rare; does not overlap with other stall conditions. See also EventSelect 0D1h.

### **EventSelect 0DBh FPU Exceptions**

The number of floating point unit exceptions for microcode assists. The UnitMask may be used to isolate specific types of exceptions.

| UnitMask | Description             |  |
|----------|-------------------------|--|
| 01h      | x87 reclass microfaults |  |
| 02h      | SSE retype microfaults  |  |
| 04h      | SSE reclass microfaults |  |
| 08h      | SSE and x87 microtraps  |  |

# **EventSelect 0DCh DR0 Breakpoint Matches**

The number of matches on the address in breakpoint register DR0, per the breakpoint type specified in DR7. The breakpoint does not have to be enabled. Each instruction breakpoint match incurs an overhead of about 120 cycles; load/store breakpoint matches do not incur any overhead.

#### **EventSelect 0DDh DR1 Breakpoint Matches**

The number of matches on the address in breakpoint register DR1. See notes for EventSelect 0DCh.

# **EventSelect 0DEh DR2 Breakpoint Matches**

The number of matches on the address in breakpoint register DR2. See notes for EventSelect 0DCh.

#### **EventSelect 0DFh DR3 Breakpoint Matches**

The number of matches on the address in breakpoint register DR3. See notes for EventSelect 0DCh.

# **3.14.7 Memory Controller Events**

# **EventSelect 0E0h DRAM Accesses**

The number of memory accesses performed by the local DRAM controller. The UnitMask may be used to iso-

late the different DRAM page access cases. Page miss cases incur an extra latency to open a page; page conflict cases incur both a page-close as well as page-open penalties. These penalties may be overlapped by DRAM accesses for other requests and don't necessarily represent lost DRAM bandwidth. The associated penalties are as follows:

Page miss: Trcd (DRAM RAS-to-CAS delay)

Page conflict: Trp + Trcd (DRAM row-precharge time plus RAS-to-CAS delay)

Each DRAM access represents one 64-byte block of data transferred if the DRAM is configured for 64-byte granularity, or one 32-byte block if the DRAM is configured for 32-byte granularity. (The latter is only applicable to single-channel DRAM systems, which may be configured either way.)

| UnitMask | Description        |
|----------|--------------------|
| 01h      | DCT0 Page hit      |
| 02h      | DCT0 Page Miss     |
| 04h      | DCT0 Page Conflict |
| 08h      | DCT1 Page hit      |
| 10h      | DCT1 Page Miss     |
| 20h      | DCT1 Page Conflict |
| 40h      | Write request      |
| 80h      | Read request       |

### **EventSelect 0E1h DRAM Controller Page Table Overflows**

The number of page table overflows in the local DRAM controller. This table maintains information about which DRAM pages are open. An overflow occurs when a request for a new page arrives when the maximum number of pages are already open. Each occurrence reflects an access latency penalty equivalent to a page conflict.

| UnitMask | Description              |  |
|----------|--------------------------|--|
| 01h      | DCT0 Page Table Overflow |  |
| 02h      | DCT1 Page Table Overflow |  |

#### **EventSelect 0E2h Memory Controller DRAM Command Slots Missed**

| UnitMask | Description               |  |
|----------|---------------------------|--|
| 01h      | DCT0 Command Slots Missed |  |
| 02h      | DCT1 Command Slots Missed |  |

#### **EventSelect 0E3h Memory Controller Turnarounds**

The number of turnarounds on the local DRAM data bus. The UnitMask may be used to isolate the different cases. These represent lost DRAM bandwidth, which may be calculated as follows (in bytes per occurrence):

DIMM turnaround: DRAM\_width\_in\_bytes \* 2 edges\_per\_memclk \* 2

R/W turnaround: DRAM\_width\_in\_bytes \* 2 edges\_per\_memclk \* 1

R/W turnaround: DRAM\_width\_in\_bytes \* 2 edges\_per\_memclk \* (Tcl-1)

where DRAM\_width\_in\_bytes is 8 or 16 (for single- or dual-channel systems), and Tcl is the CAS latency of the DRAM in memory system clock cycles (where the memory clock for DDR-400, or PC3200 DIMMS, for example, would be 200 MHz).

| UnitMask | Description                        |
|----------|------------------------------------|
| 01h      | DCT0 DIMM (chip select) turnaround |
| 02h      | DCT0 Read to write turnaround      |
| 04h      | DCT0 Write to read turnaround      |
| 08h      | DCT1 DIMM (chip select) turnaround |
| 10h      | DCT1 Read to write turnaround      |
| 20h      | DCT1 Write to read turnaround      |

# **EventSelect 0E4h Memory Controller Bypass Counter Saturation**

| UnitMask | Description                              |  |
|----------|------------------------------------------|--|
| 01h      | Memory controller high priority bypass   |  |
| 02h      | Memory controller medium priority bypass |  |
| 04h      | DCT0 DCQ bypass                          |  |
| 08h      | DCT1 DCQ bypass                          |  |

# **EventSelect 0E8h Thermal Status**

| UnitMask | Description                                   |  |
|----------|-----------------------------------------------|--|
| 04h      | Tumber of times the HTC trip point is crossed |  |
| 08h      | Number of clocks when STC trip point active   |  |
| 10h      | Number of times the STC trip point is crossed |  |
| 20h      | Number of clocks HTC P-state is inactive.     |  |
| 40h      | Number of clocks HTC P-state is active        |  |

## EventSelect 0E9h CPU/IO Requests to Memory/IO

These events reflect request flow between units and nodes, as selected by the UnitMask. The UnitMask is divided into two fields: request type (CPU or IO access to IO or Memory) and source/target location (local vs. remote). One or more requests types must be enabled via bits 3:0, and at least one source and one target location must be selected via bits 7:4. Each event reflects a request of the selected type(s) going from the selected source(s) to the selected target(s).

Not all possible paths are supported. The following table shows the UnitMask values that are valid for each request type:

| Source/Target    | CPU to Mem | CPU to IO | IO to Mem | IO to IO |
|------------------|------------|-----------|-----------|----------|
| Local -> Local   | A8h        | A4h       | A2h       | A1h      |
| Local -> Remote  | 98h        | 94h       | 92h       | 91h      |
| Remote -> Local  | -          | 64h       | -         | 61h      |
| Remote -> Remote | -          | -         | -         | -        |

Any of the mask values shown may be logically ORed to combine the events. For instance, local CPU requests to both local and remote nodes would be  $A8h \mid 98h = B8h$ . Any CPU to any IO would be  $A4h \mid 94h \mid 64h = F4h$  (but remote CPU to remote IO requests would not be included).

Note: It is not possible to tell from these events how much data is going in which direction, as there is no distinction between reads and writes. Also, particularly for IO, the requests may be for varying amounts of data, anywhere from one to sixty-four bytes. For a direct measure of the amount and direction of data flowing between nodes, use events F6h, F7h and F8h.

| UnitMask | Description      |
|----------|------------------|
| 01h      | IO to IO         |
| 02h      | IO to Mem        |
| 04h      | CPU to IO        |
| 08h      | CPU to Mem       |
| 10h      | To remote node   |
| 20h      | To local node    |
| 40h      | From remote node |
| 80h      | From local node  |

# **EventSelect 0EAh Cache Block Commands**

The number of requests made to the system for cache line transfers or coherency state changes, by request type. Each increment represents one cache line transfer, except for Change-to-Dirty. If a Change-to-Dirty request hits on a line in another processor's cache that's in the Owned state, it causes a cache line transfer, otherwise there is no data transfer associated with Change-to-Dirty requests.

| UnitMask | Description                                                   |
|----------|---------------------------------------------------------------|
| 01h      | Victim Block (Writeback)                                      |
| 04h      | Read Block (Deache load miss refill)                          |
| 08h      | Read Block Shared (Icache refill)                             |
| 10h      | Read Block Modified (Dcache store miss refill)                |
| 20h      | Change to Dirty (first store to clean block already in cache) |

# **EventSelect 0EBh Sized Commands**

The number of Sized Read/Write commands handled by the System Request Interface (local processor and hostbridge interface to the system). These commands may originate from the processor or hostbridge. Typical uses of the various Sized Read/Write commands are given in the UnitMask table. See also EventSelect 0ECh,

which provides a separate measure of Hostbridge accesses.

| UnitMask | Description                       | Typical Usage                                                                                    |
|----------|-----------------------------------|--------------------------------------------------------------------------------------------------|
| 01h      | Non-Posted SzWr Byte (1-32 bytes) | Legacy or mapped IO, typically 1-4 bytes                                                         |
| 02h      | Non-Posted SzWr DW (1-16 dwords)  | Legacy or mapped IO, typically 1 DWORD                                                           |
| 04h      | Posted SzWr Byte (1-32 bytes)     | Sub-cache-line DMA writes, size varies; also flushes of partially-filled Write Combining buffer  |
| 08h      | Posted SzWr DW (1-16 dwords)      | Block-oriented DMA writes, often cache-line sized; also processor Write Combining buffer flushes |
| 10h      | SzRd Byte (4 bytes)               | Legacy or mapped IO                                                                              |
| 20h      | SzRd DW (1-16 dwords)             | Block-oriented DMA reads, typically cache-line size                                              |

## **EventSelect 0ECh Probe Responses and Upstream Requests**

This covers two unrelated sets of events: cache probe results, and requests received by the hostbridge from devices on non-coherent links.

**Probe results**: These events reflect the results of probes sent from a memory controller to local caches. They provide an indication of the degree data and code is shared between processors (or moved between processors due to process migration). The dirty-hit events indicate the transfer of a 64-byte cache line to the requestor (for a read or cache refill) or the target memory (for a write). The system bandwidth used by these, in terms of bytes per unit of time, may be calculated as 64 times the event count, divided by the elapsed time. Sized writes to memory that cover a full cache line do not incur this cache line transfer -- they simply invalidate the line and are reported as clean hits. Cache line transfers occur for Change2Dirty requests that hit cache lines in the Owned state. (Such cache lines are counted as Modified-state refills for EventSelect 06Ch, System Read Responses.)

**Upstream requests**: The upstream read and write events reflect requests originating from a device on a local IO link. The two read events allow display refresh traffic in a UMA system to be measured separately from other DMA activity. Display refresh traffic is typically dominated by 64-byte transfers. Non-display-related DMA accesses may be anywhere from 1 to 64 bytes in size, but may be dominated by a particular size such as 32 or 64 bytes, depending on the nature of the devices.

| UnitMask | Description                                                                     |
|----------|---------------------------------------------------------------------------------|
| 01h      | Probe miss                                                                      |
| 02h      | Probe hit clean                                                                 |
| 04h      | Probe hit dirty without memory cancel (probed by Sized Write or Change2Dirty)   |
| 08h      | Probe hit dirty with memory cancel (probed by DMA read or cache refill request) |
| 10h      | Upstream display refresh/ISOC reads                                             |
| 20h      | Upstream non-display refresh reads                                              |
| 40h      | Upstream ISOC writes                                                            |
| 80h      | Upstream non-ISOC writes                                                        |

# **EventSelect 0EEh GART Events**

These events reflect GART activity, and in particular allow one to calculate the GART TLB miss ratio as GART\_miss\_count divided by GART\_aperture\_hit\_count. GART aperture accesses are typically from IO

devices as opposed to the processor, and generally from a 3D graphics accelerator, but can be from other devices when the GART is used as an IOMMU.

| UnitMask | Description                                 |
|----------|---------------------------------------------|
| 01h      | GART aperture hit on access from CPU        |
| 02h      | GART aperture hit on access from IO         |
| 04h      | GART miss                                   |
| 08h      | GART/DEV Request hit table walk in progress |
| 10h      | DEV hit                                     |
| 20h      | DEV miss                                    |
| 40h      | DEV error                                   |
| 80h      | GART/DEV multiple table walk in progress    |

# **EventSelect 1F0h Memory Controller Requests**

Read/Write requests: The read/write request events reflect the total number of commands sent to the DRAM controller.

Sized Read/Write activity: The Sized Read/Write events reflect 32- or 64-byte transfers (as opposed to other sizes which could be anywhere between 1 and 64 bytes), from either the processor or the Hostbridge (on any node in an MP system). Such accesses from the processor would be due only to write combining buffer flushes, where 32-byte accesses would reflect flushes of partially-filled buffers. EventSelect 065h provides a count of sized write requests associated with WC buffer flushes; comparing that with counts for these events (providing there is very little Hostbridge activity at the same time) gives an indication of how efficiently the write combining buffers are being used. EventSelect 065h may also be useful in factoring out WC flushes when comparing these events with the Upstream Requests component of EventSelect 06Ch.

| UnitMask | Description                                                                |
|----------|----------------------------------------------------------------------------|
| 01h      | Write requests sent to the DCT                                             |
| 02h      | Read requests (including prefetch requests) sent to the DCT                |
| 04h      | Prefetch requests sent to the DCT                                          |
| 08h      | 32 Bytes Sized Writes                                                      |
| 10h      | 64 Bytes Sized Writes                                                      |
| 20h      | 32 Bytes Sized Reads                                                       |
| 40h      | 64 Byte Sized Reads                                                        |
| 80h      | Read requests sent to the DCT while writes requests are pending in the DCT |

#### 3.14.8 Crossbar Events

### **EventSelect 1E0h CPU to DRAM Requests to Target Node**

This event counts all DRAM reads and writes generated by cores on the local node to the targeted node in the coherent fabric. This counter can be used to observe processor data affinity in NUMA aware operating systems.

| UnitMask | Description               |
|----------|---------------------------|
| 01h      | From Local node to Node 0 |

| 02h | From Local node to Node 1 |
|-----|---------------------------|
| 04h | From Local node to Node 2 |
| 08h | From Local node to Node 3 |
| 10h | From Local node to Node 4 |
| 20h | From Local node to Node 5 |
| 40h | From Local node to Node 6 |
| 80h | From Local node to Node 7 |

### **EventSelect 1E1h IO to DRAM Requests to Target Node**

This event counts all DRAM reads and writes generated by IO devices attached to the IO links of the local node the targeted node in the coherent fabric. This counter can be used to observe IO device data affinity in NUMA aware operating systems.

| UnitMask | Description               |
|----------|---------------------------|
| 01h      | From Local node to Node 0 |
| 02h      | From Local node to Node 1 |
| 04h      | From Local node to Node 2 |
| 08h      | From Local node to Node 3 |
| 10h      | From Local node to Node 4 |
| 20h      | From Local node to Node 5 |
| 40h      | From Local node to Node 6 |
| 80h      | From Local node to Node 7 |

# **EventSelect 1E2h CPU Read Command Latency to Target Node 0-3**

This event counts the number of NB clocks from when the targeted command is received in the NB to when the targeted command completes. This event only tracks one outstanding command at a time. To determine latency between the local node and a remote node set UnitMask[7:4] to select the node and UnitMask[3:0] to select the read command type. The count returned by the counter should be divided by the count returned by EventSelect 1E3h do determine the average latency for the command type.

| UnitMask | Description               |
|----------|---------------------------|
| 01h      | Read block                |
| 02h      | Read block shared         |
| 04h      | Read block modified       |
| 08h      | Change to Dirty           |
| 10h      | From Local node to Node 0 |
| 20h      | From Local node to Node 1 |
| 40h      | From Local node to Node 2 |
| 80h      | From Local node to Node 3 |

# EventSelect 1E3h CPU Read Command Requests to Target Node 0-3

This event counts the number of requests that a latency measurement is made for using EventSelect 1E2h. To determine the number of commands that a latency measurement are made for between the local node and a remote node set UnitMask[7:4] to select the node and UnitMask[3:0] to select the read command type.

| UnitMask | Description               |
|----------|---------------------------|
| 01h      | Read block                |
| 02h      | Read block shared         |
| 04h      | Read block modified       |
| 08h      | Change to Dirty           |
| 10h      | From Local node to Node 0 |
| 20h      | From Local node to Node 1 |
| 40h      | From Local node to Node 2 |
| 80h      | From Local node to Node 3 |

# EventSelect 1E4h CPU Read Command Latency to Target Node 4-7

This event counts the number of NB clocks from when the targeted command is received in the NB to when the targeted command completes. This event only tracks one outstanding command at a time. To determine latency between the local node and a remote node set UnitMask[7:4] to select the node and UnitMask[3:0] to select the read command type. The count returned by the counter should be divided by the count returned by EventSelect 1E5h do determine the average latency for the command type.

| UnitMask | Description               |
|----------|---------------------------|
| 01h      | Read block                |
| 02h      | Read block shared         |
| 04h      | Read block modified       |
| 08h      | Change to Dirty           |
| 10h      | From Local node to Node 4 |
| 20h      | From Local node to Node 5 |
| 40h      | From Local node to Node 6 |
| 80h      | From Local node to Node 7 |

### EventSelect 1E5h CPU Read Command Requests to Target Node 4-7

This event counts the number of requests that a latency measurement is made for using EventSelect 1E4h. To determine the number of commands that a latency measurement are made for between the local node and a remote node set UnitMask[7:4] to select the node and UnitMask[3:0] to select the read command type.

| UnitMask | Description               |
|----------|---------------------------|
| 01h      | Read block                |
| 02h      | Read block shared         |
| 04h      | Read block modified       |
| 08h      | Change to Dirty           |
| 10h      | From Local node to Node 4 |

| 20h | From Local node to Node 5 |
|-----|---------------------------|
| 40h | From Local node to Node 6 |
| 80h | From Local node to Node 7 |

# EventSelect 1E6h CPU Command Latency to Target Node 0-3/4-7

This event counts the number of NB clocks from when the targeted command is received in the NB to when the targeted command completes. This event only tracks one outstanding command at a time. To determine latency between the local node and a remote node set UnitMask[7:4] to select the node, UnitMask[3] to select the node group and UnitMask[3:0] to select the command type. The count returned by the counter should be divided by the count returned by EventSelect 1E7h do determine the average latency for the command type.

| UnitMask | Description                                   |
|----------|-----------------------------------------------|
| 01h      | Read Sized                                    |
| 02h      | Write Sized                                   |
| 04h      | Victim Block                                  |
| 08h      | Node Group Select. 0=Nodes 0-3. 1= Nodes 4-7. |
| 10h      | From Local node to Node 0/4                   |
| 20h      | From Local node to Node 1/5                   |
| 40h      | From Local node to Node 2/6                   |
| 80h      | From Local node to Node 3/7                   |

### **EventSelect 1E7h CPU Requests to Target Node 0-3/4-7**

This event counts the number of requests that a latency measurement is made for using EventSelect 1E6h. To determine the number of commands that a latency measurement are made for between the local node and a remote node set UnitMask[7:4] to select the node, UnitMask[3] to select the node group and UnitMask[3:0] to select the command type.

| UnitMask | Description                                   |
|----------|-----------------------------------------------|
| 01h      | Read Sized                                    |
| 02h      | Write Sized                                   |
| 04h      | Victim Block                                  |
| 08h      | Node Group Select. 0=Nodes 0-3. 1= Nodes 4-7. |
| 10h      | From Local node to Node 0/4                   |
| 20h      | From Local node to Node 1/5                   |
| 40h      | From Local node to Node 2/6                   |
| 80h      | From Local node to Node 3/7                   |

#### 3.14.9 Link Events

EventSelect 0F6h HyperTransport<sup>TM</sup> Link 0 Transmit Bandwidth EventSelect 0F7h HyperTransport<sup>TM</sup> Link 1 Transmit Bandwidth EventSelect 0F8h HyperTransport<sup>TM</sup> Link 2 Transmit Bandwidth EventSelect 1F9h HyperTransport<sup>TM</sup> Link 3 Transmit Bandwidth

The number of dwords transmitted (or unused, in the case of Nops) on the outgoing side of the HyperTransport<sup>TM</sup> links. The sum of UnitMask[5:0] directly reflects the maximum transmission rate of the link. Link utilization may be calculated by dividing the combined Command, Address extension, Data, Buffer Release and Per packet CRC count (UnitMask 02Fh) by that value plus the Nop count (UnitMask 10h). Bandwidth in terms of bytes per unit time for any one component or combination of components is calculated by multiplying the count by four and dividing by elapsed time.

The Data event provides a direct indication of the flow of data around the system. Translating this link-based view into a source/target node based view requires knowledge of the system layout (i.e. which links connect to which nodes).

UnitMask[7] specifies the sublink to count if the link is unganged.

| UnitMask | Description                  |
|----------|------------------------------|
| 01h      | Command DWORD sent           |
| 02h      | Data DWORD sent              |
| 04h      | Buffer release DWORD sent    |
| 08h      | Nop DW sent (idle)           |
| 10h      | Address extension DWORD sent |
| 20h      | Per packet CRC sent          |
| 80h      | SubLink Mask                 |

#### **3.14.10 L3** Cache Events

### EventSelect 4E0h Read Request to L3 Cache

This event tracks the read requests from each core to the L3 cache including read requests that are cancelled. The core tracked is selected using UnitMask[7:4]. One or more cores must be selected. To determine the total number of read requests from one core, select only a single core using UnitMask[7:4] and set UnitMask[2:0] to 111b.

| UnitMask | Description                                |
|----------|--------------------------------------------|
| 01h      | Read Block Exclusive (Data cache read)     |
| 02h      | Read Block Shared (Instruction cache read) |
| 04h      | Read Block Modify                          |
| 10h      | Core 0 Select                              |
| 20h      | Core 1 Select                              |
| 40h      | Core 2 Select                              |
| 80h      | Core 3 Select                              |

#### **EventSelect 4E1h L3 Cache Misses**

This event counts the number of L3 cache misses for accesses from each core. The core tracked is selected using UnitMask[7:4]. One or more cores must be selected. To determine the total number of cache misses from one core, select only a single core using UnitMask[7:4] and set UnitMask[2:0] to 111b. The approximate number of L3 hits can be determined by subtracting this event from EventSelect 4E0h.

| UnitMask | Description                                |
|----------|--------------------------------------------|
| 01h      | Read Block Exclusive (Data cache read)     |
| 02h      | Read Block Shared (Instruction cache read) |
| 04h      | Read Block Modify                          |
| 10h      | Core 0 Select                              |
| 20h      | Core 1 Select                              |
| 40h      | Core 2 Select                              |
| 80h      | Core 3 Select                              |

# EventSelect 4E2h L3 Fills caused by L2 Evictions

This event counts the number of L3 fills caused by L2 evictions. The core tracked is selected using UnitMask[7:4]. One or more cores must be selected.

| UnitMask | Description   |
|----------|---------------|
| 01h      | Shared        |
| 02h      | Exclusive     |
| 04h      | Owned         |
| 08h      | Modified      |
| 10h      | Core 0 Select |
| 20h      | Core 1 Select |
| 40h      | Core 2 Select |
| 80h      | Core 3 Select |

#### **EventSelect 4E3h L3 Evictions**

This event counts the state of the L3 lines when they are evicted from the L3 cache.

| UnitMask | Description |
|----------|-------------|
| 01h      | Shared      |
| 02h      | Exclusive   |
| 04h      | Owned       |
| 08h      | Modified    |

# 4 Register List

The following is a list of all storage elements, context, and registers provided in this document. Page numbers, register mnemonics, and register names are provided.

| 129 | SMMFEC0: SMM IO Trap Offset                                          | 166 | F2x[1, 0][5C:40]: DRAM CS Base Address Registers                |
|-----|----------------------------------------------------------------------|-----|-----------------------------------------------------------------|
| 129 | SMMFEC4: Local SMI Status                                            | 168 | F2x[1, 0][6C:60]: DRAM CS Mask Registers                        |
| 130 | SMMFEC8: SMM IO Restart Byte                                         |     | F2x[1, 0]78: DRAM Control Register                              |
| 131 | SMMFEC9: Auto Halt Restart Offset                                    | 170 | F2x[1, 0]7C: DRAM Initialization Register                       |
| 131 | SMMFECA: NMI Mask                                                    | 171 | F2x[1, 0]80: DRAM Bank Address Mapping Register                 |
| 131 | SMMFED8: SMM SVM State                                               | 173 | F2x[1, 0]84: DRAM MRS Register                                  |
| 131 | SMMFEFC: SMM-Revision Identifier                                     | 174 | F2x[1, 0]88: DRAM Timing Low Register                           |
| 131 | SMMFF00: SMM Base Address Register (SMM_BASE)                        | 177 | F2x[1, 0]8C: DRAM Timing High Register                          |
| 136 | IOCF8: IO-Space Configuration Address Register                       | 180 | F2x[1, 0]90: DRAM Configuration Low Register                    |
| 137 | IOCFC: IO-Space Configuration Data Port                              | 182 | F2x[1, 0]94: DRAM Configuration High Register                   |
| 137 | F0x00: Device/Vendor ID Register                                     | 185 | F2x[1, 0]98: DRAM Controller Additional Data Offset Register    |
| 137 | F0x04: Status/Command Register                                       | 186 | F2x[1, 0]9C: DRAM Controller Additional Data Port               |
| 138 | F0x08: Class Code/Revision ID Register                               | 186 | F2x[1, 0]9C_x00: DRAM Output Driver Compensation Control Regis- |
| 138 | F0x0C: Header Type Register                                          |     | ter                                                             |
| 138 | F0x34: Capabilities Pointer Register                                 | 187 | F2x[1, 0]9C_x[102:101, 02:01]: DRAM Write Data Timing           |
| 138 | F0x[5C:40]: Routing Table Registers                                  |     | [High:Low] Registers                                            |
| 139 | F0x60: Node ID Register                                              | 188 | F2x[1, 0]9C_x[103, 03]: DRAM Write ECC Timing Register          |
| 139 | F0x64: Unit ID Register                                              | 188 | F2x[1, 0]9C_x04: DRAM Address/Command Timing Control Register   |
| 140 | F0x68: Link Transaction Control Register                             | 190 | F2x[1, 0]9C_x[106:105, 06:05]: DRAM Read DQS Timing Control     |
| 142 | F0x6C: Link Initialization Control Register                          |     | [High:Low] Registers                                            |
| 143 | F0x[E0, C0, A0, 80]: Link Capabilities Registers                     | 191 | F2x[1, 0]9C_x[107, 07]: DRAM Read DQS ECC Timing Control Reg-   |
| 144 | F0x[E4, C4, A4, 84]: Link Control Registers                          |     | ister                                                           |
| 146 | F0x[E8, C8, A8, 88]: Link Frequency/Revision Registers               | 191 | F2x[1, 0]9C_x08: DRAM Phy Control Register                      |
| 147 | F0x[EC, CC, AC, 8C]: Link Feature Capability Registers               | 192 | F2x9C_x09: DRAM Phy Driver Calibration Register                 |
| 147 | F0x[F0, D0, B0, 90]: Link Base Channel Buffer Count Registers        | 192 | F2x9C_x0A: DRAM Phy Predriver Calibration Register              |
| 149 | F0x[F4, D4, B4, 94]: Link Isochronous Channel Buffer Count Registers | 194 | F2x[1, 0]9C_x0C: DRAM Phy Miscellaneous Register                |
| 149 | F0x[F8, D8, B8, 98]: Link Type Registers                             | 195 | F2x[1, 0]9C_x[2B:10]: DRAM DQS Receiver Enable Timing Control   |
| 150 | F0x[11C, 118, 114, 110]: Link Clumping Enable Registers              |     | Registers                                                       |
| 150 | F0x[12C, 128, 124, 120]: Sublink 1 Clumping Enable Registers         | 197 | F2x[1, 0]9C_x[45:30]: DRAM DQS Write Timing Control Registers   |
| 150 | F0x[14C:130]: Link Retry Registers                                   | 198 | F2x[1, 0]9C_x[51:50]: DRAM Phase Recovery Control Register      |
| 151 | F0x150: Link Global Retry Control Register                           |     | [High:Low] Registers                                            |
| 152 | F0x164: Coherent Link Traffic Distribution Register                  | 199 | F2x[1, 0]9C_x52: DRAM ECC Phase Recovery Control Register       |
| 153 | F0x168: Extended Link Transaction Control Register                   | 199 | F2x[1, 0]9C_x53: Write Levelization Error Register              |
| 153 | F0x16C: Link Global Extended Control Register                        | 200 | F2x[1, 0]A0: DRAM Controller Miscellaneous Register             |
| 154 | F0x[18C:170]: Link Extended Control Registers                        | 200 | F2x[1, 0]A8: DRAM Controller Miscellaneous Register 2           |
| 156 | F0x1A0: Link Initialization Status Register                          | 200 | F2x110: DRAM Controller Select Low Register                     |
| 156 | F1x00: Device/Vendor ID Register                                     | 201 | F2x114: DRAM Controller Select High Register                    |
| 156 | F1x08: Class Code/Revision ID Register                               | 202 | F2x118: Memory Controller Configuration Low Register            |
| 157 | F1x0C: Header Type Register                                          | 202 | F2x11C: Memory Controller Configuration High Register           |
| 157 | F1x[1, 0][7C:40]: DRAM Base/Limit Registers                          | 205 | F3x00: Device/Vendor ID Register                                |
| 158 | F1x[BC:80]: Memory Mapped IO Base/Limit Registers                    | 205 | F3x04: Status/Command Register                                  |
| 160 | F1x[DC:C0]: IO-Space Base/Limit Registers                            | 205 | F3x08: Class Code/Revision ID Register                          |
| 161 | F1x[EC:E0]: Configuration Map Registers                              | 205 | F3x0C: Header Type Register                                     |
| 162 | F1xF0: DRAM Hole Address Register                                    | 206 | F3x34: Capability Pointer Register                              |
| 162 | F1xF4: VGA Enable Register                                           | 206 | F3x40: MCA NB Control Register                                  |
| 163 | F1x110: Extended Address Map Control Register                        | 208 | F3x44: MCA NB Configuration Register                            |
| 164 | F1x114: Extended Address Map Data Port                               | 211 | F3x48: MCA NB Status Low Register                               |
| 164 | F1x114_x2: Extended MMIO Address Base Registers                      | 217 | F3x4C: MCA NB Status High Register                              |
| 164 | F1x114_x3: Extended MMIO Address Mask Registers                      | 218 | F3x50: MCA NB Address Low Register                              |
| 165 | F1x120: DRAM Base System Address Register                            | 222 | F3x54: MCA NB Address High Register                             |
| 165 | F1x124: DRAM Limit System Address Register                           | 223 | F3x58: Scrub Rate Control Register                              |
| 166 | F1x1[7C:40]: DRAM Base/Limit Address High Registers                  | 223 | F3x5C: DRAM Scrub Address Low Register                          |
| 166 | F2x00: Device/Vendor ID Register                                     | 224 | F3x60: DRAM Scrub Address High Register                         |
| 166 | F2x08: Class Code/Revision ID Register                               | 224 | F3x64: Hardware Thermal Control (HTC) Register                  |
| 166 | F2xOC: Header Type Register                                          | 225 | F3x68: Software Thermal Control (STC) Register                  |
| 100 | 1 240 C. Houder Type Register                                        | 223 | 1 3/100. Software Thermal Control (STC) Register                |

F4x[F4, D4, B4, 94]: Sublink 1 Isochronous Channel Buffer Count

Registers



F3x6C: Data Buffer Count Register F4x[F8, D8, B8, 98]: Sublink 1 Link Type Registers 226 257 F3x70: SRI to XBAR Command Buffer Count Register 227 257 F4x1[98, 90, 88, 80]: Link Phy Offset Registers 258 228 F3x74: XBAR to SRI Command Buffer Count Register F4x1[9C, 94, 8C, 84]: Link Phy Data Port 229 F3x78: MCT to XBAR Buffer Count Register 258 F4x1[9C, 94, 8C, 84]\_x[D0, C0]: Link Phy Impedance Registers 230 259 F4x1[9C, 94, 8C, 84]\_x[D1, C1]: Link Phy Receiver Loop Filter Regis-F3x7C: Free List Buffer Count Register 231 F3x[84:80]: ACPI Power State Control Registers ters 260 232 F3x[8C:88]: NB Configuration High, Low Registers F4x1[9C, 94, 8C, 84]\_x[D3, C3]: Link Phy Timing Margin Registers 232 F3x90: GART Aperture Control Register 261 F4x1[9C, 94, 8C, 84]\_x[D4, C4]: Link Phy DFE and DFR Control Reg-233 F3x94: GART Aperture Base Register 234 262 F4x1[9C, 94, 8C, 84]\_x[D5, C5]: Link Phy Deemphasis Value Registers F3x98: GART Table Base Register 234 F3x9C: GART Cache Control Register 264 F4x1[9C, 94, 8C, 84]\_x[DF, CF]: Link FIFO Read Pointer Optimization 234 F3xA0: Power Control Miscellaneous Register Registers F4x1[9C, 94, 8C, 84]\_xE0: Link Phy Compensation Control Register 235 264 F3xA4: Reported Temperature Control Register F4x1[9C, 94, 8C, 84] x100: Link BIST Control Register 236 F3xB0: On-Line Spare Control Register 265 238 F3xD4: Clock Power/Timing Control 0 Register 266 F4x1[9C, 94, 8C, 84]\_x104: Link BIST Southbound TX Pattern Control 240 F3xD8: Clock Power/Timing Control 1 Register Register 266 F4x1[9C, 94, 8C, 84]\_x108: Link BIST Southbound TX Pattern Buffer 241 F3xDC: Clock Power/Timing Control 2 Register 242 F3xE4: Thermtrip Status Register 1 Register 267 F4x1[9C, 94, 8C, 84]\_x10C: Link BIST Southbound TX Mask Register 243 F3xE8: Northbridge Capabilities Register 244 F3xF0: DEV Capability Header Register F4x1[9C, 94, 8C, 84]\_x110: Link BIST Southbound TX Inversion Reg-244 F3xF4: DEV Function/Index Register 245 F3xF8: DEV Data Port 267 F4x1[9C, 94, 8C, 84]\_x114: Link BIST Southbound TX Pattern Buffer 245 F3xF8 x0: DEV Base Address/Limit Low Register 2 Register 245 F3xF8 x1: DEV Base Address/Limit High Register 267 F4x1[9C, 94, 8C, 84]\_x118: Link BIST Southbound TX Pattern Buffer 245 F3xF8 x2: DEV Map Register 2 Enable Register F3xF8\_x3: DEV Capabilities Register F4x1[9C, 94, 8C, 84]\_x11C: Link BIST Southbound TX Pattern Buffer 246 246 F3xF8\_x4: DEV Control Register Extension Register 247 F3xF8\_x5: DEV Error Status Register 268 F4x1[9C, 94, 8C, 84]\_x120: Link BIST Southbound TX Scramble Reg-247 F3xF8\_x6: DEV Error Address Low Register 268 F4x1[9C, 94, 8C, 84]\_x124: Link BIST Northbound RX Pattern Control F3xF8\_x7: DEV Error Address High Register 248 F3xF8\_x8: Reserved. 248 F3xFC: CPUID Family/Model Register 269 F4x1[9C, 94, 8C, 84]\_x128: Link BIST Northbound RX Pattern Buffer 248 F3x140: SRI to XCS Token Count Register 249 F3x144: MCT to XCS Token Count Register 269 F4x1[9C, 94, 8C, 84]\_x12C: Link BIST Northbound RX Mask Register 250 F3x1[54, 50, 4C, 48]: Link to XCS Token Count Registers 270 F4x1[9C, 94, 8C, 84]\_x130: Link BIST Northbound RX Inversion Reg-250 F3x158: Link to XCS Token Count Registers 250 F3x1[78, 70, 68, 60]: NB Machine Check Misc (Thresholding) 270 F4x1[9C, 94, 8C, 84]\_x134: Link BIST Northbound RX Pattern Buffer Registers 2 Register 251 F3x180: Extended NB MCA Configuration Register 270 F4x1[9C, 94, 8C, 84]\_x138: Link BIST Northbound RX Pattern Buffer 252 F3x190: Downcore Control Register 2 Enable Register 253 F3x1A0: L3 Buffer Count Register F4x1[9C, 94, 8C, 84]\_x13C: Link BIST Northbound RX Pattern Buffer 253 F3x1CC: IBS Control Register **Extension Register** 253 F3x1E4: SBI Control Register 271 F4x1[9C, 94, 8C, 84]\_x140: Link BIST Northbound RX Scramble Reg-254 F3x1E8: SBI Address Register 271 F4x1[9C, 94, 8C, 84]\_x144: Link BIST Northbound RX Error Status 254 F3x1EC: SBI Data Register 254 F3x1F0: Product Information Register 255 271 F4x1[9C, 94, 8C, 84]\_x[530A, 520A]: DLL Control and Test Register 3 F3x1FC: Product Information Register 255 F4x1[F0:E0]: P-state Specification Registers F4x00: Device/Vendor ID Register 255 F4x04: Status/Command Register 273 APIC20: APIC ID Register 256 F4x08: Class Code/Revision ID Register 273 APIC30: APIC Version Register 274 256 F4x0C: Header Type Register APIC80: Task Priority Register 274 256 F4x34: Capabilities Pointer Register APIC90: Arbitration Priority Register 256 F4x[E0, C0, A0, 80]: Sublink 1 Capability Registers 274 APICA0: Processor Priority Register 274 256 F4x[E4, C4, A4, 84]: Sublink 1 Control Registers APICB0: End of Interrupt Register 256 F4x[E8, C8, A8, 88]: Sublink 1 Frequency/Revision Registers 274 APICC0: Remote Read Register F4x[EC, CC, AC, 8C]: Sublink 1 Feature Capability Registers 275 APICD0: Logical Destination Register F4x[F0, D0, B0, 90]: Sublink 1 Base Channel Buffer Count Registers 275 APICE0: Destination Format Register

275

275

APICF0: Spurious Interrupt Vector Register

APIC[170:100]: In-Service Registers



| 276                     | APIC[1F0:180]: Trigger Mode Registers                                | 294 | MSR0000_01DD: Last Exception From IP Register                 |
|-------------------------|----------------------------------------------------------------------|-----|---------------------------------------------------------------|
| 276                     | APIC[270:200]: Interrupt Request Registers                           | 294 | MSR0000_01DE: Last Exception To IP Register                   |
| 276                     | APIC280: Error Status Register                                       | 294 | MSR0000_02[0F:00]: Variable-Size MTRRs (MTRRphysBasen and     |
| 277                     | APIC300: Interrupt Command Register Low                              |     | MTRRphysMaskn)                                                |
| 278                     | APIC310: Interrupt Command Register High                             | 295 | MSR0000_02[6F:68, 59, 58, 50]: Fixed-Size MTRRs (MTRRfixn)    |
| 278                     | APIC320: Timer Local Vector Table Entry                              | 297 | MSR0000_0277: Page Attribute Table Register (PAT)             |
| 279                     | APIC330: Thermal Local Vector Table Entry                            | 297 | MSR0000_02FF: MTRR Default Memory Type Register               |
| 279                     | APIC340: Performance Counter Vector Table Entry                      |     | (MTRRdefType)                                                 |
| 279                     | APIC350: Local Interrupt 0 (Legacy INTR) Local Vector Table Entry    | 298 | MSR0000_0400: DC Machine Check Control Register (MC0_CTL)     |
| 280                     | APIC360: Local Interrupt 1(Legacy NMI) Local Vector Table Entry      | 298 | MSR0000_0401: DC Machine Check Status Register (MC0_STATUS)   |
| 280                     | APIC370: Error Local Vector Table Entry                              | 300 | MSR0000_0402: DC Machine Check Address Register (MC0_ADDR)    |
| 280                     | APIC380: Timer Initial Count Register                                | 301 | MSR0000_0403: DC Machine Check Miscellaneous Register         |
| 281                     | APIC390: Timer Current Count Register                                |     | (MC0_MISC)                                                    |
| 281                     | APIC3E0: Timer Divide Configuration Register                         | 301 | MSR0000_0404: IC Machine Check Control Register (MC1_CTL)     |
| 281                     | APIC400: Extended APIC Feature Register                              | 302 | MSR0000_0405: IC Machine Check Status Register (MC1_STATUS)   |
| 282                     | APIC410: Extended APIC Control Register                              | 303 | MSR0000_0406: IC Machine Check Address Register (MC1_ADDR)    |
| 282                     | APIC420: Specific End Of Interrupt Register                          | 303 | MSR0000_0407: IC Machine Check Miscellaneous Register         |
| 282                     | APIC[4F0:480]: Interrupt Enable Registers                            |     | (MC1_MISC)                                                    |
| 283                     | APIC[530:500]: Extended Interrupt [3:0] Local Vector Table Registers | 304 | MSR0000_0408: BU Machine Check Control Register (MC2_CTL)     |
| 283                     | CPUID Fn[8000_0000, 0000_0000]: AMD Authentic Identifier             | 304 | MSR0000_0409: BU Machine Check Status Register (MC2_STATUS)   |
| 283                     | CPUID Fn[8000_0001, 0000_0001]_EAX: Family, Model, Stepping          | 305 | MSR0000_040A: BU Machine Check Address Register (MC2_ADDR)    |
| 203                     | Identifiers                                                          | 306 | MSR0000_040R: BU Machine Check Miscellaneous Register         |
| 284                     | CPUID Fn0000_0001_EBX: LocalApicId, LogicalProcessorCount,           | 300 | (MC2_MISC)                                                    |
| 204                     |                                                                      | 206 | MSR0000_040C: LS Machine Check Control Register (MC3_CTL)     |
| 201                     | CLFlush, 8BitBrandId CDLID Engono 0001 EDV: BrandId Identifier       | 306 |                                                               |
| 284                     | CPUID Fn8000_0001_EBX: BrandId Identifier                            | 306 | MSR0000_040D: LS Machine Check Status Register (MC3_STATUS)   |
| 284                     | CPUID Fn0000_0001_ECX: Feature Identifiers                           | 306 | MSR0000_040E: LS Machine Check Address Register (MC3_ADDR)    |
| 285                     | CPUID Fn8000_0001_ECX: Feature Identifiers                           | 307 | MSR0000_040F: LS Machine Check Miscellaneous Register         |
| 285                     | CPUID Fn[8000_0001, 0000_0001]_EDX: Feature Identifiers              | 207 | (MC3_MISC)                                                    |
| 287                     | CPUID Fn0000_000[4, 3, 2]: Reserved.                                 | 307 | MSR0000_0410: NB Machine Check Control Register (MC4_CTL)     |
| 287                     | CPUID Fn8000_000[4, 3, 2]: Processor Name String Identifier          | 307 | MSR0000_0411: NB Machine Check Status Register (MC4_STATUS)   |
| 287                     | CPUID Fn0000_0005: Monitor/MWait                                     | 307 | MSR0000_0412: NB Machine Check Address Register (MC4_ADDR)    |
| 287                     | CPUID Fn8000_0005: TLB and L1 Cache Identifiers                      | 307 | MSR0000_0413: NB Machine Check Misc (Thresholding) Register   |
| 288                     | CPUID Fn8000_0006: L2/L3 Cache and L2 TLB Identifiers                |     | (MC4_MISC0)                                                   |
| 289                     | CPUID Fn8000_0007: Advanced Power Management Information             | 308 | MSR0000_0414: FR Machine Check Control Register (MC5_CTL)     |
| 289                     | CPUID Fn8000_0008: Address Size And Physical Core Count              | 308 | MSR0000_0415: FR Machine Check Status Register (MC5_STATUS)   |
|                         | Information                                                          | 308 | MSR0000_0416: FR Machine Check Address Register (MC5_ADDR)    |
| 290                     | CPUID Fn8000_0009: Reserved                                          | 308 | MSR0000_0417: FR Machine Check Miscellaneous Register         |
| 290                     | CPUID Fn8000_000A: SVM Revision and Feature Identification           |     | (MC5_MISC)                                                    |
| 290                     | CPUID Fn8000_00[18:0B]: Reserved                                     | 309 | MSRC000_0080: Extended Feature Enable Register (EFER)         |
| 290                     | CPUID Fn8000_0019: TLB 1GB Page Identifiers                          | 309 | MSRC000_0081: SYSCALL Target Address Register (STAR)          |
| 291                     | CPUID Fn8000_001A: Performance Optimization Identifiers              | 309 | MSRC000_0082: Long Mode SYSCALL Target Address Register       |
| 291                     | MSR0000_0000: Load-Store MCA Address Register                        |     | (STAR64)                                                      |
| 291                     | MSR0000_0001: Load-Store MCA Status Register                         | 310 | MSRC000_0083: Compatibility Mode SYSCALL Target Address       |
| 291                     | MSR0000_0010: Time Stamp Counter Register (TSC)                      |     | Register (STARCOMPAT)                                         |
| 291                     | MSR0000_001B: APIC Base Address Register (APIC_BAR)                  | 310 | MSRC000_0084: SYSCALL Flag Mask Register                      |
| 292                     | MSR0000_002A: Cluster ID Register (EBL_CR_POWERON)                   |     | (SYSCALL_FLAG_MASK)                                           |
| 292                     | MSR0000_00FE: MTRR Capabilities Register (MTRRcap)                   | 310 | MSRC000_0100: FS Base Register (FS_BASE)                      |
| 292                     | MSR0000_0174: SYSENTER CS Register (SYSENTER_CS)                     | 310 | MSRC000_0101: GS Base Register (GS_BASE)                      |
| 292                     | MSR0000_0175: SYSENTER ESP Register (SYSENTER_ESP)                   | 310 | MSRC000_0102: Kernel GS Base Register (KernelGSbase)          |
| 292                     | MSR0000_0176: SYSENTER EIP Register (SYSENTER_EIP)                   | 311 | MSRC000_0103: Auxiliary Time Stamp Counter Register (TSC_AUX) |
| 293                     | MSR0000_0179: Global Machine Check Capabilities Register             | 311 | MSRC000_04[0A:08]: Machine Check Misc 4 (Thresholding)        |
|                         | (MCG_CAP)                                                            |     | Registers 1 to 3 (MC4_MISC[3:1])                              |
| 293                     | MSR0000_017A: Global Machine Check Status Register                   | 311 | MSRC001_00[03:00]: Performance Event Select Register          |
| -/-                     | (MCG_STAT)                                                           | 011 | (PERF_CTL[3:0])                                               |
| 293                     | MSR0000_017B: Global Machine Check Exception Reporting Control       | 313 | MSRC001_00[07:04]: Performance Event Counter Registers        |
|                         | Register (MCG_CTL)                                                   | 213 | (PERF_CTR[3:0])                                               |
| 294                     | MSR0000_01D9: Debug Control Register (DBG_CTL_MSR)                   | 314 | MSRC001_0010: System Configuration Register (SYS_CFG)         |
| 294                     | MSR0000_01D9: Last Branch From IP Register (BR_FROM)                 | 314 | MSRC001_0015: Hardware Configuration Register (HWCR)          |
| 294                     | MSR0000_01DB: Last Branch To IP Register (BR_TO)                     | 316 | MSRC001_00[18, 16]: IO Range Registers Base (IORR_BASE[1:0])  |
| <i>∠</i> / <del>+</del> | MERCOOO_OTDC. Dast Branch To II Register (BR_IO)                     | 510 | Marcool_oo[10, 10]. To Range Registers Dast (IORR_DASE[1.0])  |



| 217 | MCDC001 00[10 17], IO Dongo Dogistors Mosk (IODD MACK[1,0])            | 229 | EventSelect 020h, Segment Desister Londs                           |
|-----|------------------------------------------------------------------------|-----|--------------------------------------------------------------------|
| 317 | MSRC001_00[19, 17]: IO Range Registers Mask (IORR_MASK[1:0])           | 338 | EventSelect 020h: Segment Register Loads                           |
| 317 | MSRC001_001A: Top Of Memory Register (TOP_MEM)                         | 339 | EventSelect 021h: Pipeline Restart Due to Self-Modifying Code      |
| 317 | MSRC001_001D: Top Of Memory 2 Register (TOM2)                          | 339 | EventSelect 022h: Pipeline Restart Due to Probe Hit                |
| 317 | MSRC001_001F: Northbridge Configuration Register (NB_CFG)              | 339 | EventSelect 023h: LS Buffer 2 Full                                 |
| 318 | MSRC001_0022: Machine Check Exception Redirection Register             | 339 | EventSelect 024h: Locked Operations                                |
| 319 | MSRC001_00[35:30]: Processor Name String Registers                     | 339 | EventSelect 026h: Retired CLFLUSH Instructions                     |
| 319 | MSRC001_00[49:44]: Machine Check Control Mask Registers                | 339 | EventSelect 027h: Retired CPUID Instructions                       |
|     | (MCi_CTL_MASK)                                                         | 339 | EventSelect 02Ah: Cancelled Store to Load Forward Operations       |
| 319 | MSRC001_00[53:50]: IO Trap Registers (SMI_ON_IO_TRAP_[3:0])            | 340 | EventSelect 02Bh: SMIs Received                                    |
| 320 | MSRC001_0054: IO Trap Control Register                                 | 340 | EventSelect 040h: Data Cache Accesses                              |
|     | (SMI_ON_IO_TRAP_CTL_STS)                                               | 340 | EventSelect 041h: Data Cache Misses                                |
| 320 | MSRC001_0055: Interrupt Pending and CMP-Halt Register                  | 340 | EventSelect 042h: Data Cache Refills from L2 or Northbridge        |
| 321 | MSRC001_0056: SMI Trigger IO Cycle Register                            | 340 | EventSelect 043h: Data Cache Refills from the northbridge          |
| 321 | MSRC001_0058: MMIO Configuration Base Address Register                 | 341 | EventSelect 044h: Data Cache Lines Evicted                         |
| 322 | MSRC001_0059: MMIO Configuration Trap Control Register                 | 341 | EventSelect 045h: L1 DTLB Miss and L2 DTLB Hit                     |
| 322 | MSRC001_00[5D:5A]: MMIO Configuration Trap Address Registers           | 341 | EventSelect 046h: L1 DTLB and L2 DTLB Miss                         |
| 323 | MSRC001_0061: P-State Current Limit Register                           | 342 | EventSelect 047h: Misaligned Accesses                              |
| 323 | MSRC001_0062: P-State Control Register                                 | 342 | EventSelect 048h: Microarchitectural Late Cancel of an Access      |
| 324 | MSRC001_0063: P-State Status Register                                  | 342 | EventSelect 049h: Microarchitectural Early Cancel of an Access     |
| 324 | MSRC001_00[68:64]: P-State [4:0] Registers                             | 342 | EventSelect 04Ah: Single-bit ECC Errors Recorded by Scrubber       |
| 325 | MSRC001_0070: COFVID Control Register                                  | 342 | EventSelect 04Bh: Prefetch Instructions Dispatched                 |
| 326 | MSRC001_0071: COFVID Status Register                                   | 342 | EventSelect 04Ch: DCACHE Misses by Locked Instructions             |
| 326 | MSRC001_0074: CPU Watchdog Timer Register (CpuWdTmrCfg)                | 343 | EventSelect 04Dh: L1 DTLB Hit                                      |
| 327 | MSRC001_0111: SMM Base Address Register (SMM_BASE)                     | 343 | EventSelect 052h: Ineffective Software Prefetchs                   |
| 327 |                                                                        |     |                                                                    |
|     | MSRC001_0112: SMM TSeg Base Address Register (SMMAddr)                 | 343 | EventSelect 054h: Global TLB Flushes                               |
| 328 | MSRC001_0113: SMM TSeg Mask Register (SMMMask)                         | 343 | EventSelect 065h: Memory Requests by Type                          |
| 329 | MSRC001_0114: Virtual Machine Control Register (VM_CR)                 | 343 | EventSelect 067h: Data Prefetcher                                  |
| 330 | MSRC001_0115: IGNNE Register (IGNNE)                                   | 344 | EventSelect 06Ch: Northbridge Read Responses by Coherency State    |
| 330 | MSRC001_0116: SMM Control Register (SMM_CTL)                           | 344 | EventSelect 06Dh: Octwords Written to System                       |
| 330 | MSRC001_0117: Virtual Machine Host Save Physical Address Register      | 344 | EventSelect 076h: CPU Clocks not Halted                            |
| 220 | (VM_HSAVE_PA)                                                          | 344 | EventSelect 07Dh: Requests to L2 Cache                             |
| 330 | MSRC001_0118: SVM Lock Key                                             | 345 | EventSelect 07Eh: L2 Cache Misses                                  |
| 331 | MSRC001_011A: Local SMI Status                                         | 345 | EventSelect 07Fh: L2 Fill/Writeback                                |
| 331 | MSRC001_0140: OS Visible Work-around MSR0                              | 345 | EventSelect 080h: Instruction Cache Fetches                        |
| 224 | (OSVW_ID_Length)                                                       | 346 | EventSelect 081h: Instruction Cache Misses                         |
| 331 | MSRC001_0141: OS Visible Work-around MSR1 (OSVW Status)                | 346 | EventSelect 082h: Instruction Cache Refills from L2                |
| 331 | MSRC001_1022: Data Cache Configuration Register (DC_CFG)               | 346 | EventSelect 083h: Instruction Cache Refills from System            |
| 331 | MSRC001_1023: Bus Unit Configuration Register (BU_CFG)                 | 346 | EventSelect 084h: L1 ITLB Miss, L2 ITLB Hit                        |
| 332 | MSRC001_102A: Bus Unit Configuration 2 Register (BU_CFG2)              | 346 | EventSelect 085h: L1 ITLB Miss, L2 ITLB Miss                       |
| 332 | MSRC001_1030: IBS Fetch Control Register (IbsFetchCtl)                 | 346 | EventSelect 086h: Pipeline Restart Due to Instruction Stream Probe |
| 333 | MSRC001_1031: IBS Fetch Linear Address Register (IbsFetchLinAd)        | 346 | EventSelect 087h: Instruction Fetch Stall                          |
| 333 | MSRC001_1032: IBS Fetch Physical Address Register                      | 346 | EventSelect 088h: Return Stack Hits                                |
|     | (IbsFetchPhysAd)                                                       | 346 | EventSelect 089h: Return Stack Overflows                           |
| 333 | MSRC001_1033: IBS Execution Control Register (IbsOpCtl)                | 347 | EventSelect 08Bh: Instruction Cache Victims                        |
| 334 | MSRC001_1034: IBS Op Logical Address Register (IbsOpRip)               | 347 | EventSelect 08Ch: Instruction Cache Lines Invalidated              |
| 334 | MSRC001_1035: IBS Op Data Register (IbsOpData)                         | 347 | EventSelect 099h: ITLB Reloads                                     |
| 334 | MSRC001_1036: IBS Op Data 2 Register (IbsOpData2)                      | 347 | EventSelect 09Ah: ITLB Reloads Aborted                             |
| 335 | MSRC001_1037: IBS Op Data 3 Register (IbsOpData3)                      | 347 | EventSelect 0C0h: Retired Instructions                             |
| 336 | MSRC001_1038: IBS DC Linear Address Register (IbsDcLinAd)              | 347 | EventSelect 0C1h: Retired uops                                     |
| 336 | MSRC001_1039: IBS DC Physical Address Register (IbsDcPhysAd)           | 347 | EventSelect 0C2h: Retired Branch Instructions                      |
| 336 | MSRC001_103A: IBS Control Register                                     | 347 | EventSelect 0C3h: Retired Mispredicted Branch Instructions         |
| 337 | EventSelect 000h: Dispatched FPU Operations                            | 347 | EventSelect 0C4h: Retired Taken Branch Instructions                |
| 337 | EventSelect 001h: Cycles in which the FPU is Empty                     | 348 | EventSelect 0C5h: Retired Taken Branch Instructions Mispredicted   |
| 337 | EventSelect 002h: Dispatched Fast Flag FPU Operations                  | 348 | EventSelect 0C6h: Retired Far Control Transfers                    |
| 337 | EventSelect 003h: Retired SSE Operations                               | 348 | EventSelect 0C7h: Retired Branch Resyncs                           |
| 338 | EventSelect 004h: Retired Move Ops                                     | 348 | EventSelect 0C8h: Retired Near Returns                             |
| 338 | EventSelect 005h: Retired Serializing Ops                              | 348 | EventSelect 0C9h: Retired Near Returns Mispredicted                |
| 338 | EventSelect 006h: Number of Cycles that a Serializing uop is in the FP | 348 | EventSelect 0CAh: Retired Indirect Branches Mispredicted           |
|     | Scheduler                                                              | 348 | EventSelect 0CBh: Retired MMX <sup>TM</sup> /FP Instructions       |
|     |                                                                        |     |                                                                    |

AMD Family 10h Processor BKDG

- 348 EventSelect 0CCh: Retired Fastpath Double Op Instructions
- 348 EventSelect 0CDh: Interrupts-Masked Cycles
- 349 EventSelect 0CEh: Interrupts-Masked Cycles with Interrupt Pending
- 349 EventSelect 0CFh: Interrupts Taken
- 349 EventSelect 0D0h: Decoder Empty
- 349 EventSelect 0D1h: Dispatch Stalls
- 349 EventSelect 0D2h: Dispatch Stall for Branch Abort to Retire
- 349 EventSelect 0D3h: Dispatch Stall for Serialization
- 349 EventSelect 0D4h: Dispatch Stall for Segment Load
- 349 EventSelect 0D5h: Dispatch Stall for Reorder Buffer Full
- 349 EventSelect 0D6h: Dispatch Stall for Reservation Station Full
- 349 EventSelect 0D7h: Dispatch Stall for FPU Full
- 350 EventSelect 0D8h: Dispatch Stall for LS Full
- 350 EventSelect 0D9h: Dispatch Stall Waiting for All Quiet
- 350 EventSelect 0DAh: Dispatch Stall for Far Transfer or Resync to Retire
- 350 EventSelect 0DBh: FPU Exceptions
- 350 EventSelect 0DCh: DR0 Breakpoint Matches
- 350 EventSelect 0DDh: DR1 Breakpoint Matches
- 350 EventSelect 0DEh: DR2 Breakpoint Matches
- 350 EventSelect 0DFh: DR3 Breakpoint Matches
- 350 EventSelect 0E0h: DRAM Accesses
- 351 EventSelect 0E1h: DRAM Controller Page Table Overflows
- 351 EventSelect 0E2h: Memory Controller DRAM Command Slots Missed
- 351 EventSelect 0E3h: Memory Controller Turnarounds
- 352 EventSelect 0E4h: Memory Controller Bypass Counter Saturation
- 352 EventSelect 0E8h: Thermal Status
- 352 EventSelect 0E9h: CPU/IO Requests to Memory/IO
- 353 EventSelect 0EAh: Cache Block Commands
- 353 EventSelect 0EBh: Sized Commands
- 354 EventSelect 0ECh: Probe Responses and Upstream Requests
- 354 EventSelect 0EEh: GART Events
- 355 EventSelect 1F0h: Memory Controller Requests
- 355 EventSelect 1E0h: CPU to DRAM Requests to Target Node
- 356 EventSelect 1E1h: IO to DRAM Requests to Target Node
- 356 EventSelect 1E2h: CPU Read Command Latency to Target Node 0-3
- 356 EventSelect 1E3h: CPU Read Command Requests to Target Node 0-3
- 357 EventSelect 1E4h: CPU Read Command Latency to Target Node 4-7
- 357 EventSelect 1E5h: CPU Read Command Requests to Target Node 4-7
- 358 EventSelect 1E6h: CPU Command Latency to Target Node 0-3/4-7
- 358 EventSelect 1E7h: CPU Requests to Target Node 0-3/4-7
- 359 EventSelect 0F6h: HyperTransport<sup>TM</sup> Link 0 Transmit Bandwidth
- 359 EventSelect 0F7h: HyperTransport™ Link 1 Transmit Bandwidth
- 359 EventSelect 0F8h: HyperTransport™ Link 2 Transmit Bandwidth
- 359 EventSelect 1F9h: HyperTransport<sup>TM</sup> Link 3 Transmit Bandwidth
- 359 EventSelect 4E0h: Read Request to L3 Cache
- 359 EventSelect 4E1h: L3 Cache Misses
- 360 EventSelect 4E2h: L3 Fills caused by L2 Evictions
- 360 EventSelect 4E3h: L3 Evictions