

# AMD SR5690/5670/5650 Register Programming Requirements

Publication #43872Revision:Rev 3.05Issue Date:August 2012

#### Trademarks

AMD, the AMD Arrow logo, and combinations thereof, are trademarks of Advanced Micro Devices, Inc.

HyperTransport is a licensed trademark of the HyperTransport Technology Consortium.

PCI Express and PCIe are registered trademarks of the PCI-Special Interest Group (PCI-SIG).

Microsoft and Windows are registered trademarks of Microsoft Corporation.

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

#### Disclaimer

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 are 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 propese, 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.

© 2012 Advanced Micro Devices, Inc. All rights reserved.

# Table of Contents

## **Chapter 1: Introduction**

| 1.1 | About This Manual | <br>1-1 |
|-----|-------------------|---------|
|     |                   |         |

## Chapter 2: I/O Control (IOC)

| 2.1 | SR5690    | /5670/5650 Device Mapping                                                 |  |
|-----|-----------|---------------------------------------------------------------------------|--|
| 2.2 | Configu   | ration Access to SR5690/5670/5650 Device Registers                        |  |
| 2.3 | General   | SR5690/5670/5650 IOC Programming After Bootup                             |  |
|     |           | neous IOC Features Programming.                                           |  |
|     | 2.4.1     | S3 PME_Turn_Off/PME_To_Ack Sequence.                                      |  |
|     | 2.4.2     | Disabling Bus n Device 2, 3, 11, and 12 PCI Bridge                        |  |
|     | 2.4.3     | Disabling Bus Devices 4-7, 9-10, and 13 PCI Bridges.                      |  |
|     | 2.4.4     | Enabling Accesses to Busn Dev0 Fun2 Registers (IOMMU Configuration Space) |  |
|     | 2.4.5     | Peer-To-Peer (P2P) Modes                                                  |  |
|     | 2.4.6     | Device ID for Hot-Plug (HP) and PMPME Messages to SB                      |  |
|     | 2.4.7     | Edge-Triggered and Level-Sensitive Interrupt Mode Support                 |  |
|     | 2.4.8     | Forwarding RequesterID (ReqID for Peer-To-Peer (P2P) Requests             |  |
|     | 2.4.9     | JTAG Controller Enable and Security Feature                               |  |
|     | 2.4.10    | MCU Enable and Security Feature                                           |  |
|     | 2.4.11    | Zero-Byte Read Support                                                    |  |
|     | 2.4.12    | Advanced Error Reporting (AER) Support                                    |  |
| 2.5 | Enablin   | g/Disabling Peer-to-Peer Traffic Access                                   |  |
| 2.6 | IOC Dy    | namic Clock Setup                                                         |  |
| 2.7 | Interrup  | t Mapping                                                                 |  |
| 2.8 | Multiple  | Northbridge (NB) Support                                                  |  |
|     | -         | /5670/5650 A21 Features                                                   |  |
|     | 2.9.1     | Forwarding of Host Non-Posted Write Completion Status                     |  |
|     | 2.9.2     | Increase Downstream Message Priority                                      |  |
|     | 2.9.3     | Prevent Spurious UR of DMA Requests                                       |  |
| 2.1 | ) Erratui | n 81 Programming                                                          |  |

# Chapter 3: Clock Settings

| 3.1 | Power S | Saving Settings            | 3-1 | 1 |
|-----|---------|----------------------------|-----|---|
|     |         | Enabling Dynamic Clocks    |     |   |
|     | 3.1.2   | CLKCFG Configuration Space | 3-3 | 1 |

# Chapter 4: PCIe® Initialization

| 4.1 | Introduc | ction                                      | 4-1  |
|-----|----------|--------------------------------------------|------|
| 4.2 | Organiz  | ation                                      | 4-1  |
| 4.3 | Archited | cture and Configuration Topology           | 4-1  |
|     |          | Configuration Space Topology.              |      |
|     | 4.3.2    | PCIe® Configuration Space.                 | 4-5  |
|     | 4.3.3    | PCIe® Cores Configuration Topologies.      | 4-9  |
|     |          | Methods to Bring PCIe Links to Gen 2 Speed |      |
| 4.4 | Overall  | PCIe Programming Sequence                  | 4-18 |
|     | 4.4.1    | Power-On Default State                     | 4-18 |
|     | 4.4.2    | PCIe® Cores Initialization.                | 4-19 |

| 4.4.3 | PCIe® Links Training                                         | 4-51 |
|-------|--------------------------------------------------------------|------|
| 4.4.4 | PCIe® Power Control                                          |      |
| 4.4.5 | Static PCIe® Port Power Down Control                         | 4-64 |
| 4.4.6 | PCIe® Enumeration and Special Features Programming Sequence. | 4-74 |
| 4.4.7 | Optional Features                                            | 4-79 |
|       | •                                                            |      |

# Chapter 5: HTIU Settings

| 5.1 Hyper | TransportTM Link Initialization                 | 5-1  |
|-----------|-------------------------------------------------|------|
| 5.2 HTIU  | Indirect Register Space                         | 5-1  |
| 5.3 CPU F | Register Access                                 |      |
| 5.3.1     | Normal Registers                                |      |
| 5.3.2     | PHY Dataport Register Access                    |      |
| 5.3.3     | Link Dependent Registers                        | 5-1  |
| 5.4 Chang | ing to High-Speed Mode                          |      |
| 5.4.1     | Identifying Supported HT Frequencies            |      |
| 5.4.2     | Changing to High-Speed HT 1 Mode                |      |
| 5.4.3     | Changing to HT 3 Mode                           | 5-3  |
| 5.5 HT Re | gister Settings                                 | 5-4  |
| 5.5.1     | General Register Settings                       |      |
| 5.5.2     | UnitID Clumping (Optional)                      | 5-6  |
| 5.5.3     | Extended Address Support                        | 5-6  |
| 5.5.4     | Isochronous Flow-Control Mode                   |      |
| 5.5.5     | Family 10h Processor Buffer Allocation Settings | 5-7  |
| 5.5.6     | HyperTransportTM Protocol Checker               |      |
| 5.5.7     | Transmitter De-emphasis                         |      |
| 5.5.8     | Low-Power HyperTransportTM Features             | 5-10 |

# Chapter 6: IOAPIC

| 6.1 | IOAPIC    | CRegister Spaces                                                |      |
|-----|-----------|-----------------------------------------------------------------|------|
|     | 6.1.1     | IOAPIC Registers in the NBCFG Space                             |      |
|     | 6.1.2     | IOAPIC Configuration Registers Space                            |      |
|     | 6.1.3     | IOAPIC Direct Memory Mapped Registers Space.                    |      |
|     | 6.1.4     | IOAPIC Indirect Memory Mapped Registers Space                   | 6-3  |
| 6.2 | IOAPIC    | COperation                                                      | 6-3  |
| 6.3 | Setting 1 | Interrupts                                                      | 6-5  |
|     | 6.3.1     | Group Interrupt Routing Registers                               | 6-5  |
|     | 6.3.2     | Individual Interrupt Routing                                    | 6-8  |
|     | 6.3.3     | Swizzling                                                       | 6-9  |
|     | 6.3.4     | Group Assignment                                                |      |
|     | 6.3.5     | IOAPIC Interrupt Interrupt Status Register                      | 6-13 |
| 6.4 | Southbr   | idge Re-Routing Feature                                         |      |
|     | 6.4.1     | Recommended Usage                                               | 6-15 |
|     | 6.4.2     | Interrupt Swizzling by the Processor in a Multi-NB Environment. |      |
| 6.5 | Redirect  | tion Table Entry Registers                                      | 6-15 |

# Chapter 7: RAS Settings

| 7.1 Overvie  | 2W                                       | 7-1 |
|--------------|------------------------------------------|-----|
| 7.2 Platforr | n Configuration                          | 7-1 |
|              | ature Configuration                      |     |
|              | Sideband Pin Configuration.              |     |
|              | HyperTransport RAS Feature Configuration |     |
| 7.3.3        | Error Status for HyperTransportTM Errors | 7-8 |

| 7.3.4      | Internal Parity Error Configuration |  |
|------------|-------------------------------------|--|
|            | PCIe® RAS Feature Configuration     |  |
| 7.4 Platfo | m Level Error Handling              |  |
|            | OS-First Error Handling             |  |
| 7.4.2      | Firmware-First Error Handling       |  |
| 7.4.3      | System Halt on Error                |  |

# Chapter 8: IOMMU Initialization

| 8.1 IOMMU Configuration Space                                 |  |
|---------------------------------------------------------------|--|
| 8.1.1 PCI Configuration Space                                 |  |
| 8.1.2 IOMMU Memory Mapped Register Space                      |  |
| 8.1.3 IOMMU L1 Indexed Space.                                 |  |
| 8.1.4 IOMMU L2 Indexed Space.                                 |  |
| 8.2 IOMMU Initialization                                      |  |
| 8.2.1 IOMMU L1 Initialization                                 |  |
| 8.2.2 IOMMU L2 Initialization                                 |  |
| 8.3 Virtualization ACPI Tables                                |  |
| 8.3.1 I/O Virtualization ACPI Tables Configuration            |  |
| 8.4 Programming Requirements for OS and Hypervisor Developers |  |
| 8.4.1 DTE Setup                                               |  |
| 8.4.2 Register Programming.                                   |  |

# Appendix A: Revision History

## 1.1 About This Manual

This document is intended for BIOS engineers designing BIOSes for systems based on AMD's SR5690/5670/5650 Northbridge. It describes the register programming requirements needed to ensure the proper functioning of the SR5690/5670/5650. Use this document in conjunction with the related *AMD SR5690/5670/5650 Register Reference Guide* and *AMD SR5690/5670/5650 BIOS Developer's Guide*.

Note that, while this document covers all three SR56xx variants, and that, whenever a section is specific or not applicable to a particular variant, attention will be drawn with a warning, the reader should consult the individual databooks to verify the supported or non-supported features.

If the programming requirements for a particular function/feature differ within different ASIC revisions, the differences will be properly highlighted. Some of the settings indicated in this document are workarounds for problems that are expected to be solved in subsequent ASIC revisions. This document will therefore be updated as frequently as required.

Changes and additions to the previous release of this document are highlighted in red. Refer to *Appendix A: Revision History* at the end of this document for a detailed revision history.

This page intentionally left blank.

# Chapter 2 I/O Control (IOC)

## 2.1 SR5690/5670/5650 Device Mapping

The SR5690/5670/5650 has the devices indicated below. All devices reside on the northbridge's primary bus number (Busn). For a primary northbridge the bus number is 0, and for a secondary northbridge the bus number is non-zero.

- BusnDev0Fun0: Host bridge
- BusnDev0Fun1: Clock control
- BusnDev0Fun2: IOMMU
- BusnDev2: PCIe<sup>®</sup> P2P bridge
- BusnDev3: PCIe P2P bridge
- BusnDev4: PCIe P2P bridge
- BusnDev5: PCIe P2P bridge
- BusnDev6: PCIe P2P bridge
- BusnDev7: PCIe P2P bridge
- BusnDev8: NB/SB Link P2P bridge (hidden by default)
- BusnDev9: PCIe P2P bridge
- BusnDev10: PCIe P2P bridge
- BusnDev11: PCIe P2P bridge
- BusnDev12: PCIe P2P bridge
- BusnDev13: PCIe P2P bridge

Note: Each device has a P2P bridge header, except Dev0, for which all functions have a PCI device header.

## 2.2 Configuration Access to SR5690/5670/5650 Device Registers

Refer to the section entitled "Configuration Space" in the AMD family 10h processor BKDG to see how to access Configuration Space as well as Extended Configuration Space.

## 2.3 General SR5690/5670/5650 IOC Programming After Bootup

- After system boot-up, all registers should keep the default values.
- The BIOS starts the bus enumeration, and detects the following: BusnDev0Fun0, BusnDev0Fun1, BusnDev1Fun0, BusnDev1Fun1, BusnDev2Fun0, BusnDev3Fun0, BusnDev4Fun0, BusnDev5Fun0, BusnDev6Fun0, BusnDev7Fun0, BusnDev9Fun0, BusnDev10Fun0, BusnDev11Fun0, BusnDev12Fun0. Then, for all of these PCI device headers, or P2P device headers, the BIOS enables IOSpace (0x04[0]) and MemSpaceEn (0x04[1]). It also defines the primary bus number, the secondary bus number, and the subordinate bus number.

The IOC registers should be programmed as per the following table:

#### Table 2-1 IOC Expected Register Values

| ASIC Rev      | Register                   | Offset      | Expected Value                              |
|---------------|----------------------------|-------------|---------------------------------------------|
| SR5690/5670/  | NB_BAR1_RCRB               | nbcfg:0x14  | 32'hxxxx_xxxx                               |
| 5650 All Revs | NB_BAR2_PM2                | nbcfg:0x18  | 32'hxxxx_xxxx                               |
|               | NB_BAR3_PCIEXP_MMCFG       | nbcfg:0x1C  | 32'hxxxx_xxxx                               |
|               | NB_BAR3_UPPER_PCIEXP_MMCFG | nbcfg:0x20  | 32'h0000_000x                               |
|               | NB_PCI_CTRL                | nbcfg:0x4C  | 32'b0000_0000_0x00_01x1_0010_0000_1100_00xx |
|               | NB_IO_CFG_CNTL             | nbcfg:0x7C  | 32'h4000_0000                               |
|               | NB_PCI_ARB                 | nbcfg:0x84  | 32'b0000_0000_0000_0xxx_0000_00xx_1001_0101 |
|               | NB_IOC_DEBUG               | nbmisc:0x01 | 32'bxxxx_xxxx_xxxx_xxxx_xxxx_xxx1_xxxx      |
|               | IOC_DMA_ARBITER            | nbmisc:0x09 | 32'hxxxx_xxxx                               |

| ASIC Rev      | Register               | Offset     | Expected Value                              |
|---------------|------------------------|------------|---------------------------------------------|
|               | IOC_PCIE_CSR_COUNT     | nbmisc0x0A | 32'hxxxx_xxxx                               |
|               | IOC_PCIE_CNTL          | nbmisc0x0B | 32'h0000_0180                               |
|               | IOC_P2P_CNTL           | nbmisc0x0C | 32'bxxxx_0000_0000_0000_0xx1_0111_xxxx_xx00 |
|               | IOCISOCMAPADDR_LO      | nbmisc0x0E | 32'hxxxx_xxxx                               |
|               | IOCISOCMAPADDR_HI      | nbmisc0x0F | 32'hxxxx_xxxx                               |
|               | NB_BUS_NUM_CNTL        | nbmisc0x11 | 32'hxxxx_xxxx                               |
|               | PCIE_CORE_ARB          | nbmisc0x12 | 32'h5555_5555                               |
|               | IOC_PERF_COUNT0        | nbmisc0x13 | 32'hxxxx_xxxx                               |
|               | IOC_PERF_COUNT1        | nbmisc0x14 | 32'hxxxx_xxxx                               |
|               | IOC_PERF_CNTL          | nbmisc0x15 | 32'h0000_0000                               |
|               | NB_TOM_PCI             | nbmisc0x16 | 32'hxxxx_000x                               |
|               | NB_MMIOBASE            | nbmisc0x17 | 32'h0000_0000                               |
|               | NB_MMIOLIMIT           | nbmisc0x18 | 32'h0000_0000                               |
|               | NB_PROG_DEVICE_REMAP_0 | nbmisc0x20 | 32'h0000_0002                               |
| SR5690/5670/  | NB_PROG_DEVICE_REMAP_1 | nbmisc0x21 | 32'h0000_0000                               |
| 5650 All Revs | IOC_LAT_PERF_CNTR_CNTL | nbmisc0x30 | 32'hxxxx_xx00                               |
| 5050 All Revs | IOC_LAT_PERF_CNTR_OUT  | nbmisc0x31 | 32'hxxxx_xxxx                               |
|               | NB_BROADCAST_BASE_LO   | nbmisc0x3A | 32'hxxx0_00xx                               |
|               | NB_BROADCAST_BASE_HI   | nbmisc0x3B | 32'h0000_000x                               |
|               | NB_BROADCAST_CNTL      | nbmisc0x3C | 32'hxxxx_xxxx                               |
|               | IOC_JTAG_CNTL          | nbmisc0x47 | 32'h0000_xxxx                               |
|               | IOC_PCIE_D2_CNTL       | nbmisc0x51 | 32'h0010_0100                               |
|               | IOC_PCIE_D3_CNTL       | nbmisc0x53 | 32'h0010_0100                               |
|               | IOC_PCIE_D4_CNTL       | nbmisc0x55 | 32'h0010_0100                               |
|               | IOC_PCIE_D5_CNTL       | nbmisc0x57 | 32'h0010_0100                               |
|               | IOC_PCIE_D6_CNTL       | nbmisc0x59 | 32'h0010_0100                               |
|               | IOC_PCIE_D7_CNTL       | nbmisc0x5B | 32'h0010_0100                               |
|               | IOC_PCIE_D9_CNTL       | nbmisc0x5D | 32'h0010_0100                               |
|               | IOC_PCIE_D10_CNTL      | nbmisc0x5F | 32'h0010_0100                               |
|               | IOC_PCIE_D11_CNTL      | nbmisc0x61 | 32'h0010_0100                               |
|               | IOC_PCIE_D12_CNTL      | nbmisc0x63 | 32'h0010_0100                               |

| Table 2-1 IOC Expected Register Values | (Continued) |
|----------------------------------------|-------------|
|----------------------------------------|-------------|

## 2.4 Miscellaneous IOC Features Programming

## 2.4.1 S3 PME\_Turn\_Off/PME\_To\_Ack Sequence

During S3, S4 or S5 entry, PCIe<sup>®</sup> links need to be placed in the L2/L3 Ready state via the use of the PME Turn Off packet. On the primary NB, the PME Turn Off sequence is initiated by the southbridge in response to a request to enter S3/S4/S5. On secondary NBs, PME Turn Off must be initiated by SBIOS prior to the entry into S3/S4/S5 by trapping the request and performing the following sequence:

1. To initiate a downstream PMETurnOff message to all present PCIe endpoints on the secondary NB, program PMEMode to 1 (nbcfg0x84[8]) and, when the PMETurnOff message is to be sent out, assert PMETurnOff (nbcfg0x84[9]).

2. When the PMETOAck message is received from all present endpoint devices on the secondary NB, SR5690/5670/5650 will assert the PMETOAckStatus register bit (nbcfg0x84[10]), to indicate to BIOS that the sequence has completed.

## 2.4.2 Disabling Bus n Device 2, 3, 11, and 12 PCI Bridge

Note: The GPP ports may be disabled using a register bit or an e-fuse strap.

#### Table 2-2 Disabling Bus n Device 2, 3, 11, and 12 PCI Bridge Register Settings

| ASIC Rev                                                                                                                   | Device          | Port          | Bit Settings       | Disable Strap             |
|----------------------------------------------------------------------------------------------------------------------------|-----------------|---------------|--------------------|---------------------------|
| SR5690/5670/5                                                                                                              | Bus n Device 2  | GPP1 Port 0   | nbmiscind:0x0C[2]  | EFUSE_DISABLE_GPP1_PORT_0 |
| 650 All Revs                                                                                                               | Bus n Device 3  | GPP1 Port 1   | nbmiscind:0x0C[3]  | EFUSE_DISABLE_GPP1_PORT_1 |
|                                                                                                                            | Bus n Device 11 | GPP2 Port 0*  | nbmiscind:0x0C[18] | EFUSE_DISABLE_GPP2_PORT_0 |
|                                                                                                                            | Bus n Device 12 | GPP2 Port 1** | nbmiscind:0x0C[19] | EFUSE_DISABLE_GPP2_PORT_1 |
| * Not for SR5650                                                                                                           |                 |               |                    |                           |
| ** Not for SR5670 and SR5650                                                                                               |                 |               |                    |                           |
| Note: A strap called SLI_DISABLE is also used that could disable Device 3. Either bit, set to 1, would disable the device. |                 |               |                    |                           |

## 2.4.3 Disabling Bus Devices 4-7, 9-10, and 13 PCI Bridges

Set any bit according to the information found in *Table 2-3*.

#### Table 2-3 Disabling Bus n Devices 4-7, 9-10, and 13 PCI Bridges Register Settings

| Device          | Port                                                                                                      | Bit Settings                                                                                                                                                  |
|-----------------|-----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bus n Device 4  | GPP3a Port 0                                                                                              | nbmiscind:0x0C[4]                                                                                                                                             |
| Bus n Device 5  | GPP3a Port 1                                                                                              | nbmiscind:0x0C[5]                                                                                                                                             |
| Bus n Device 6  | GPP3a Port 2                                                                                              | nbmiscind:0x0C[6]                                                                                                                                             |
| Bus n Device 7  | GPP3a Port 3                                                                                              | nbmiscind:0x0C[7]                                                                                                                                             |
| Bus n Device 9  | GPP3a Port 4                                                                                              | nbmiscind:0x0C[16]                                                                                                                                            |
| Bus n Device 10 | GPP3a Port 5                                                                                              | nbmiscind:0x0C[17]                                                                                                                                            |
| Bus n Device 13 | GPP3b Port 0 *                                                                                            | nbmiscind:0x0C[20]                                                                                                                                            |
|                 | Bus n Device 4<br>Bus n Device 5<br>Bus n Device 6<br>Bus n Device 7<br>Bus n Device 9<br>Bus n Device 10 | Bus n Device 4GPP3a Port 0Bus n Device 5GPP3a Port 1Bus n Device 6GPP3a Port 2Bus n Device 7GPP3a Port 3Bus n Device 9GPP3a Port 4Bus n Device 10GPP3a Port 5 |

#### 2.4.4 Enabling Accesses to Busn Dev0 Fun2 Registers (IOMMU Configuration Space)

Setting nbmiscind:0x75[0] allows access to Busn Dev0 Fun2 PCI configuration space.

When IOMMU is enabled, the bit nbmiscind:0x1[9] should be programmed to 0 for proper behaviour when handling zero-byte reads.

#### 2.4.5 Peer-To-Peer (P2P) Modes

#### Table 2-4 P2P Modes

| (default) nbmiscind:0x75[10<br>nbmiscind:0x75[10 | the memory space of any P2P bridge, the request is dropped in IOC. Memory writes within main memory are unaffected.                            |
|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| nbmiscind:0x75[10                                | dropped in IOC. Memory writes within main memory are unaffected.                                                                               |
| nbmiscind:0x75[10                                | 9] = 2'b01 When a memory write does not match the memory space of                                                                              |
|                                                  | any P2P bridge, the request is forwarded upstream to HT<br>(HyperTransport <sup>™</sup> ). Memory writes within main memory<br>are unaffected. |
| nbmiscind:0x75[10                                | 9] = 2'b10 All memory writes are forwarded to HT.                                                                                              |
| d nbmiscind:0x75[10                              | 9] = 2'b11 Will mimic P2P mode 0                                                                                                               |
| d                                                | nbmiscind:0x75[10:<br>nbmiscind:0x75[10:<br>quired for P2P to work in a multi                                                                  |

behind the SB. BIOS should set the P2P mode to Mode 1, as this will support both single and multi NB configurations.

#### 2.4.6 Device ID for Hot-Plug (HP) and PMPME Messages to SB

By setting nbmiscind:0x75[29] to 1 (default is 0), the ReqID[15:0] field in the msg TLP to SB will contain the device number of the P2P bridge that generated the HP or PMPME message, i.e.:

ReqID[15:0] = 8-bit Bus, 5-bit Device, 3-bit Function = {8'b0, Bridge\_Device\_ID, 3'b0}

## 2.4.7 Edge-Triggered and Level-Sensitive Interrupt Mode Support

BIOS should program nbmiscind:0x12[19] to 1 to support both interrupt modes.

#### 2.4.8 Forwarding RequesterID (ReqID for Peer-To-Peer (P2P) Requests

This feature should be enabled in SBIOS.

To enable forwarding of the ReqID[15:0] field with a request for P2P transactions, program the following:

- For P2P requests going to external graphics (bus 0, devices 2, 3, 11, and 12), set nbmiscind:0x12[16] = 1 (default 0).
- For P2P requests going to GPP ports (bus 0, devices 4, 5, 6, 7, 9, 10, 13), set nbmiscind:0x12[17] = 1 (default 0).
- To enable Requester ID forwarding in PCIe<sup>®</sup>, set nbmiscind:0x6A[3] to 1 (default 0).

### 2.4.9 JTAG Controller Enable and Security Feature

Nbmiscind:0x75[11] enables the JTAG interface in IOC. By default, the value of this register bit is 1 (JTAG is enabled). If it is written to 0, posted writes from JTAG will be dropped, while non-posted writes will receive a commit, and reads will be returned with read data set to all 1s.

A SKINIT instruction from the processor will force nbmiscind:0x75[11] to 0. Secure software may write a 1 to re-enable JTAG.

### 2.4.10 MCU Enable and Security Feature

Nbmiscind:0x75[12] enables the MCU interface in IOC. By default, the value of the register bit is 1 (MCU is enabled). If bit 12 of the register is written to 0, posted writes from MCU will be dropped, while non-posted writes will receive a commit, and reads will be returned with read data set to all 1s.

A SKINIT instruction from the processor will force nbmiscind:0x75[12] to 0. Secure software may write a 1 to re-enable MCU.

### 2.4.11 Zero-Byte Read Support

By programming nbmiscind:0x1[8] to 1, IOC will forward the byte-enable (BE) provided by the PCIe<sup>®</sup> DMA access upstream to HTIU, which is 16'b0 for zero-byte reads. This should be enabled by default in system BIOS.

### 2.4.12 Advanced Error Reporting (AER) Support

The AER support feature in IOC is used to return the original, pre-translated, TLP back to PCIe, along with the corresponding status field, for error logging. To enable the support feature in IOC, per PCIe core, program the following register bits:

| NBMISCIND:0x75 Bits | Description      | BIOS Programming Value |
|---------------------|------------------|------------------------|
| 15:13               | GPP1 AER enable  | 0x4                    |
| 18:16               | GPP2 AER enable  | 0x4                    |
| 21:19               | SB AER enable    | 0x4                    |
| 24:22               | GPP3a AER enable | 0x4                    |
| 27:25               | GPP3b AER enable | 0x4                    |

#### Table 2-5 Enabling AER Support

## 2.5 Enabling/Disabling Peer-to-Peer Traffic Access

Any device from the southbridge as well as devices connected behind P2P bridges 2, 3, 4, 5, 6, 7, 9, 10, 11, 12, and 13 can initiate peer-to-peer requests. The P2P targets can be devices connected behind P2P bridges 2, 3, 4, 5, 6, 7, 9, 10, 11, 12 and 13. The southbridge can also be the target of a P2P request if the P2P mode is set to 1 or 2 (see section 2.4.5: *"Peer-To-Peer (P2P) Modes" on page 2-3*). Only P2P memory writes are supported. After power-on all P2P traffic paths are enabled by default. These can be disabled by setting the following register bits in *Table 2-6*.

#### Table 2-6 Disabling Peer-To-Peer Traffic Access Settings

| ASIC Rev                  | Devices         | Bit Settings  |
|---------------------------|-----------------|---------------|
| SR5690/5670/5650 All Revs | Bus n Device 2  | nbmisc0x51[3] |
|                           | Bus n Device 3  | nbmisc0x53[3] |
|                           | Bus n Device 4  | nbmisc0x55[3] |
|                           | Bus n Device 5  | nbmisc0x57[3] |
|                           | Bus n Device 6  | nbmisc0x59[3] |
|                           | Bus n Device 7  | nbmisc0x5b[3] |
|                           | Bus n Device 9  | nbmisc0x5d[3] |
|                           | Bus n Device 10 | nbmisc0x5f[3] |
|                           | Bus n Device 11 | nbmisc0x61[3] |
|                           | Bus n Device 12 | nbmisc0x63[3] |
|                           | Bus n Device 13 | nbmisc0x1F[3] |

## 2.6 IOC Dynamic Clock Setup

There are three clocks in IOC:

- LCLK (free running)
- LCLK\_MST (master branch)
- LCLK\_SLV (slave branch)

Note: Only LCLK\_MST (master branch) and LCLK\_SLV (slave branch) can be dynamically turned on and off.

The two bits that control the IOC dynamic clocks are:

- clkcfg0x8C[13] CLKGATE\_DIS\_IOC\_LLK\_MST
- clkcfg0x8C[14] CLKGATE\_DIS\_IOC\_LCLK\_SLV

The following settings apply to both of these bits:

- 1= Dynamic clock is disabled
- 0= Dynamic clock is enabled

## 2.7 Interrupt Mapping

IOC interrupt mapping only applies when the NB IOAPIC is disabled and interrupts are routed to the SB IOAPIC. Interrupt mapping is controlled with the bit IntSelMod of the IOC\_PCIE\_D\*\_CNTL registers.

| ASIC Rev      | Device Behind Internal Bridge # | Interrupt Mapping | IntSelMod == 1 Interrupt Mapping |
|---------------|---------------------------------|-------------------|----------------------------------|
| SR5690/5670/5 | 2                               | INTA -> INTC      | INTA -> INTG                     |
| 650 All Revs  |                                 | INTB -> INTD      | INTB -> INTH                     |
|               |                                 | INTC -> INTA      | INTC -> INTE                     |
|               |                                 | INTD -> INTB      | INTD -> INTF                     |
|               | 3                               | INTA -> INTD      | INTA -> INTH                     |
|               |                                 | INTB -> INTA      | INTB -> INTE                     |
|               |                                 | INTC -> INTB      | INTC -> INTF                     |
|               |                                 | INTD -> INTC      | INTD -> INTG                     |
|               | 4                               | INTA -> INTA      | INTA -> INTE                     |
|               |                                 | INTB -> INTB      | INTB -> INTF                     |
|               |                                 | INTC -> INTC      | INTC -> INTG                     |
|               |                                 | INTD -> INTD      | INTD -> INTH                     |
|               | 5                               | INTA -> INTB      | INTA -> INTF                     |
|               |                                 | INTB -> INTC      | INTB -> INTG                     |
|               |                                 | INTC -> INTD      | INTC -> INTH                     |
|               |                                 | INTD -> INTA      | INTD -> INTE                     |
|               | 6                               | INTA -> INTC      | INTA -> INTG                     |
|               |                                 | INTB -> INTD      | INTB -> INTH                     |
|               |                                 | INTC -> INTA      | INTC -> INTE                     |
|               |                                 | INTD -> INTB      | INTD -> INTF                     |
|               | 7                               | INTA -> INTD      | INTA -> INTH                     |
|               |                                 | INTB -> INTA      | INTB -> INTE                     |
|               |                                 | INTC -> INTB      | INTC -> INTF                     |
|               |                                 | INTD -> INTC      | INTD -> INTG                     |
|               | 9                               | INTA -> INTB      | INTA -> INTF                     |
|               |                                 | INTB -> INTC      | INTB -> INTG                     |
|               |                                 | INTC -> INTD      | INTC -> INTH                     |
|               |                                 | INTD -> INTA      | INTD -> INTE                     |
|               | 10                              | INTA -> INTC      | INTA -> INTG                     |
|               |                                 | INTB -> INTD      | INTB -> INTH                     |
|               |                                 | INTC -> INTA      | INTC -> INTE                     |
|               |                                 | INTD -> INTB      | INTD -> INTF                     |
|               | 11                              | INTA -> INTD      | INTA -> INTH                     |
|               |                                 | INTB -> INTA      | INTB -> INTE                     |
|               |                                 | INTC -> INTB      | INTC -> INTF                     |
|               |                                 | INTD -> INTC      | INTD -> INTG                     |
| [             | 12                              | INTA -> INTA      | INTA -> INTE                     |
|               |                                 | INTB -> INTB      | INTB -> INTF                     |
|               |                                 | INTC -> INTC      | INTC -> INTG                     |
|               |                                 | INTD -> INTD      | INTD -> INTH                     |
|               | 13                              | INTA -> INTB      | INTA -> INTF                     |
|               |                                 | INTB -> INTC      | INTB -> INTG                     |
|               |                                 | INTC -> INTD      | INTC -> INTH                     |
|               |                                 | INTD -> INTA      | INTD -> INTE                     |

#### Table 2-7 Interrupt Mapping

## 2.8 Multiple Northbridge (NB) Support

When multiple SR5690/5670/5650 NBs are implemented on the system, only one of the NB (primary) will have the SB connected to it. The remaining NBs (without the PCIe<sup>®</sup> connection to SB) are considered secondary NBs.

INTx, hot-plug (HP), and PMPME interrupts originating at the primary NB will be sent to the SB; however, for a secondary NB, the INTx, HP, or PMPME messages will be converted into HT INTx messages or HT vendor defined

messages and sent upstream to the processor. INT A-> D are converted into HT INTx messages, and INT E-H, HP and PMPME are sent using HT vendor defined messages.

The processor will then forward these messages to the primary NB, which will forward it to the SB. Due to this forwarding, SR5690/5670/5650 must also be able to decode HT messages arriving from the processor and send them to the SB.

The offset register should be programmed to 0x2, this results in the use of the lowest HT vendor defined message encodings (10 of them). If there is a conflict with other HT vendor defined messages in the system, the offset can be increased accordingly to change the messages used by the SR5690/5670/5650. The same offset needs to be used on all SR5690/5670/5650's in the system.

#### Table 2-8 Register Programming for Multi-NB Support

| nbmiscind: 0x75                 | Primary NB (Connected to SB) | Secondary NB                 |
|---------------------------------|------------------------------|------------------------------|
| Bit 2 (default 0x0)             | 0x0                          | 0x1                          |
| (Enable HT Interrupts Upstream) |                              |                              |
| Bit 3 (default 0x0)             | 0x1                          | 0x0                          |
| (Enable HT Interrupt Decoding)  |                              |                              |
| Bits [8:4] (default 0x0)        | Greater than or equal to 0x2 | Same value as for primary NB |
| (HT Interrupt Encoding Offset)  |                              |                              |

## 2.9 SR5690/5670/5650 A21 Features

#### Table 2-9 SR5690/5670/5650 A21 Features

| Feature                                               | Programming to Enable Feature |
|-------------------------------------------------------|-------------------------------|
| Forwarding of host non-posted write completion status | NBMISCIND:0x12[20] = 1        |
| Increase downstream message priority                  | NBMISCIND:0x12[21] = 1        |
| Prevent spurious UR of DMA requests                   | NBMISCIND:0x12[22] = 0        |

## 2.9.1 Forwarding of Host Non-Posted Write Completion Status

To enable forwarding of the status of host non-posted write completions from PCIe<sup>®</sup> to HTIU, set the following bit to 0x1: NBMISCIND:0x12[20] = 0x1

### 2.9.2 Increase Downstream Message Priority

To enable downstream messages to pass downstream host traffic in IOC, set the following bit to 0x1:

NBMISCIND:0x12[21] = 0x1

### 2.9.3 Prevent Spurious UR of DMA Requests

To prevent the chipset from spuriously logging a good DMA request as an unsupported request, the register bit NBMISCIND:0x12[22] must be cleared, i.e., BIOS should program it to 0x0.

## 2.10 Erratum 81 Programming

The following registers must be set in advance of enabling the microcontroller firmware update for erratum 81.

NBMISCIND x 0x5[0] = 0x1

NBMISCIND x 0x5 [15:10] = 0x16

NBMISCIND x 0x10 [22:16] = 0x1C

## 3.1 **Power Saving Settings**

## 3.1.1 Enabling Dynamic Clocks

## Table 3-1 Dynamic Clocks Settings

| ASIC Rev                | Register | Settings                                                                                                                                                                        |
|-------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670<br>All Revs | 0        | Controls dynamic clock gating for HTIU/IOC<br>clkcfg:0xF8 [11:0] = 0x0 enable dynamic clock<br>clkcfg:0xF8 [11:0] = 0xFFF disable dynamic clock (default)                       |
|                         |          | Controls dynamic clock gating for lclk (PCIe <sup>®</sup> )<br>clkcfg:0x94[30:0] = 0x0 enable dynamic clock<br>clkcfg:0x94[30:0] = 0x7FFFFF7 disable dynamic clock (default)    |
|                         |          | Controls dynamic clock gating for PCIe, cfg and mcu LCLK branches<br>Clkcfg:0xE8[31:25] = 0x7F enable dynamic clock<br>Clkcfg:0xE8[31:25] = 0x0 disable dynamic clock (default) |

## **3.1.2 CLKCFG Configuration Space**

The CLKCFG configuration space (Bus0Dev0Fn1) can be hidden via a register setting. Additionally, the PCI header of CLKCFG (register offsets 0x0 - 0x3F) can be hidden as well. When hidden, write accesses to CLKCFG will have no effect, and read accesses will return 0xFFFFFFFF.

| ASIC Rev    | Register                                | Function/Comment                                                  |
|-------------|-----------------------------------------|-------------------------------------------------------------------|
| SR5690/5670 | NB_PCI_CTRL <nbcfg:0x4c></nbcfg:0x4c>   | Bit [0] controls hiding of entire CLKCFG space                    |
| All Revs    |                                         | NB_PCI_CTRL[0] = 0 Hide CLKCFG                                    |
|             |                                         | NB_PCI_CTRL[0] = 1 Expose CLKCFG                                  |
|             | NB_CNTL <nbmiscind:0x0></nbmiscind:0x0> | Bit [8] controls hiding of CLKCFG PCI header (offsets 0x0 – 0x3F) |
|             |                                         | NB_CNTL[8] = 0 Expose CLKCFG header                               |
|             |                                         | NB_CNTL[8] = 1 Hide CLKCFG header                                 |

SBIOS should fully expose CLKCFG, i.e., set:

 $NB_PCI_CTRL[0] = 1$ 

 $NB_CNTL[8] = 0$ 

## 4.1 Introduction

This chapter describes the programming sequences needed to configure and enable the PCIe<sup>®</sup> subsystem in SR5690/5670/5650. The Northbridge PCIe subsystem is highly configurable, designed to support a wide variety of system topologies.

Except for "A-Link Express II", all PCIe links are disabled by default on initial boot up, until system BIOS has the opportunity to reflect the system topology into PCIe subsystem configuration. It is then that all PCIe links are allowed to train and establish point-to-point connections with all the PCIe devices present in the system. Once all PCIe devices are successfully connected in the system, system BIOS is allowed to either complete other tasks or pass control to the Operating System.

## 4.2 Organization

This chapter essentially comprises two major parts:

- The first part (*Section 4.3*) describes the general architecture, configuration topology, and configurability of the PCIe subsystem.
- The second part (*Section 4.4*) details the programming sequences required to train the individual PCIe links and enable various PCIe features.

## 4.3 Architecture and Configuration Topology

The SR5690 PCIe subsystem has 11 configurable PCIe ports that control in total 42 PCIe lanes, in addition to a 4-lane "A-Link Express II" with the Southbridge.

The SR5670 PCIe subsystem has 9 configurable PCIe ports that control in total 30 PCIe lanes in addition to a 4-lane "A-Link Express II" with the Southbridge.

The SR5650 PCIe subsystem has 8 configurable PCIe ports that control in total 22 PCIe lanes in addition to a 4-lane "A-Link Express II" with the Southbridge.

The PCIe ports are divided into two major groups:

- Group 1 is represented by the PCIE-GPP1 and PCIE-GPP2 cores. This group controls in total 32 PCIe lanes in SR5690, 24 PCIe lanes in SR5670 and 16 PCIe lanes in SR5650. Each PCIE-GPP1 and PCIE-GPP2 core controls two PCIe ports (Port 0 and Port 1) with a total of 16 PCIe lanes distributed in either of the following two configurations (*note: the nomenclature used here reflects the number of lanes assigned to each of the ports, according to the order "Port 0:Port 1"*):
  - 8:8
  - 16:0

[NOTE 1: PCIE-GPP2 core in SR5670 supports only one PCIe port (Port 0), controlling up to 8 PCIe lanes; therefore, all programming notes in this document related to PCIE-GPP2 Port 1 are not applicable to SR5670.]

[NOTE 2: PCIE-GPP2 is not present in SR5650, hence all programming notes in this document related to the PCIE-GPP2 core and its associated ports are not applicable to SR5650.]

- Group 2 is represented by the PCIE-GPP3a, PCIE-GPP3b and PCIE-SB cores. This group controls in total 14 PCIe lanes in SR5690, and 10 PCIe lanes in SR5670 and SR5650. The PCIE-SB core controls a single PCIe port (Port 0), dedicated to the Souhtbridge, and is configurable in x1, x2, and x4 PCIe lanes. The PCIE-GPP3b core also controls a single PCIe port (Port 0), configurable in x1, x2, and x4 PCIe lanes. The PCIE-GPP3b core controls six PCIe ports (Port 0 to Port 5), with 6 PCIe lanes distributed across them in the following six possible configurations (*the nomenclature used here denotes the number of lanes assigned to each of the ports, according to the order* "Port0:Port1:Port2:Port3:Port4:Port5"):
  - 4:2:0:0:0:0

- 4:1:1:0:0:0
- 2:2:2:0:0:0
- 2:2:1:1:0:0
- 2:1:1:1:1:0
- 1:1:1:1:1:1

[NOTE: The PCIE-GPP3b core is not present in SR5670 and SR5650, hence all programming notes in this document related to PCIE-GPP3b are not applicable to SR5670 and SR5650.]

## 4.3.1 Configuration Space Topology

Each SR5690/5670/5650 PCIe port has a virtual PCI-to-PCI bridge structure that connects one or more host CPUs via Northbridge bus n, as the primary bus number of the bridge, to the PCIe link, which is attached to the bridge secondary bus number. Each of these virtual PCI-to-PCI bridges is referred to as a device. Devices are mapped into the Configuration space such that each will respond to a particular device number.

*Figure 4-1, Figure 4-2, and Figure 4-3* illustrate the organization of the PCIe subsystem devices of the three variants from the perspective of the system BIOS on the overall PCI/PCIe configuration space.



Figure 4-1 SR5690 PCle<sup>®</sup> Configuration Space Topology



Figure 4-2 SR5670 PCIe<sup>®</sup> Configuration Space Topology



Figure 4-3 SR5650 PCIe<sup>®</sup> Configuration Space Topology

## 4.3.2 PCIe<sup>®</sup> Configuration Space

The SR5690/5670/5650 PCIe configuration space consists of the following four configuration spaces:

- PCI Configuration Space
- PCIe Core Index Space
- PCIe Port Index Space
- PCIe Extended Configuration Space

### 4.3.2.1 PCI Configuration Space

In order to maintain compatibility with PCI software configuration mechanism, each SR5690/5670/5650 PCIe port has a standard Type 1 virtual PCI-to-PCI bridge header in the PCI configuration space. As shown in *Figure 4-1, Figure 4-2*, and *Figure 4-3* above, these headers are organized as devices 2 through 13, for SR5690, and 2 through 11, for SR5670 and SR5650, on PCI bus n.

[Note: Device 8 (for the Southbridge link) is hidden by default. Before system BIOS turns control over to any system software that may scan the PCI configuration topology, device 8 must be hidden so that it is not detected by system software.]

Figure 4-4 below illustrates the PCI configuration spaces of all SR5690/5670/5650 PCIe ports.



Figure 4-4 PCI Configuration Space

## 4.3.2.2 PCIe<sup>®</sup> Core Index Space

SR5690 PCIe Core Index Space is composed of five core index spaces corresponding to the five PCIe cores, whereas SR5670 and SR5650 PCIe Core Index Space is each composed of four and three core index spaces respectively. Each of them encompasses control and status registers that are generic to all PCIe ports within each PCIe core.



Figure 4-5 PCIe<sup>®</sup> Core Index Space

SR5690/5670/5650 PCIe Core Index Register Space is accessed via an index/data register pair located in the Northbridge Configuration Registers Space. The Index register is located at offset 0xE0 and the Data register is located at 0xE4.

Note: PCIe Core Index Space register descriptions are referenced with the name PCIEIND or BIF\_NB.

Hardware has been implemented to provide a mechanism to access each PCIe Core Index Space register independently or jointly, through the programming of bits [18:16] of the index register 0xE0. The encoding is as follows:

- 0xE0[18:16] = 0x4: Read and write access to 0xE4 will be directed at per core index registers for the PCIE-GPP1 core only.
- 0xE0[18:16] = 0x6: Read and write access to 0xE4 will be directed at per core index register for the PCIE-GPP2 core only.
- 0xE0[18:16] = 0x0: Write access to 0xE4 will be directed at per core index registers for both the PCIE-GPP1 and the PCIE-GPP2 cores. However, reads will be only issued to the PCIE-GPP1 core.
- 0xE0[18:16] = 0x7: Read and write access to 0xE4 will be directed at per core index register for the PCIE-GPP3a core only.
- 0xE0[18:16] = 0x5: Read and write access to 0xE4 will be directed at per core index register for the PCIE-SB core only.
- 0xE0[18:16] = 0x3: Read and write access to 0xE4 will be directed at per core index register for the PCIE-GPP3b core only.
- 0xE0[18:16] = 0x1: Write access to 0xE4 will be directed at per core index registers for the PCIE-GPP3a, PCIE-GPP3b and the PCIE-SB cores. However, reads will be only issued to the PCIE-SB core.
- 0xE0[18:16] = 0x2: Write access to 0xE4 will be directed at per core index registers for the PCIE-GPP1, PCIE-GPP2, PCIE-GPP3a, PCIE-GPP3b and the PCIE-SB cores. However, reads will be only issued to the PCIE-SB core.

## **4.3.2.3 PCIe<sup>®</sup>** Port Index Space

PCIe Port Index Space contains control and status registers that are specific to each port within each PCIe core. Each PCIe device implements its own set of registers in its own instance of this space. Each instance has the same register organization.

To access per port index space registers, each PCIe device has its own Index/Data register pair located in its virtual type 1 PCI-to-PCI bridge configuration space. The Index register is located at offset 0xE0 and the Data register is located at offset 0xE4. *Figure 4-6* illustrates PCIe Port Index spaces for all PCIe ports.

[Note: PCIe Port Index Space registers descriptions are referenced with the name PCIEIND\_P or BIF\_NBP.]



Figure 4-6 PCle<sup>®</sup> Port Index Space

## 4.3.2.4 PCIe<sup>®</sup> Extended Configuration Space

PCIe extends the PCI configuration space from 256 bytes to 4096 bytes as shown in *Figure 4-7* below. Extended PCIe Configuration space memory maps 4KB for each device. The first 256 bytes of each 4KB are the same as PCI 2.3 configuration registers, and the remaining 3840 bytes are PCIe specific configuration registers.



Figure 4-7 PCle<sup>®</sup> Extended Configuration Space

## 4.3.3 PCIe<sup>®</sup> Cores Configuration Topologies

## 4.3.3.1 PCIE-GPP1 and PCIE-GPP2 Cores Configuration Topologies

Each SR5690 PCIE-GPP1 and PCIE-GPP2 core supports two PCIe configuration topologies. On initial boot up, the default configuration topology for both cores is single port configuration, in which each core controls a single port with up to 16 lanes. The alternative configuration topology is dual port configuration in which each core controls two ports with up to 8 lanes.

Each PCIE-GPP1 and PCIE-GPP2 core supports either one standard type-1 virtual PCI-to-PCI bridge header in single port configuration or two standard type-1 PCI-to-PCI bridge headers in dual port configuration. For PCI-GPP1 core, this is Device 2 in single port configuration or alternatively Device 2 and Device 3 in dual port configuration attached to bus n in the configuration space of the PCIE-GPP1 core. For PCI-GPP2 core, this is Device 11 in single port configuration or alternatively Device 12 in dual port configuration attached to bus n in the configuration space of the PCIE-GPP1 core. For PCI-GPP2 core, this is not not possible port configuration or alternatively Device 12 in dual port configuration attached to bus n in the configuration space of the PCIE-GPP2 core.

*Table 4-1* below lists the two PCIE-GPP1 configuration topologies, the Northbridge configuration space register controlling these configuration topologies, the PCIe lanes controlled by each port in each configuration topology and the corresponding HOLD\_TRAINING bit which must be cleared for each port to allow the associated PCIe link to start training.

| ASIC Rev                         | NBCFG:PCIE_LINK_CFG[8]<br>· NBMISCIND:0x8       | PCIE-GPP1<br>Port 0       | PCIE-GPP1<br>Port 1 | NBCFG:PCIE_LINK_CFG[5:4] · NBMISCIND:0x8<br>HOLD_TRAIN*_GPP1                        |
|----------------------------------|-------------------------------------------------|---------------------------|---------------------|-------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 0 (default, single port,<br>configuration 16:0) | 1, 2, 4, 8 or 16<br>lanes |                     | PCIE_LINK_CFG[4]<br>HOLD_TRAIN1_GPP1 (Hold PCIE- GPP1 Port 0<br>from Link Training) |
|                                  | 1 (dual port,<br>configuration 8:8)             | 1, 2, 4 or 8 lanes        |                     | PCIE_LINK_CFG[5]<br>HOLD_TRAIN1_GPP1 (Hold PCIE- GPP1 Port 1<br>from Link Training) |

#### Table 4-1 PCIE-GPP1 Ports Configurations

*Table 4-2* below lists the two PCIE-GPP2 configuration topologies, the Northbridge configuration space register controlling these configuration topologies, the PCIe lanes controlled by each port in each configuration topology, and the corresponding HOLD\_TRAINING bit which must be cleared for each port to allow the associated PCIe link to start training.

## Table 4-2 PCIE-GPP2 Ports Configurations

| ASIC Rev    | NBCFG:PCIE_LINK_CFG[9]<br>· NBMISCIND:0x8 | PCIE-GPP2<br>Port 0    | PCIE-GPP2 Port<br>1  | NBCFG:PCIE_LINK_CFG[7:6] ·<br>NBMISCIND:0x8<br>HOLD_TRAIN*GPP2 |
|-------------|-------------------------------------------|------------------------|----------------------|----------------------------------------------------------------|
| SR5690/5670 | 0 (default, single port,                  | 1, 2, 4, 8 or 16 lanes | N/A                  | PCIE_LINK_CFG[6]                                               |
| All Revs    | configuration 16:0)                       | Note: Not applicable   |                      | HOLD_TRAIN1_GPP2 (Hold PCIE- GPP2                              |
|             | Note: Not applicable to SR5670            | to SR5670              |                      | Port 0 from Link Training)                                     |
|             | 1 (dual port,                             | 1, 2, 4 or 8 lanes     | 1, 2, 4 or 8 lanes   | PCIE_LINK_CFG[7]                                               |
|             | configuration 8:8)                        |                        | Note: Not applicable | HOLD_TRAIN1_GPP2 (Hold PCIE- GPP2                              |
|             |                                           |                        | to SR5670            | Port 1 from Link Training)                                     |
|             |                                           |                        |                      | Note: Not applicable to SR5670                                 |

All PCIe links originating from PCIE-GPP1 and PCIE-GPP2 cores' ports are disabled by default on initial system boot up until system BIOS configures each core to reflect required customer's configuration topology of the system.

### 4.3.3.1.1 Reflecting Platform Topology into PCIE-GPP1 and PCIE-GPP2 Cores Configuration Topologies

A wide variety of customer system topologies may differ from the default configuration topologies of PCIE-GPP1 and PCIE-GPP2 cores after a power-on reset or warm-reset event; therefore, customer requirements must be translated into selection of each configuration topology of PCIE-GPP1 and PCIE-GPP2 cores.

The methods for determining the required configurations topologies depend on the level of required platform modularity. If the platform configuration topology is static, then system BIOS may choose to hardcode these requirements into the selection of PCIE-GPP1 and PCIE-GPP2 cores configurations. For example, if either PCIE-GPP1 or PCIE-GPP2 core is

required to support only one PCIe port, and all of its 16 PCIe lanes are required to be routed only to a single PCIe slot on the platform (or a single endpoint device mounted on the platform), then system BIOS will not have to do any additional programming since the required PCIE-GPP1 or PCIE-GPP2 core configuration conforms with the default configuration. Another example would be the case where the platform imposes hard requirements of routing the lower 8 PCIe lanes of either core only to one PCIe slot (or a single endpoint device mounted on the platform), and the 8 upper PCIe lanes of the same core to another PCIe slot (or another endpoint device mounted on the platform). In this case system BIOS may choose to hardcode programming of the dual core configuration topology.

Customers' system topologies might require platforms with a higher degree of modularity. Such platforms would require support for automatic detection of configuration topologies required on initial boot up and automatic configurations loading. One way to automatically determine the required configuration topology would be to use two software programmable GPIOs for each PCIE-GPP1 and PCIE-GPP2 core, each connected to PRSNT# pin of each PCIe slot supported. System BIOS could then read the status of these pins on initial boot up via these GPIOs in order to determine which PCIe slots are populated, and hence make a decision on whether to load 8:8 or 16:0 configuration in each of the cores.

*Section 4.3.3.1.1.1* and *Section 4.3.3.1.1.2* below detail the programming sequence requirement for system BIOS to load either configuration topology into PCIE-GPP1 and PCIE-GPP2 cores respectively.

## 4.3.3.1.1.1 Configuring PCIE-GPP1 Core Topology

The sequence below should be performed to switch configurations of the PCIE-GPP1core.

| ASIC Rev                   | Step | Register Settings                                                                    | Function/Comment                                      |
|----------------------------|------|--------------------------------------------------------------------------------------|-------------------------------------------------------|
| All Revs GLOBAL_RESET_GPP1 |      |                                                                                      | Asserts PCIE-GPP1 global reset                        |
|                            |      | Set bit [15] to 0x1.                                                                 |                                                       |
|                            | 2    | NBCFG:PCIE_NBCFG_REGE[28]=0x1 · NBMISCIND:0x26<br>~STRAP_BIF_all_valid for PCIE-GPP1 | De-asserts STRAP_BIF_all_valid for<br>PCIE-GPP1 core  |
|                            |      | Set bit [28] to 0x1.                                                                 |                                                       |
|                            | 3    | NBCFG:PCIE_LINK_CFG[8]=0x1 · NBMISCIND:0x8<br>MULTIPORT_CONFIG_GPP1                  | Programs PCIE-GPP1 to be dual port configuration 8:8. |
|                            |      | Set bit [8] to 0x1.                                                                  |                                                       |
|                            | 4    | Wait for 2 ms                                                                        |                                                       |
|                            | 5    | NBCFG:PCIE_NBCFG_REGE[28]=0x0 · NBMISCIND:0x26<br>~STRAP_BIF_all_valid for PCIE-GPP1 | Asserts STRAP_BIF_all_valid for<br>PCIE-GPP1 core     |
|                            |      | Clear bit [28] to 0x 0.                                                              |                                                       |
|                            | 6    | NBCFG:PCIE_LINK_CFG[15]=0x0 · NBMISCIND:0x8<br>GLOBAL_RESET_GPP1                     | De-asserts PCIE-GPP1 global reset.                    |
|                            |      | Clear bit [15] to 0x0.                                                               |                                                       |
|                            | 7    | Follow the procedure for PCIE-GPP1 common initialization and link training sequence. |                                                       |

 Table 4-3 Programming Sequence for Loading Dual PCIE-GPP1 Core Configuration Topology

### 4.3.3.1.1.2 Configuring PCIE-GPP2 Core Topology

[NOTE: This section is not applicable to SR5670 and SR5650.]

The sequence below should be performed to switch configurations of the PCIE-GPP2 core.

| ASIC Rev | Step | Register Settings                                            | Function/Comment                   |
|----------|------|--------------------------------------------------------------|------------------------------------|
| SR5690   | 1    | NBCFG:PCIE_LINK_CFG[13]=0x1 · NBMISCIND:0x8                  | Asserts PCIE-GPP2 global reset     |
| All Revs |      | GLOBAL_RESET_GPP2                                            |                                    |
|          |      | Set bit [13] to 0x1.                                         |                                    |
|          | 2    | NBCFG:PCIE_NBCFG_REGE[29]=0x1 · NBMISCIND:0x26               | De-asserts STRAP_BIF_all_valid for |
|          |      | ~STRAP_BIF_all_valid for PCIE_GPP2                           | PCIE-GPP2 core.                    |
|          |      | Set bit [29] to 0x1.                                         |                                    |
|          | 3    | NBCFG:PCIE_LINK_CFG[9]=0x1 · NBMISCIND:0x8                   | Programs PCIE-GPP2 to dual port    |
|          |      | MULTIPORT_CONFIG_GPP2                                        | configuration 8:8.                 |
|          |      |                                                              |                                    |
|          |      | Set bit [9] to 0x1.                                          |                                    |
|          | 4    | Wait for 2 ms                                                |                                    |
|          | 5    | NBCFG:PCIE_NBCFG_REGE[29]=0x0 · NBMISCIND:0x26               | Asserts STRAP_BIF_all_valid for    |
|          |      | ~STRAP_BIF_all_valid for PCIE-GPP2                           | PCIE-GPP2 core.                    |
|          |      |                                                              |                                    |
|          |      | Clear bit [29] to 0x0.                                       |                                    |
|          | 6    | NBCFG:PCIE_LINK_CFG[13]=0x0 · NBMISCIND:0x8                  | De-asserts PCIE-GPP2 global reset. |
|          |      | GLOBAL_RESET_GPP2                                            |                                    |
|          |      |                                                              |                                    |
|          |      | Clear bit [13] to 0x0.                                       |                                    |
|          | 7    | Follow the procedure for PCIE-GPP2 common initialization and |                                    |
|          |      | link training sequence                                       |                                    |

## 4.3.3.2 A-Link Express II, PCIE-GPP3a and PCIE-GPP3b Configuration Topologies

## 4.3.3.2.1 A-Link Express II Configuration Topology

The PCIE-SB core controls a single PCIe<sup>®</sup> port with up to 4 PCIe lanes for establishing a high performance link with the Southbridge, known as A-Link Express II. A-Link Express II gets automatically trained upon initial boot up, after Northbridge and then Southbridge power rails become stable, and after the CPU clock becomes stable. Taking Northbridge out of reset automatically triggers training of this link as it is released for training by hardware default.

## 4.3.3.2.2 PCIE-GPP3a Core Configuration Topologies

The PCIE-GPP3a core supports six PCIe configuration topologies controlling six PCIe lanes. This PCIe core is disabled by default on initial boot-up until system BIOS configures the core to reflect the required customer's configuration topology of the system. The following is a description of the six PCIE-GPP3a Core Configuration Topologies.

## 4.3.3.2.2.1 PCIE-GPP3a Configuration 1:1:1:1:1

The default PCIE-GPP3a core configuration controls six PCIe ports, each one with 1 PCIe lane. All six ports are held from link training by default. To allow link training on each PCIE-GPP3a port, the corresponding HOLD\_TRAINING bit must be cleared.

| ASIC Rev     | GPP3a Port<br>(Static Device Number) | Associated Lanes | NBCFG:PCIE_LINK_CFG[26:21] NBMISCIND:0x8<br>HOLD_TRAIN*_GPP3a |
|--------------|--------------------------------------|------------------|---------------------------------------------------------------|
| SR5690/5670/ | GPP3a Port 0                         | GPP3a_RX/TX0     | PCIE_LINK_CFG[21]                                             |
| 5650         | (Dev4)                               |                  | HOLD_TRAIN1_GPP3a (Hold PCIE-GPP3a Port 0 from Link Training) |
| All Revs     | GPP3a Port 1                         | GPP3a_RX/TX1     | PCIE_LINK_CFG[22]                                             |
|              | (Dev5)                               |                  | HOLD_TRAIN2_GPP3a (Hold PCIE-GPP3a Port 1 from Link Training) |
|              | GPP3a Port 2                         | GPP3a_RX/TX2     | PCIE_LINK_CFG[23]                                             |
|              | (Dev6)                               |                  | HOLD_TRAIN3_GPP3a (Hold PCIE-GPP3a Port 2 from Link Training) |
| SR5690/5670/ | GPP3a Port 3                         | GPP3a_RX/TX3     | PCIE_LINK_CFG[24]                                             |
| 5650         | (Dev7)                               |                  | HOLD_TRAIN4_GPP3a (Hold PCIE-GPP3a Port 3 from Link Training) |
| All Revs     | GPP3a Port 4                         | GPP3a_RX/TX4     | PCIE_LINK_CFG[25]                                             |
|              | (Dev9)                               |                  | HOLD_TRAIN5_GPP3a (Hold PCIE-GPP3a Port 4 from Link Training) |
|              | GPP3a Port 5                         | GPP3a_RX/TX5     | PCIE_LINK_CFG[26]                                             |
|              | (Dev10)                              |                  | HOLD_TRAIN6_GPP3a (Hold PCIE-GPP3a Port 5 from Link Training) |

#### Table 4-5 Default PCIE-GPP3a Configuration 1:1:1:1:1:1

#### 4.3.3.2.2.2 PCIE-GPP3a Configuration 4:2:0:0:0:0

This configuration controls two PCIe ports, one controlling up to 4 PCIe lanes and the other controlling up to 2 PCIe lanes. To allow link training on each port, the corresponding HOLD\_TRAINING bit must be cleared as described below.

Table 4-6 PCIE-GPP3a Configuration 4:2:0:0:0:0

| ASIC Rev     | GPP3a Port<br>(Static Device Number) | Associated Lanes | NBCFG:PCIE_LINK_CFG[26:21]· NBMISCIND:0x8<br>HOLD_TRAIN*_GPP3a |
|--------------|--------------------------------------|------------------|----------------------------------------------------------------|
| SR5690/5670/ | GPP3a Port 0                         | GPP3a_RX/TX0     | PCIE_LINK_CFG[21]                                              |
| 5650         | (Dev4)                               | GPP3a_RX/TX1     | HOLD_TRAIN1_GPP3a (Hold PCIE-GPP3a Port 0 from Link Training)  |
| All Revs     |                                      | GPP3a_RX/TX2     |                                                                |
|              |                                      | GPP3a_RX/TX3     |                                                                |
|              | GPP3a Port 1                         | GPP3a_RX/TX4     | PCIE_LINK_CFG[22]                                              |
|              | (Dev9)                               | GPP3a_RX/TX5     | HOLD_TRAIN2_GPP3a (Hold PCIE-GPP3a Port 1 from Link Training)  |

#### 4.3.3.2.2.3 PCIE-GPP3a Configuration 4:1:1:0:0:0

This configuration controls 3 PCIe ports, one controlling up to 4 PCIe lanes, and other two each controlling 1 PCIe lane. To allow link training on each port, the corresponding HOLD\_TRAINING bit must be cleared as described below.

Table 4-7 PCIE-GPP3a Configuration 4:1:1:0:0:0

| ASIC Rev     | GPP3a Port<br>(Static Device Number) | Associated Lanes | NBCFG:PCIE_LINK_CFG[26:21]· NBMISCIND:0x8<br>HOLD_TRAIN*_GPP3a |
|--------------|--------------------------------------|------------------|----------------------------------------------------------------|
| SR5690/5670/ | GPP3a Port 0                         | GPP3a_RX/TX0     | PCIE_LINK_CFG[21]                                              |
| 5650         | (Dev4)                               | GPP3a_RX/TX1     | HOLD_TRAIN1_GPP3a (Hold PCIE-GPP3a Port 0 from Link Training)  |
| All Revs     |                                      | GPP3a_RX/TX2     |                                                                |
|              |                                      | GPP3a_RX/TX3     |                                                                |
|              | GPP3a Port 1                         | GPP3a_RX/TX4     | PCIE_LINK_CFG[22]                                              |
|              | (Dev9)                               |                  | HOLD_TRAIN2_GPP3a (Hold PCIE-GPP3a Port 1 from Link Training)  |
|              | GPP3a Port 2                         | GPP3a_RX/TX5     | PCIE_LINK_CFG[23]                                              |
|              | (Dev10)                              |                  | HOLD_TRAIN3_GPP3a (Hold PCIE-GPP3a Port 2 from Link Training)  |

## 4.3.3.2.2.4 PCIE-GPPGPP3a Configuration 2:2:2:0:0:0

This configuration controls 3 PCIe ports, each one controlling up to 2 PCIe lanes. To allow link training on each port, the corresponding HOLD\_TRAINING bit must be cleared as described below.

| ASIC Rev     | GPP3a Port<br>(Static Device<br>Number) | Associated Lanes | NBCFG:PCIE_LINK_CFG[26:21]· NBMISCIND:0x8<br>HOLD_TRAIN*_GPP3a |
|--------------|-----------------------------------------|------------------|----------------------------------------------------------------|
| SR5690/5670/ | GPP3a Port 0                            | GPP3a_RX/TX0     | PCIE_LINK_CFG[21]                                              |
| 5650         | (Dev4)                                  | GPP3a_RX/TX1     | HOLD_TRAIN1_GPP3a (Hold PCIE-GPP3a Port 0 from Link Training)  |
| All Revs     | GPP3a Port 1                            | GPP3a_RX/TX2     | PCIE_LINK_CFG[22]                                              |
|              | (Dev6)                                  | GPP3a_RX/TX3     | HOLD_TRAIN2_GPP3a (Hold PCIE-GPP3a Port 1 from Link Training)  |
|              | GPP3a Port 2                            | GPP3a_RX/TX4     | PCIE_LINK_CFG[23]                                              |
|              | (Dev9)                                  | GPP3a_RX/TX5     | HOLD_TRAIN3_GPP3a (Hold PCIE-GPP3a Port 2 from Link Training)  |

Table 4-8 PCIE-GPP3a Configuration 2:2:2:0:0:0

## 4.3.3.2.2.5 PCIE-GPP3a Configuration 2:2:1:1:0:0

This configuration controls 4 PCIe ports, the first two controlling up to 2 PCIe lanes and the other two controlling 1 PCIe lane. To allow link training on each port, the corresponding HOLD\_TRAINING bit must be cleared as described below.

#### Table 4-9 PCIE-GPP3a Configuration 2:2:1:1:0:0

| ASIC Rev     | PCIE-GPP3a Port<br>(Static Device Number) | Associated Lanes | NBCFG:PCIE_LINK_CFG[26:21]· NBMISCIND:0x8<br>HOLD_TRAIN*_GPP3a |
|--------------|-------------------------------------------|------------------|----------------------------------------------------------------|
| SR5690/5670/ | GPP3a Port 0                              | GPP3a_RX/TX0     | PCIE_LINK_CFG[21]                                              |
| 5650         | (Dev4)                                    | GPP3a_RX/TX1     | HOLD_TRAIN1_GPP3a (Hold PCIE-GPP3a Port 0 from Link            |
| All Revs     |                                           |                  | Training)                                                      |
|              | GPP3a Port 1                              | GPP3a_RX/TX2     | PCIE_LINK_CFG[22]                                              |
|              | (Dev6)                                    | GPP3a_RX/TX3     | HOLD_TRAIN2_GPP3a (Hold PCIE-GPP3a Port 1 from Link            |
|              |                                           |                  | Training)                                                      |
|              | GPP3a Port 2                              | GPP3a_RX/TX4     | PCIE_LINK_CFG[23]                                              |
|              | (Dev9)                                    |                  | HOLD_TRAIN3_GPP3a (Hold PCIE-GPP3a Port 2 from Link            |
|              |                                           |                  | Training)                                                      |
|              | GPP3a Port 3                              | GPP3a_RX/TX5     | PCIE_LINK_CFG[24]                                              |
|              | (Dev10)                                   |                  | HOLD_TRAIN4_GPP3a (Hold PCIE-GPP3a Port 3 from Link            |
|              |                                           |                  | Training)                                                      |

### 4.3.3.2.2.6 PCIE-GPP3a Configuration 2:1:1:1:1:0

This configuration controls 5 PCIe ports, the first one controlling up to 2 PCIe lanes and other 4 controlling 1 PCIe lane. To allow link training on each port, the corresponding HOLD\_TRAINING bit must be cleared as described below.

Table 4-10 PCIE-GPP3a Configuration 2:1:1:1:1:0

| ASIC Rev     | GPP3a Port<br>(Static Device Number) | Associated Lanes | NBCFG:PCIE_LINK_CFG[26:21]· NBMISCIND:0x8<br>HOLD_TRAIN*_GPP3a |
|--------------|--------------------------------------|------------------|----------------------------------------------------------------|
| SR5690/5670/ | GPP3a Port 0                         | GPP3a_RX/TX0     | PCIE_LINK_CFG[21]                                              |
| 5650         | (Dev4)                               | GPP3a_RX/TX1     | HOLD_TRAIN1_GPP3a (Hold PCIE-GPP3a Port 0 from Link Training)  |
| All Revs     | GPP3a Port 1                         | GPP3a_RX/TX2     | PCIE_LINK_CFG[22]                                              |
|              | (Dev6)                               |                  | HOLD_TRAIN2_GPP3a (Hold PCIE-GPP3a Port 1 from Link Training)  |
|              | GPP3a Port 2                         | GPP3a_RX/TX3     | PCIE_LINK_CFG[23]                                              |
|              | (Dev7)                               |                  | HOLD_TRAIN3_GPP3a (Hold PCIE-GPP3a Port 2 from Link Training)  |
|              | GPP3a Port 3                         | GPP3a_RX/TX4     | PCIE_LINK_CFG[24]                                              |
|              | (Dev9)                               |                  | HOLD_TRAIN4_GPP3a (Hold PCIE-GPP3a Port 3 from Link Training)  |
|              | GPP3a Port 4                         | GPP3a_RX/TX5     | PCIE_LINK_CFG[25]                                              |
|              | (Dev10)                              |                  | HOLD_TRAIN1_GPP3a (Hold PCIE-GPP3a Port 4 from Link Training)  |

### 4.3.3.2.3 Reflecting Platform Topology into PCIE-GPP3a Core Configuration Topologies

PCIE-GPP3a configuration topology can be selected using either one of the two methods:

- "**Pin Straps**" method (default method)
- "Software Programming Sequence" method

The selection of the method to load the required PCIE-GPP3a configuration topology again depends on the level of the required platform modularity. If the required platform configuration is static, then the "Pin Straps" method represents the simpler platform solution to load the required customer topology into PCIE-GPP3a core with no dependency on any additional software programming. Customers' system topologies requiring platforms with a higher degree of modularity may find the "Software Programming Sequence" method to be more suitable.

#### 4.3.3.2.3.1 Configuring PCIE-GPP3a Core Topology Using "Pin Straps" Method

SR5690/5670/5650 offers three dedicated pin straps - DFT\_GPIO[4:2] - in order to select one out of six possible PCIE-GPP3a configurations and reflect the required customer's system topology into PCIE-GPP3a core. The pin straps are active low straps and are pulled up internally to operate in default states. In order to change the default value of the pin strap, the strap pins must be pulled down to VSS through a resistor, typically of the value of 3 KOhms.

*Table 4-11* shows the pin strap value mapping into PCIE-GPP3a core configuration and the read-back register of the configuration selected.

| PCIE-GI | Encoding Scheme of<br>PCIE-GPP3a Configurations<br>using Pin Straps DFT_GPIO[4:2] |   | Read-back value of Pin Straps Used to Define<br>PCIE-GPP3a Configuration<br>NBCFG:StrapsOutputMux7[4:0] · NBMISCIND:0x67 | PCIE-GPP3a Configuration                                                                                                                                                                                                                       |
|---------|-----------------------------------------------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | 1                                                                                 | 0 | 01011                                                                                                                    | 1:1:1:1:1 (default)                                                                                                                                                                                                                            |
| 0       | 0                                                                                 | 0 | 00001                                                                                                                    | 4:2:0:0:0:0                                                                                                                                                                                                                                    |
| 0       | 0                                                                                 | 1 | 00010                                                                                                                    | 4:1:1:0:0:0                                                                                                                                                                                                                                    |
| 1       | 0                                                                                 | 1 | 01100                                                                                                                    | 2:2:2:0:0:0                                                                                                                                                                                                                                    |
| 1       | 0                                                                                 | 0 | 01010                                                                                                                    | 2:2:1:1:0:0                                                                                                                                                                                                                                    |
| 0       | 1                                                                                 | 1 | 00100                                                                                                                    | 2:1:1:1:10                                                                                                                                                                                                                                     |
| 1       | 1                                                                                 | 1 | Read back register programmed configuration.                                                                             | PCIE-GPP3a configuration selected by<br>register programmed value:<br>NBCFG:StrapsOutputMux7[4:0] ·<br>NBMISCIND:0x67<br>STRAP_BIF_LINK_CONFIG<br>NOTE: Encoded register value should<br>reflect one of the supported configurations<br>above. |
| 1       | 1                                                                                 | 0 | Same as above                                                                                                            | Same as above                                                                                                                                                                                                                                  |

#### Table 4-11 Pin Strap Value and Link Configuration Mapping

Pin straps can be overwritten by a register, regardless of the PCIE-GPP3a configuration set by pin straps. To switch the PCIE-GPP3a ports configuration from the one selected by pin straps, use the "Software Programming Sequence" method described below.

### 4.3.3.2.3.2 Configuring PCIE-GPP3a Core Topology Using "Software Programming Sequence" Method

PCIE-GPP3a core configuration topology can be selected by following the programming sequence outlined below.

| ASIC Rev                         | Step | Register Settings                                                                                                                                           | Function/Comment                                                                                                                                                                                                                                           |
|----------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    | NBCFG:PCIE_LINK_CFG[31]=0x1 · NBMISCIND:0x8<br>GLOBAL_RESET_GPP3a<br>Set bit [31] to 0x 1.                                                                  | Asserts PCIE-GPP3a global reset.                                                                                                                                                                                                                           |
|                                  | 2    | NBCFG:PCIE_NBCFG_REGE[30]=0x1 · NBMISCIND:0x26<br>~STRAP_BIF_all_valid for PCIE-GPP3a<br>Set bit [30] to 0x1.                                               | De-asserts STRAP_BIF_all_valid for<br>PCIE-GPP3a core.                                                                                                                                                                                                     |
|                                  | 3    | Reprogram bits [4:0] to select new PCIE-GPP3a configuration<br>to override the one defined via pin straps.<br>NBCFG:StrapsOutputMux7 [4:0] · NBMISCIND:0x67 | Programs the desired PCIE-GPP3a<br>configuration. [Refer to Table 4-11 for<br>encoding scheme.]<br>[Note: This step is performed only if<br>PCIE-GPP3a ports are to be configured in a<br>configuration different from the one defined<br>via pin straps.] |
|                                  | 4    | NBCFG:PCIE_NBCFG_REGE[27:0] · NBMISCIND:0x26                                                                                                                | Programs PCIE-GPP3a Line Director.<br>Refer to <i>Table 4-13</i> for the encoding scheme.                                                                                                                                                                  |
|                                  | 5    | NBCFG:PCIE_NBCFG_REGE[30]=0x0 · NBMISCIND:0x26<br>~STRAP_BIF_all_valid for PCIE-GPP3a<br>Clear bit [30] to 0x0.                                             | Assert STRAP_BIF_all_valid for<br>PCIE-GPP3a core.                                                                                                                                                                                                         |
|                                  | 6    | NBCFG:PCIE_LINK_CFG[31]=0x0 · NBMISCIND:0x8<br>GLOBAL_RESET_GPP3a<br>Clear bit [31] to 0x0.                                                                 | De-asserts PCIE-GPP3a global reset.                                                                                                                                                                                                                        |

Table 4-12 Switching PCIE-GPP3a Configurations

### 4.3.3.2.3.3 Programming PCIE-GPP3a Line Director

PCIE-GPP3a core has in place a Line Director whose main function is to distribute PCIe lanes to each of PCIe ports in each of the configuration topologies. System BIOS must program PCIE-GPP3a Line Director depending on the selected PCIE-GPP3a configuration regardless of the method chosen to load the configuration topology into PCIE-GPP3a core.

*Table 4-13* lists the values that need to be programmed into the Line Director depending on the configuration topology selected. Programming steps required are detailed in *Section 4.4 "Overall PCIe Programming Sequence" on page 4-18.* 

|                             | NBCFG:PCIE_NBCFG_REGE[27:0] · NBMISCIND:0x26 |                             |                             |                             |                                        |                                        |                                        |                                                   |
|-----------------------------|----------------------------------------------|-----------------------------|-----------------------------|-----------------------------|----------------------------------------|----------------------------------------|----------------------------------------|---------------------------------------------------|
| PCIE-GPP3a<br>Configuration | Straight<br>Configuration                    | Port 0<br>Lanes<br>Reversed | Port 1<br>Lanes<br>Reversed | Port 2<br>Lanes<br>Reversed | Port 0 and<br>Port 1 Lanes<br>Reversed | Port 0 and<br>Port 2 Lanes<br>Reversed | Port 1 and<br>Port 2 Lanes<br>Reversed | Port 0, Port 1<br>and Port 2<br>Lanes<br>Reversed |
| 1:1:1:1:1:1                 | 0x2AA3554                                    | N/A                         | N/A                         | N/A                         | N/A                                    | N/A                                    | N/A                                    | N/A                                               |
| 4:2:0:0:0:0                 | 0x055B000                                    | 0x055B000                   | 0xF05BA00                   | N/A                         | 0xF05BA00                              | N/A                                    | N/A                                    | N/A                                               |
| 4:1:1:0:0:0                 | 0x215B400                                    | 0x215B400                   | N/A                         | N/A                         | N/A                                    | N/A                                    | N/A                                    | N/A                                               |
| 2:2:2:0:0:0                 | 0xFF0BAA0                                    | 0xFFF0AAA                   | 0xFF0BAA0                   | 0xFF0BAA0                   | 0xFFF0AAA                              | 0xFFF0AAA                              | 0xFF0BAA0                              | 0xFFF0AAA                                         |
| 2:2:1:1:0:0                 | 0x215B400                                    | 0x215B400                   | 0x215B400                   | N/A                         | 0x215B400                              | N/A                                    | N/A                                    | N/A                                               |
| 2:1:1:1:1:0                 | 0xFF0BAA0                                    | 0xFFF0AAA                   | N/A                         | N/A                         | N/A                                    | N/A                                    | N/A                                    | N/A                                               |

Table 4-13 PCIE-GPP3a Line Director Mapping

## 4.3.3.2.4 PCIE-GPP3b Core Configuration Topology

NOTE: This section does not apply to SR5670 and SR5650 as neither supports the PCIE-GPP3b core.

SR5690/5670/5650 PCIE-GPP3b core controls a single PCIe port (Port 0) with up to 4 PCIe lanes. This PCIe core is disabled by hardware default. To allow link training on the PCIE-GPP3b PCIe port, the corresponding HOLD\_TRAINING bit must be cleared as described below.

#### Table 4-14 PCIE GPP3b Port Configuration

| ASIC Rev | PCIE-GPP3b Port<br>(Static Device Number) | Associated Lanes                             | NBCFG:PCIE_NBCFG_REG12 [4] · NBMISCIND:0x2A<br>HOLD_TRAIN*_GPP3b |
|----------|-------------------------------------------|----------------------------------------------|------------------------------------------------------------------|
| SR5690   | GPP3b Port 0                              | GPP3b_RX/TX0                                 | PCIE_NBCFG_REG12 [4]                                             |
| All Revs | (Dev13)                                   | GPP3b_RX/TX1<br>GPP3b_RX/TX2<br>GPP3b_RX/TX3 | HOLD_TRAIN1_GPP3b (Hold PCIE-GPP3b Port 0 from Link<br>Training) |

## 4.3.4 Methods to Bring PCIe Links to Gen 2 Speed

SR5690/5670/5650 supports three methods to bring PCIe links to Gen 2 speed.

- Hardware Autonomous method
- RC Advertised Gen 2 method
- Software Initiated Gen 2 Speed method

#### Hardware Autonomous Method:

This method completely relies on SR5690/5670/5650 hardware to train each PCIe link to operational state at Gen 2 speed once each PCIe link is allowed to start training on initial boot up. This method is used as primary method and it is embedded into PCIe link training sequence that maximizes each PCIe link bandwidth as well as interoperability with all devices present in the system on initial boot up. The PCIe link training sequence is referred to in the document as "Auto". When this PCIe link training sequence is selected on initial boot up, each SR5690/5670/5650 PCIe port will advertise Gen 2 capabilities on each PCIe link during the link training and try to bring the link to Gen 2 speed depending on advertised capabilities of device on the other side of PCIe link. All PCIe links with Gen 2 capable devices will then be trained to operational state at Gen 2 speed and all PCIe links with only Gen 1 capable devices will be trained to operational state at Gen 1 speed.

#### **RC Advertised Gen 2 Method:**

When this method is selected, SR5690/5670/5650 hardware advertises its Gen 2 capabilities to all devices present in the system on initial boot up, during the link training. It is then up to endpoint device software, usually built into device driver, to initiate the transition to Gen 2 speed on the PCIe link. All PCIe links with only Gen 1 capable devices would be trained to operational state at Gen 1 speed respecting backwards compatibility with Gen 1 devices.

#### Software Initiated Gen 2 Speed Method:

This method assumes that the PCIe link is already operational at Gen 1 rate. Software would initiate the transition to Gen 2 rate by triggering a register write either from the SR5690/5670/5650 PCIe Port PCI Configuration Space register or from the port's private register.

#### 4.4 **Overall PCIe Programming Sequence**

The overall PCIe programming sequence is composed of the following sections:

- Section 4.4.1 "Power-On Default State" on page 4-18
- Section 4.4.2 "PCIe® Cores Initialization" on page 4-19
- Section 4.4.3 "PCIe® Links Training" on page 4-51 •
- Section 4.4.4 "PCIe® Power Control" on page 4-60 •
- Section 4.4.5 "Static PCIe® Port Power Down Control" on page 4-64 •
- Section 4.4.6 "PCIe® Enumeration and Special Features Programming Sequence" on page 4-74 •
- Section 4.4.7 "Optional Features" on page 4-79
- Section 4.4.8 "PCIe Workarounds" on page 4-87

#### 4.4.1 **Power-On Default State**

After a power-on reset or a warm-reset event, the northbridge places all of its PCIe devices in the PCIe subsystem in their default states. For maximum flexibility and robustness, the default states are set such that only the link to the southbridge is active, so that CPU boot-code can be fetched. All other links/lanes are inactive so that no assumptions on system topology are required. When the link to the southbridge trains, it will only do so in the safest mode of operation to ensure a robust start up with maximum margin. The default state of each northbridge PCIe device is shown in Table 4-15.

| ASIC Rev               | PCIE Port (PCI Device Number)                     | Link Training | Number of Lanes Supported |
|------------------------|---------------------------------------------------|---------------|---------------------------|
| SR5690/5670/5650       | PCIE-GPP1 Port 0 (Dev 2)                          | Disabled      | 1, 2, 4, 8, or 16         |
| All Revs               | PCIE-GPP1 Port 1 (Dev 3)                          | Disabled      | 1, 2, 4, or 8             |
|                        | PCIE-GPP3a Port 0 (Dev 4)                         | Disabled      | 1, 2, or 4                |
|                        | PCIE-GPP3a Port 1 (Dev 5)                         | Disabled      | 1 or 2                    |
|                        | PCIE-GPP3a Port 2 (Dev 6)                         | Disabled      | 1 or 2                    |
|                        | PCIE-GPP3a Port 3 (Dev 7) Disabl                  |               | 1                         |
|                        | PCIE-SB Port 0 (Dev 8) * Enabl                    |               | 1 or 2 or 4               |
|                        | PCIE-GPP3a Port 4 (Dev 9) Disabled                |               | 1                         |
|                        | PCIE-GPP3a Port 5 (Dev 10)                        | Disabled      | 1                         |
|                        | PCIE-GPP2 Port 0 (Dev 11) **, ***                 | Disabled      | 1, 2, 4, 8, or 16         |
|                        | PCIE-GPP2 Port 1 (Dev 12) *** Disab               |               | 1, 2, 4, or 8             |
|                        | PCIE-GPP3b Port 0 (Dev 13) ****                   | Disabled      | 1, 2, or 4                |
| PCI device 8 (Dev 8) o | does not appear in the PCI configuration space by | default.      |                           |
| * For SR5670, the num  | nber of lanes supported is: 1, 2, 4, or 8         |               |                           |
| ** SR5650 does not su  | pport PCIE-GPP2 core and its associated ports     |               |                           |
| **** SP5670 and SP564  | 50 do not support PCIE-GPP3b core                 |               |                           |

#### Table 4-15 Northbridge PCIe Default States

SR5670 and SR5650 do not support PCIE-GPP3b core

# 4.4.2 PCIe<sup>®</sup> Cores Initialization

[Note 1: All references in this section related to Port 1 of PCIE-GPP2 core do not apply to SR5670.]

[Note 2: All references in this section related to either Port 0 or Port 1 of PCIE-GPP2 core or the core itself do not apply to SR5650.]

• Step 1: Reflect platform topology requirements into PCIE-GPP1, PCIE-GPP2 and PCIE-GPP3a cores configurations:

In order to reflect customer requirements for system topology into PCIE-GPP1 and PCIE-GPP2 cores configurations, follow Step 1-to-Step 4 specified in *Table 4-3* and *Table 4-4* of *Section 4.3.3.1.1.1 "Configuring PCIE-GPP1 Core Topology" on page 4-10* and *Section 4.3.3.1.1.2 "Configuring PCIE-GPP2 Core Topology" on page 4-11* respectively.

If "Pin Strap" method is used to configure PCIE-GPP3a core in order to reflect the required customer's system topology configuration, then this step should be bypassed. If "Software Programming Sequence" is used instead, then follow Step1-to-Step 3 specified in *Table 4-12 "Switching PCIE-GPP3a Configurations" on page 4-15.* 

#### • Step 2: PCIe Ports Lane Reversal (CMOS option):

SR5690/5670/5650 PCIe ports are fully capable of supporting lane reversal feature. For example, certain platform designs may place a multi-lane on-board endpoint device on the reverse side of the PCB relative to the root-complex. To ease signal routing issues, the lanes of the root-complex may be connected to the endpoint lanes in reverse order such that root-complex Lane 0 connects to the highest numbered lane on the endpoint, root-complex Lane 1 connects to the second highest numbered lane on the endpoint, and so on. Enabling the lane reversal feature on the associated SR5690/5670/5650 PCIe port would allow the endpoint device to see normally ordered rather than reversed lanes, hence this CMOS option should be enabled by default for each SR5690/5670/5650 PCIE-GPP1 or PCIE-GPP2 port, where routing requirements impose reverse lane mapping on a PCIe link.

The following CMOS options are available:

- PCIE-GPP1 Port 0 Lane Reversal (Single/Dual Port Configuration)
- PCIE-GPP1 Port 1 Lane Reversal (Dual Port Configuration)
- PCIE-GPP2 Port 0 Lane Reversal (Single/Dual Port Configuration) (Not applicable to SR5650)
- PCIE-GPP2 Port 1 Lane Reversal (Dual Port Configuration) (Not applicable to SR5670 and SR5650)
- PCIE-GPP3a Port 0 Lane Reversal [NOTE: This CMOS option is applicable in the following PCIE-GPP3a configurations: 4:2:0:0:00, 4:1:1:0:0:0, 2:2:2:0:0:0, 2:2:1:1:0:0, 2:1:1:1:1:0]
- PCIE-GPP3a Port 1 Lane Reversal [NOTE: This CMOS option is applicable in the following PCIE-GPP3a configurations: 4:2:0:0:0, 2:2:2:0:00, 2:2:1:1:0:0]
- PCIE-GPP3a Port 2 Lane Reversal [NOTE: This CMOS option is applicable in the following PCIE-GPP3a configuration: 2:2:2:0:0:0]
- PCIE-GPP3a Port 0 and 1 Lane Reversal [NOTE: This CMOS option is applicable in the following PCIE-GPP3a configurations: 4:2:0:0:0, 2:2:2:0:0:0, 2:2:1:1:0:0]
- PCIE-GPP3a Port 0 and 2 Lane Reversal [NOTE: This CMOS option is applicable in the following PCIE-GPP3a configuration: 2:2:2:0:0:0]
- PCIE-GPP3a Port 1 and 2 Lane Reversal [NOTE: This CMOS option is applicable in the following PCIE-GPP3a configuration: 2:2:2:0:0:0]
- PCIE-GPP3a Port 0, 1 and 2 Lane Reversal [NOTE: This CMOS option is applicable in the following PCIE-GPP3a configuration: 2:2:2:0:0:0]
- PCIE-GPP3b Port 0 Lane Reversal (Not applicable to SR5670, SR5650)

To enable Lane Reversal on any of SR5690/5670/5650 PCIE-GPP1 ports, follow the programming sequence outlined below.

| ASIC Rev     | Step | Register Settings                              | Function/Comment                           |
|--------------|------|------------------------------------------------|--------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_NBCFG_REGE[28]=0x1 ·NBMISCIND:0x26  | De-asserts STRAP_BIF_all_valid for         |
| 5650         |      | ~STRAP_BIF_all_valid for GPP1                  | PCIE-GPP1 core.                            |
| All Revs     |      |                                                |                                            |
|              |      | Set bit [28] to 0x1.                           |                                            |
|              | 2    | NBCFG:PCIE_NBCFG_REGF[3]=0x1 ·NBMISCIND:0x27   | Enables PCIE-GPP1 Port 0 lane reversal if  |
|              |      | STRAP_BIF_REVERSE_LANES_0                      | respective CMOS option is selected in      |
|              |      |                                                | Single or Dual Configuration               |
|              |      | Set bit [3] to 0x1.                            |                                            |
|              | 3    | NBCFG:PCIE_NBCFG_REGF[4]=0x1 ·NBMISCIND:0x27   | Enables PCIE-GPP1 Port 1 lane reversal if  |
|              |      | STRAP_BIF_REVERSE_LANES_1                      | respective CMOS option is selected only in |
|              |      |                                                | Dual Configuration.                        |
|              |      | Set bit [4] to 0x1.                            |                                            |
|              | 4    | NBCFG:PCIE_NBCFG_REGE[28]=0x0 · NBMISCIND:0x26 | Asserts STRAP_BIF_all_valid for            |
|              |      | ~STRAP_BIF_all_valid for GPP1                  | PCIE-GPP1 core.                            |
|              |      | Clear bit [28] to 0x0.                         |                                            |

If it is detected in *Step1, on page 4-19* that PCIE-GPP1 core is configured in single slot configuration, and PCIE-GPP1 Lane Reversal CMOS option is selected, program as shown in table below.

#### Table 4-17 PCIE-GPP1 Lane Reversal PLL Selection

| ASIC Rev         | Step | Register Settings                                | Function/Comment                                                                  |
|------------------|------|--------------------------------------------------|-----------------------------------------------------------------------------------|
| SR5690/5670/     | 1    | NBCFG:PCIE_PDNB_CNTL[16:12]=0x1F · NBMISCIND:0x7 | Program this step if PCIE-GPP1 core is                                            |
| 5650<br>All Revs |      | TXCLK_SEL_GPP1 [16]                              | configured in Single Slot Configuration and Lane Reversal CMOS option is enabled: |
|                  |      |                                                  | PLL Mux Control for TXCLK PERM, DYN,<br>and IO for PCIE-GPP1 core.                |

To enable lane reversal on any of SR5690/5670/5650 PCIE-GPP2 ports, follow the programming sequence outlined below.

| Table 4-18 | PCIE-GPP2 Ports | Lane Reversal | Programming Sequence |
|------------|-----------------|---------------|----------------------|
|------------|-----------------|---------------|----------------------|

| ASIC Rev     | Step | Register Settings                              | Function/Comment                             |
|--------------|------|------------------------------------------------|----------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_NBCFG_REGE[29]=0x1 · NBMISCIND:0x26 | De-asserts STRAP_BIF_all_valid for           |
| 5650         |      | ~STRAP_BIF_all_valid for GPP2                  | PCIE-GPP2 core.                              |
| All Revs     |      |                                                |                                              |
|              |      | Set bit [29] to 0x1.                           |                                              |
|              | 2    | NBCFG:PCIE_NBCFG_REGF[5]=0x1 · BMISCIND:0x27   | Enables PCIE-GPP2 Port 0 lane reversal if    |
|              |      | STRAP_BIF_REVERSE_LANES_0                      | respected CMOS option is selected in Single  |
|              |      |                                                | or Dual Configuration                        |
|              |      | Set bit [5] to 0x1.                            |                                              |
|              | 3    | NBCFG:PCIE_NBCFG_REGF[6]=0x1 · NBMISCIND:0x27  | Enables PCIE-GPP2 Port 1 lane reversal if    |
|              |      | STRAP_BIF_REVERSE_LANES_1                      | respected CMOS option is selected only in    |
|              |      |                                                | Dual Configuration.                          |
|              |      |                                                |                                              |
|              |      | Set bit [6] to 0x1.                            | NOTE: This step is not applicable to SR5670. |
|              | 4    | NBCFG:PCIE_NBCFG_REGE[29]=0x0 · NBMISCIND:0x26 | Asserts STRAP_BIF_all_valid for PCIE-GPP2    |
|              |      | ~STRAP_BIF_all_valid for GPP2                  | core.                                        |
|              |      |                                                |                                              |
|              |      | Clear bit [29] to 0x0.                         |                                              |

If it is detected in *Step1, on page 4-19* that PCIE-GPP2 core is configured in single port configuration, and PCIE-GPP2 Lane Reversal CMOS option is selected, follow the sequence below.

| ASIC Rev           | Step | Register Settings                                | Function/Comment                                                   |
|--------------------|------|--------------------------------------------------|--------------------------------------------------------------------|
| SR5690<br>All Revs |      |                                                  | PLL Mux Control for TXCLK PERM, DYN, and IO<br>for PCIE-GPP2 core. |
|                    |      | TXCLK_IO_SEL_GPP2 [23.22]<br>TXCLK_SEL_GPP2 [17] |                                                                    |
|                    |      | Set bits [23:20] and [17] to 0x1F.               |                                                                    |

| Table 4-19 | PCIE-GPP2 Lane | Reversal PL | L Selection |
|------------|----------------|-------------|-------------|
|------------|----------------|-------------|-------------|

To enable lane reversal on any of SR5690/5670/5650 PCIE-GPP3a ports, follow the programming sequence outlined below.

| Table 4-20 PCIE-GPP3a Lane Reversal Programming Sequenc |
|---------------------------------------------------------|
|---------------------------------------------------------|

| ASIC Rev                         | Step | Register Settings                              | Function/Comment                                       |
|----------------------------------|------|------------------------------------------------|--------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    |                                                | De-asserts STRAP_BIF_all_valid for<br>PCIE-GPP3a core. |
|                                  |      | Set bit [30] to 0x1.                           |                                                        |
|                                  | 2    | NBCFG:PCIE_NBCFG_REGF[7]=0x1 · NBMISCIND:0x27  | Enables PCIE-GPP3a Port 0 lane reversal if             |
|                                  |      | STRAP_BIF_REVERSE_LANES_A_GPP3a                | respected CMOS option is selected.                     |
|                                  |      | Set bit [7] to 0x1.                            |                                                        |
|                                  | 3    | NBCFG:PCIE_NBCFG_REGF[8]=0x1 · BMISCIND:0x27   | Enables PCIE-GPP3a Port 1 lane reversal if             |
|                                  |      | STRAP_BIF_REVERSE_LANES_B_GPP3a                | respected CMOS option is selected.                     |
|                                  |      | Set bit [8] to 0x1.                            |                                                        |
|                                  | 4    | NBCFG:PCIE_NBCFG_REGF[9]=0x1 · NBMISCIND:0x27  | Enables PCIE-GPP3a Port 2 lane reversal if             |
|                                  |      | STRAP_BIF_REVERSE_LANES_C_GPP3a                | respected CMOS option is selected.                     |
|                                  |      | Set bit [9] to 0x1.                            |                                                        |
|                                  | 5    | NBCFG:PCIE_NBCFG_REGE[30]=0x0 · NBMISCIND:0x26 | Asserts STRAP_BIF_all_valid for PCIE-GPP3a             |
|                                  |      | ~STRAP_BIF_all_valid for PCIE-GPP3a            | core.                                                  |
|                                  |      | Clear bit [30] to 0x0.                         |                                                        |

To enable lane reversal of the SR5690/5670/5650 PCIE-GPP3b port, follow the programming sequence outlined below.

Table 4-21 PCIE-GPP3b Lane Reversal Programming Sequence

| ASIC Rev                         | Step | Register Settings                                | Function/Comment                                       |
|----------------------------------|------|--------------------------------------------------|--------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    |                                                  | De-asserts STRAP_BIF_all_valid for<br>PCIE-GPP3b core. |
|                                  |      | Set bit [21] to 0x1.                             |                                                        |
|                                  | 2    | NBCFG:PCIE_NBCFG_REG15 [25]=0x1 · NBMISCIND:0x2D | Enables PCIE-GPP3b Port 0 lane reversal if             |
|                                  |      | STRAP_BIF_REVERSE_LANES_A_GPP3b                  | respected CMOS option is selected in Single            |
|                                  |      |                                                  | or Dual Configuration                                  |
|                                  |      | Set bit [25] to 0x1.                             |                                                        |
|                                  | 3    | NBCFG:PCIE_NBCFG_REG15 [21]=0x0 · NBMISCIND:0x2D | Asserts STRAP_BIF_all_valid for                        |
|                                  |      | ~STRAP_BIF_all_valid for PCIE-GPP3b              | PCIE-GPP3b core.                                       |
|                                  |      | Clear bit [21] to 0x0.                           |                                                        |

# Step 3: Complete PCIE-GPP1, PCIE-GPP2 and PCIE-GPP3a Ports Configuration Programming:

If PCIE-GPP1 core is configured in dual slot configuration and none of the CMOS options in *Step2*, on page 4-19 are selected, then execute steps 6-8 of the programming sequence described in *Table 4-3 "Programming Sequence for Loading Dual PCIE-GPP1 Core Configuration Topology" on page 4-10;* otherwise, skip this step.

If PCIE-GPP2 core is configured in dual slot configuration, and none of the CMOS options in *Step2*, on page 4-19 are selected, then execute steps 6-8 of the programming sequence described in *Table 4-4 "Programming Sequence for loading dual PCIE-GPP2 Core Configuration Topology" on page 4-11*; otherwise, skip this step.

If "Pin Strap" method is used to configure PCIE-GPP3a core in order to reflect the required customer's system topology configuration, then program Line Director to distribute PCIe lanes across PCIe ports for the selected PCIE-GPP3a core configuration as indicated in *Table 4-22* below.

If "Software Programming Sequence" is used instead, follow steps 4-6 specified in *Table 4-12 "Switching PCIE-GPP3a Configurations" on page 4-15.* 

#### Table 4-22 Programming PCIE-GPP3a Line Director

| ASIC Rev             | Step | Register Settings                                                                                         | Function/Comment                                                                                                                                                      |
|----------------------|------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 | 1    |                                                                                                           | Program PCIE-GPP3a line director, depending on<br>chosen PCIE-GPP3a configuration topology.                                                                           |
| All Revs             |      | <i>"PCIE-GPP3a Line Director Mapping" on page 4-15</i><br>depending on PCIE-GPP3a configuration topology. | Refer to <i>Table 4-13 "PCIE-GPP3a Line Director</i><br><i>Mapping" on page 4-15</i> for mapping of<br>programming value to the PCIE-GPP3a<br>configuration topology. |

#### • Step 4: PCIe Ports Software Compliance (CMOS Option – Disabled by Default):

Characterization of PCIe transmitters requires placing them into compliance state which should not be entered in normal functional operation. The CMOS options below in *Step4.1, on page 4-22* and *Step4.2, on page 4-23* indicate programming sequences to force SR5690/5670/5650 PCIE-GPP1, PCIE-GPP2, PCIE-GPP3a and PCIE-GPP3b ports transmitter into compliance state at Gen 1 or Gen 2 speed respectively.

#### • Step 4.1: PCIe Ports Gen1 Software Compliance (CMOS Option – Disabled by Default):

The PCIe Gen 1 Software Compliance feature is a function of a PCIe port. The following options are available:

- PCIE-GPP1 Port 0 Gen1 Software Compliance (Single/Dual Port Configuration)
- PCIE-GPP1 Port 1 Gen1 Software Compliance (Dual Port Configuration)
- PCIE-GPP2 Port 0 Gen1 Software Compliance (Single/Dual Port Configuration) (Not applicable to SR5650)
- PCIE-GPP2 Port 1 Gen1 Software Compliance (Dual Port Configuration) (Not applicable to SR5670 and SR5650)
- PCIE-GPP3a Port 0 Gen1 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations: 4:2:0:0:0;0, 4:1:1:0:0:0, 2:2:2:0:0:0, 2:2:1:1:0:0, 2:1:1:1:10, 1:1:1:1:1]
- PCIE-GPP3a Port 1 Gen1 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations: 4:2:0:0:00, 4:11:10:0:0, 2:2:2:0:0:0, 2:2:11:10:0, 2:11:11:10, 1:11:11:11]
- PCIE-GPP3a Port 2 Gen1 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations: 4:1:1:0:0:0, 2:2:2:0:00, 2:2:1:1:0:0, 2:1:1:1:10, 1:1:1:1:1]
- PCIE-GPP3a Port 3 Gen1 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations: 2:2:1:1:0:0, 2:1:1:1:1:0, 1:1:1:1:1]
- PCIE-GPP3a Port 4 Gen1 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations:2:1:1:1:0, 1:1:1:1:1:1]

- PCIE-GPP3a Port 5 Gen1 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configuration: 1:1:1:1:1]
- PCIE-GPP3b Port 0 Gen1 Software Compliance (Not applicable to SR5670 and SR5650)

To initiate PCIE Gen1 Software Compliance for each of the options listed above, follow the programming sequence below.

#### Table 4-23 PCle Gen1 Software Compliance Programming Sequence

| ASIC Rev                         | Step | Register Settings      | Function/Comment                                                           |
|----------------------------------|------|------------------------|----------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    | STRAP_FORCE_COMPLIANCE | Forces root-complex transmitter to output compliance pattern at Gen1 rate. |
|                                  |      | Set bit [13] to 0x1.   |                                                                            |

# • Step 4.2: PCIe Ports Gen2 Software Compliance (CMOS Option – Disabled by Default):

The PCIe Gen2 Software Compliance feature is a function of a PCIe port.

The following options are available:

- PCIE-GPP1 Port 0 Gen2 Software Compliance (Single/Dual Port Configuration)
- PCIE-GPP1 Port 1 Gen2 Software Compliance (Dual Port Configuration)
- PCIE-GPP2 Port 0 Gen2 Software Compliance (Single/Dual Port Configuration) (Not applicable to SR5650)
- PCIE-GPP2 Port 1 Gen2 Software Compliance (Dual Port Configuration) (Not applicable to SR5670 and SR5650)
- PCIE-GPP3a Port 0 Gen2 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations: 4:2:0:0:00, 4:1:1:0:0:0, 2:2:2:0:0:0, 2:2:1:1:0:0, 2:1:1:1:1:0, 1:1:1:1:1]
- PCIE-GPP3a Port 1 Gen2 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations: 4:2:0:0:00, 4:1:1:0:00, 2:2:2:0:00, 2:2:1:1:0:0, 2:1:1:1:10, 1:1:1:1:1]
- PCIE-GPP3a Port 2 Gen2 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations: 4:1:1:0:0:0, 2:2:2:0:00, 2:2:1:1:0:0, 2:1:1:1:1:0, 1:1:1:1:1]
- PCIE-GPP3a Port 3 Gen2 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations: 2:2:1:1:0:0, 2:1:1:1:10, 1:1:1:1:1]
- PCIE-GPP3a Port 4 Gen2 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configurations:2:1:1:1:0, 1:1:1:1:1]
- PCIE-GPP3a Port 5 Gen2 Software Compliance [NOTE: This CMOS option is applicable to the following PCIE-GPP3a configuration: 1:1:1:1:1]
- PCIE-GPP3b Port 0 Gen2 Software Compliance (Not applicable to SR5670 and SR5650)

To initiate PCIe Gen2 Software Compliance for each of the options listed above, follow the programming sequence below.

| ASIC Rev     | Step | Register Setting                                                             | Function/Comment                                                                 |
|--------------|------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| SR5690/5670/ | 1    | BIF_NBP:PCIE_LC_SPEED_CNTL[0]=0x1 · PCIEIND_P:0xA4                           | Enables Gen 2 capability of root complex                                         |
| 5650         |      | LC_GEN2_EN_STRAP                                                             | port *                                                                           |
| All Revs     |      |                                                                              |                                                                                  |
|              |      | Set bit [0] to 0x1.                                                          |                                                                                  |
|              | 2    | BIF_NBP:LINK_CNTL2[3:0]=0x2 · pcieCopcieConfigDev*:0x88<br>TARGET_LINK_SPEED | Advertises root complex port * link speed to<br>be Gen2                          |
|              |      | Set bits [3:0] to 0x2.                                                       |                                                                                  |
|              | 3    | BIF_NBP:LINK_CNTL2[4]=0x1 · pcieCopcieConfigDev*:0x88<br>ENTER_COMPLIANCE    | Forces root complex port * transmitter to<br>enter Compliance mode at Gen2 rate. |
|              |      | Set bit [4] to 0x1.                                                          |                                                                                  |

# • Step 5: Programming PCIe Cores PHY for Per Link Channel Characteristics

[NOTE: SR5690/5670/5650 has Transmitter Drive Strength, Half-Swing, Zero De-Emphasis controls implemented on per core basis, rather than per port basis. This should be taken into consideration when defining system configuration topology.]

Each SR5690/5670/5650 PCIe channel is defined by its insertion loss, return loss and aggressor-victim coupling. Understanding and managing the amount of signal attenuation that can be tolerated between the transmitter and receiver of each PCIe link is critical for proper system functionality. There are many factors contributing to the channel loss of a PCIe link, such as the number of PCB layers, shape and length of each microstrip and stripline which define its inductive and capacitive characteristics, PCB characteristics (material, thickness etc.), platform form factor, etc. Loading these parameters into simulation environment on multiple SR5690/5670/5650 platforms has resulted in identifying three major types of channels. For each of these channel types, it is recommended to configure PCIE PHY parameters as indicated below. These categories can be used as starting points for additional fine tuning if necessary for particular platform implementations.

# • Short Channels (less than 3" in length)

Short channels, typically present on compact platforms, should be optimized for maximum power savings and hence SR5690/5670/5650 PCIe ports should have their transmitters operating in half-swing, zero de-emphasis signaling mode. To set SR5690/5670/5650 PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b PCIe transmitters for half-swing, zero-de-emphasis signaling, follow *Step5.1: "Half Swing, Zero De-emphasis (CMOS option)" on page 4-25*.

# • Medium Channels (between 3" and 12" in length)

Medium channels are deployed on most platforms. Transmitters' drive strength of SR5690/5670/5650 PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b PCIe ports should be set to 22mA when operating in either Gen 1 or Gen 2 link speeds. *Step5.2: "Transmitter Drive Strength (CMOS Option)" on page 4-26* should be followed for programming sequence. Root complex should set de-emphasis value of PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3b PCIe transmitters to -3.5dB when operating in either Gen 1 or Gen 2 speeds as well as advertise required -3.5dB de-emphasis setting of endpoint transmitters when operating in Gen 2 speed, to the Gen 2 compliant endpoint device during link training. This PCIe PHY setting is the default setting after a power-on reset or a warm-reset event, so no programming is required.

# • Long Channels (more than 12" in length)

In long channels, transmitter's drive strength of SR5690/5670/5650 PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b PCIe ports should be set to 26mA when operating in either Gen 1 or Gen 2 link speeds. Root complex should set de-emphasis value of the PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b transmitters to -3.5dB when operating in Gen 1 link speed and -6dB when operating in Gen 2 link speed as well as advertise required -6dB de-emphasis setting of endpoint transmitters when operating in Gen 2 speed, to the Gen 2 compliant endpoint device during link training. To configure SR5690/5670/5650 PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-SB, PCIE-GPP3b PCIE PHY transmitter with these parameters, follow *Step5.2: "Transmitter*"

Drive Strength (CMOS Option)" on page 4-26 and Step5.3: "Configured and RC Advertised De-emphasis Strength (CMOS Option)" on page 4-27.

# • Step 5.1: Half Swing, Zero De-emphasis (CMOS option)

The following CMOS options are available:

- Half Swing, Zero De-Emphasis for PCIE-GPP1 Transmitters
- Half Swing, Zero De-Emphasis for PCIE-GPP2 Transmitters
- Half Swing, Zero De-Emphasis for PCIE-SB Transmitters
- Half Swing, Zero De-Emphasis for PCIE-GPP3a Transmitters
- Half Swing, Zero De-Emphasis for PCIE-GPP3b Transmitters

To set SR5690/5670/5650 PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b PCIe transmitters for half-swing, zero-de-emphasis signaling, follow the programming sequence below.

# Table 4-25 Half Swing, Zero De-emphasis for PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b Transmitters

| ASIC Rev                         | Step | Register Settings                                                                                                                               | Function/Comment                                              |
|----------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    | Half-Swing for all PCIE-GPP1 Transmitters:<br>NBCFG:PCIE_NBCFG_REG5[18]=0x0 · NBMISCIND:0x35<br>B_PTX_PWRS_ENB_GPP1                             | Half Swing, Zero De-emphasis for all PCIE-GPP1 Transmitters.  |
|                                  |      | Clear bit [18] to 0x0.                                                                                                                          |                                                               |
|                                  |      | Zero De-Emphases for all PCIE-GPP1 Transmitters:<br>NBCFG:PCIE_NBCFG_REG6[25:24]=0x0 · NBMISCIND:0x36<br>B_PTX_DEEMPH_EN_GPP1                   |                                                               |
| _                                |      | Clear bits [25:24] to 0x0.                                                                                                                      |                                                               |
|                                  | 2    | Half-Swing for all PCIE-GPP2 Transmitters:<br>NBCFG:PCIE_NBCFG_REG5[19]=0x0 · NBMISCIND:0x35<br>B_PTX_PWRS_ENB_GPP2                             | Half Swing, Zero De-emphasis for all PCIE-GPP2 Transmitters.  |
|                                  |      | Clear bit [19] to 0x0.                                                                                                                          |                                                               |
|                                  |      | Zero De-Emphases for all PCIE-GPP1 Transmitters:<br>NBCFG:PCIE_NBCFG_REG6[27:26]=0x0 · NBMISCIND:0x36<br>B_PTX_DEEMPH_EN_GPP2                   |                                                               |
|                                  |      | Clear bits [27:26] to 0x0.                                                                                                                      |                                                               |
| -                                | 3    | Half-Swing for all PCIE-SB Transmitters:<br>NBCFG:StrapsOutputMux_7[27]=0x0 · NBMISCIND:0x67<br>B_PTX_PWRS_ENB_SB<br>Clear bit [27] to 0x0.     | Half Swing, Zero De-emphasis for all PCIE-SB Transmitters.    |
|                                  |      | Zero De-Emphases for all PCIE-SB Transmitters:<br>NBCFG:StrapsOutputMux_8[21:20]=0x0 · NBMISCIND:0x68<br>B_PTX_DEEMPH_EN_sb                     |                                                               |
|                                  |      | Clear bits [21:20] to 0x0.                                                                                                                      |                                                               |
|                                  | 4    | Half-Swing for all PCIE-GPP3a Transmitters:<br>NBCFG:PCIE_NBCFG_REG5[20]=0x0 · NBMISCIND:0x35<br>B_PTX_PWRS_ENB_GPP3a<br>Clear bit [20] to 0x0. | Half Swing, Zero De-emphasis for all PCIE-GPP3a Transmitters. |
|                                  |      | Zero De-Emphases for all PCIE-GPP3a Transmitters:<br>NBCFG:PCIE_NBCFG_REG6[29:28]=0x0 · NBMISCIND:0x36<br>B_PTX_DEEMPH_EN_GPP3a                 |                                                               |
|                                  |      | Clear bits [29:28] to 0x0.                                                                                                                      |                                                               |

| Table 4-25 Half Swing, Zero De-emphasis for PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b |
|------------------------------------------------------------------------------------------------------|
| Transmitters (Continued)                                                                             |

| ASIC Rev     | Step | Register Settings                                                                                                                | Function/Comment                     |
|--------------|------|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| SR5690/5670/ | 5    | Half-Swing for all PCIE-GPP3b Transmitters:                                                                                      | Half Swing, Zero De-emphasis for all |
| 5650         |      | NBCFG:PCIE_NBCFG_REG14[2]=0x0 · NBMISCIND:0x2C                                                                                   | PCIE-GPP3b Transmitters.             |
| All Revs     |      | B_PTX_PWRS_ENB_GPP3b                                                                                                             |                                      |
|              |      | Clear bit [2] to 0x0.                                                                                                            |                                      |
|              |      | Zero De-Emphases for all PCIE-GPP3b Transmitters:<br>NBCFG:PCIE_NBCFG_REG13[11:10]=0x0 · NBMISCIND:0x2B<br>B_PTX_DEEMPH_EN_GPP3b |                                      |
|              |      | Clear bits [11:10] to 0x0.                                                                                                       |                                      |

# • Step 5.2: Transmitter Drive Strength (CMOS Option)

The following CMOS options are available:

- Transmitter Drive Strength for PCIE-GPP1 Core
- Transmitter Drive Strength for PCIE-GPP2 Core
- Transmitter Drive Strength for PCIE-SB Core
- Transmitter Drive Strength for PCIE-GPP3a Core
- Transmitter Drive Strength for PCIE-GPP3b Core

To set transmitter drive strength on SR5690/5670/5650 PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b PCIe ports, follow the programming sequence below.

# Table 4-26 Transmitter Drive Strength for PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b Transmitters

| ASIC Rev     | Step | Register Settings                                          | Function/Comment                                  |
|--------------|------|------------------------------------------------------------|---------------------------------------------------|
| SR5690/5670/ | 1    | Transmitter Drive Strength for all PCIE-GPP1 Transmitters: | Transmitter Drive Strength for all PCIE-GPP1      |
| 5650         |      | NBCFG:PCIE_NBCFG_REG5 [27:26] · NBMISCIND:0x35             | Transmitters in both Gen 1 and Gen 2 link speeds: |
| All Revs     |      | B_P90TX_DRV_STR[1:0] for GPP1                              | Possible CMOS options:                            |
|              |      |                                                            | 0x0: 26mA nominal                                 |
|              |      |                                                            | 0x1: 20mA nominal                                 |
|              |      |                                                            | 0x2: 22mA nominal                                 |
|              |      | Set bits [27:26] according to the CMOS option selected.    | 0x3: 24mA nominal                                 |
|              |      |                                                            | To give better signal integrity for PCIe lanes    |
|              |      |                                                            | program [27:26] according to the CMOS option      |
|              |      |                                                            | selected.                                         |
|              | 2    | Transmitter Drive Strength for all PCIE-GPP2 Transmitters: | Transmitter Drive Strength for all PCIE-GPP2      |
|              |      | NBCFG:PCIE_NBCFG_REG5 [29:28] · NBMISCIND:0x35             | Transmitters in both Gen 1 and Gen 2 link speeds: |
|              |      | B_P90TX_DRV_STR[1:0] for GPP2                              | Possible CMOS options:                            |
|              |      |                                                            | 0x0: 26mA nominal                                 |
|              |      |                                                            | 0x1: 20mA nominal                                 |
|              |      |                                                            | 0x2: 22mA nominal                                 |
|              |      | Set bits [27:26] according to the CMOS option selected.    | 0x3: 24mA nominal                                 |
|              |      |                                                            | To give better signal integrity for PCIe lanes    |
|              |      |                                                            | program [29:28] according to the CMOS option      |
|              |      |                                                            | selected.                                         |

| ASIC Rev     | Step | Register Settings                                        | Function/Comment                               |
|--------------|------|----------------------------------------------------------|------------------------------------------------|
| SR5690/5670/ | 3    | Transmitter Drive Strength for all PCIE-SB Transmitters: | Transmitter Drive Strength for all PCIE-SB     |
| 5650         |      | NBCFG:StrapsOutputMux_8[9:8] · NBMISCIND:0x68            | Transmitters:                                  |
| All Revs     |      | B_P90TX_DRV_STR[1:0] for PCIE-SB                         | Possible CMOS options:                         |
|              |      |                                                          | 0x0: 26mA nominal                              |
|              |      |                                                          | 0x1: 20mA nominal                              |
|              |      |                                                          | 0x2: 22mA nominal                              |
|              |      |                                                          | 0x3: 24mA nominal                              |
|              |      | Set bits [9:8] according to the CMOS option selected.    | To give better signal integrity for PCIE lanes |
|              |      |                                                          | program [9:8] according to the CMOS option     |
|              |      |                                                          | selected.                                      |
| -            | 4    | Transmitter Drive Strength for all PCIE-GPP3a            | Transmitter Drive Strength for all PCIE-GPP3a  |
|              |      | Transmitters:                                            | Transmitters:                                  |
|              |      | NBCFG:PCIE_NBCFG_REG5 [31:30] · NBMISCIND:0x35           | Possible CMOS options:                         |
|              |      | B_P90TX_DRV_STR[1:0] for PCIE-GPP3a                      | 0x0: 26mA nominal                              |
|              |      |                                                          | 0x1: 20mA nominal                              |
|              |      |                                                          | 0x2: 22mA nominal                              |
|              |      |                                                          | 0x3: 24mA nominal                              |
|              |      | Set bits [31:30] according to the CMOS option selected.  | To give better signal integrity for PCIE lanes |
|              |      |                                                          | program [31:30] according to the CMOS option   |
|              |      |                                                          | selected.                                      |
| -            | 5    | Transmitter Drive Strength for all PCIE-GPP3b            | Transmitter Drive Strength for all PCIE-GPP3b  |
|              |      | Transmitters:                                            | Transmitters:                                  |
|              |      | NBCFG:PCIE_NBCFG_REG14[5:4] · NBMISCIND:0x2C             | Possible CMOS options:                         |
|              |      | B_P90TX_DRV_STR[1:0] for PCIE-GPP3b                      | 0x0: 26mA nominal                              |
|              |      |                                                          | 0x1: 20mA nominal                              |
|              |      |                                                          | 0x2: 22mA nominal                              |
|              |      |                                                          | 0x3: 24mA nominal                              |
|              |      | Set bits [5:4] according to the CMOS option selected.    | To give better signal integrity for PCIE lanes |
|              |      |                                                          | program [31:30] according to the CMOS option   |
|              |      |                                                          | selected.                                      |

# Table 4-26 Transmitter Drive Strength for PCIE-GPP1, PCIE-GPP2, PCIE-SB, PCIE-GPP3a and PCIE-GPP3b Transmitters (Continued)

# • Step 5.3: Configured and RC Advertised De-emphasis Strength (CMOS Option)

The following CMOS options are available:

- PCIE-GPP1 Port 0 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2
- PCIE-GPP1 Port 1 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2
- PCIE-GPP2 Port 0 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2 (Not applicable to SR5670)
- PCIE-GPP2 Port 1 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2 (Not applicable to SR5670 and SR5650)
- PCIE-GPP3a Port 0 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2
- PCIE-GPP3a Port 1 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2
- PCIE-GPP3a Port 2 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2
- PCIE-GPP3a Port 3 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2
- PCIE-GPP3a Port 4 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2
- PCIE-GPP3a Port 5 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2

 PCIE-GPP3b Port 0 Configured and Advertised -3.5dB/-6dB De-Emphasis Strength in Gen 2 (Not applicable to SR5670 and SR5650)

To dynamically set SR5690/5670/5650 PCIE-GPP1, PCIE-GPP2, PCIE-GPP3a and PCIE-GPP3b ports transmitters' de-emphasis value to -3.5dB when running in Gen 1 link speed, or to -3.5dB/-6dB when running in Gen 2 link speed, as well as to advertise the required -3.5dB/-6 dB de-emphasis setting of endpoint transmitters when operating in Gen 2 link speed, to the Gen 2 compliant endpoint devices during link training, follow the programming sequence below.

| ASIC Rev     | Step | Register Settings                                                                   | Function/Comment                                 |
|--------------|------|-------------------------------------------------------------------------------------|--------------------------------------------------|
| SR5690/5670/ | 1    | PCIE-GPP1 Port 0:                                                                   | When this register is cleared, hardware will     |
| 5650         |      | NBCFG:PCIE_NBCFG_REG10[0]=0x0 ·NBMISCIND:0x28                                       | change PCIE-PCIE-GPP1 Port 0 transmitters'       |
| All Revs     |      | STRAP_BIF_DE_EMPHASIS_SEL_A_GPP1                                                    | de-emphasis value to -6dB from the default       |
|              |      |                                                                                     | value of -3.5dB when running in Gen 2 link       |
|              |      | Clear bit [0] to 0x0.                                                               | speed, as well as advertise required -6dB        |
|              |      |                                                                                     | de-emphasis setting of endpoint transmitters     |
|              |      |                                                                                     | when operating in Gen 2 link speed, to the Gen   |
|              |      |                                                                                     | 2 compliant endpoint device during link training |
|              |      |                                                                                     | in TS1 Data Rate Identifier (set bit 6) for      |
|              |      |                                                                                     | PCIE-GPP1 Port 0 lanes. The default value is     |
|              |      |                                                                                     | -3.5dB.                                          |
|              |      |                                                                                     | NOTE: In Gen 1 link speed, hardware will         |
|              |      |                                                                                     | ensure that PCIE-GPP1 Port 0 transmitters'       |
|              |      |                                                                                     | de-emphasis value stays set at -3.5dB.           |
|              | 2    | PCIE-GPP1 Port 1:                                                                   | Same comment as above but referring to           |
|              |      | NBCFG:PCIE_NBCFG_REG10[1]=0x0 · NBMISCIND:0x28<br>STRAP_BIF_DE_EMPHASIS_SEL_B_GPP1  | PCIE-PCIE-GPP1 Port 1.                           |
|              |      | Clear bit [1] to 0x0.                                                               |                                                  |
|              | 3    | PCIE-GPP2 Port 0:                                                                   | Same comment as above but referring to           |
|              |      | NBCFG:PCIE_NBCFG_REGF[30]= 0x0 · NBMISCIND:0x27<br>STRAP_BIF_DE_EMPHASIS_SEL_A_GPP2 | PCIE-PCIE-GPP2 Port 0.                           |
|              |      | Clear bit [30] to 0x0.                                                              |                                                  |
|              | 4    | PCIE-GPP2 Port 1:                                                                   | Same comment as above but referring to           |
|              |      | NBCFG:PCIE_NBCFG_REGF[31]= 0x0 · NBMISCIND:0x27<br>STRAP_BIF_DE_EMPHASIS_SEL_B_GPP2 | PCIE-PCIE-GPP2 Port 1.                           |
|              |      | Clear bit [31] to 0x0.                                                              |                                                  |
|              | 5    | PCIE-GPP3a Port 0:                                                                  | Same comment as above but referring to           |
|              |      | NBCFG:PCIE_NBCFG_REG10[2]=0x0 · NBMISCIND:0x28<br>STRAP_BIF_DE_EMPHASIS_SEL_A_GPP3a | PCIE-PCIE-GPP3a Port 0.                          |
|              |      | Clear bit [2] to 0x0                                                                |                                                  |

Table 4-27 Advertised RC Gen 2 De-Emphasis Value for PCIE Ports

| ASIC Rev         | Step | Register Settings                                                                    | Function/Comment                       |
|------------------|------|--------------------------------------------------------------------------------------|----------------------------------------|
| SR5690/5670/     | 6    | PCIE-GPP3a Port 1:                                                                   | Same comment as above but referring to |
| 5650<br>All Revs |      | NBCFG:PCIE_NBCFG_REG10[3]=0x0 · NBMISCIND:0x28<br>STRAP_BIF_DE_EMPHASIS_SEL_B_GPP3a  | PCIE-PCIE-GPP3a Port 1.                |
|                  |      | Clear bit [3] to 0x0                                                                 |                                        |
| Ì                | 7    | PCIE-GPP3a Port 2:                                                                   | Same comment as above but referring to |
|                  |      | NBCFG:PCIE_NBCFG_REG10[4]=0x0 · NBMISCIND:0x28<br>STRAP_BIF_DE_EMPHASIS_SEL_C_GPP3a  | PCIE-PCIE-GPP3a Port 2.                |
|                  |      | Clear bit [4] to 0x0                                                                 |                                        |
| 1                | 8    | PCIE-GPP3a Port 3:                                                                   | Same comment as above but referring to |
|                  |      | NBCFG:PCIE_NBCFG_REG10[5]=0x0 · NBMISCIND:0x28<br>STRAP_BIF_DE_EMPHASIS_SEL_D_GPP3a  | PCIE-PCIE-GPP3a Port 3.                |
|                  |      | Clear bit [5] to 0x0                                                                 |                                        |
|                  | 9    | PCIE-GPP3a Port 4:                                                                   | Same comment as above but referring to |
|                  |      | NBCFG:PCIE_NBCFG_REG10[6]=0x0 · NBMISCIND:0x28<br>STRAP_BIF_DE_EMPHASIS_SEL_E_GPP3aa | PCIE-PCIE-GPP3a Port 4.                |
|                  |      | Clear bit [5] to 0x0                                                                 |                                        |
| İ                | 10   | PCIE-GPP3a Port 5:                                                                   | Same comment as above but referring to |
|                  |      | NBCFG:PCIE_NBCFG_REG10[7]=0x0 · NBMISCIND:0x28<br>STRAP_BIF_DE_EMPHASIS_SEL_F_GPP3a  | PCIE-PCIE-GPP3a Port 5.                |
|                  |      | Clear bit [7] to 0x0.                                                                |                                        |
|                  | 11   | PCIE-GPP3b Port 0:                                                                   | Same comment as above but referring to |
|                  |      | NBCFG:PCIE_NBCFG_REG15[5] =0x0 · NBMISCIND:0x2D<br>STRAP_BIF_DE_EMPHASIS_SEL_A_GPP3b | PCIE-PCIE-GPP3b Port 0.                |
|                  |      | Clear bit [5] to 0x0.                                                                |                                        |

Table 4-27 Advertised RC Gen 2 De-Emphasis Value for PCIE Ports (Continued)

# • Step 6: Program Optimal PCIe Cores PHY Parameters

To set optimal SR5690/5670/5650 PCIe cores PCIe PHY parameters, follow the programming sequence below.

#### Table 4-28 Optimal PCIe Cores PHY Parameters

| ASIC Rev     | Step | Register Settings                                                                                      | Function/Comment                        |
|--------------|------|--------------------------------------------------------------------------------------------------------|-----------------------------------------|
| SR5690/5670/ | 1    | PCIE-GPP1 Phase Filter size:                                                                           | CDR Phase Filter Size for BW control of |
| 5650         |      | NBCFG:PCIE_NBCFG_REG8[7:6]=0x3 · NBMISCIND:0x38                                                        | PCIE-GPP1 core.                         |
| All Revs     |      | B_P90RX_CRFR_ON_GPP1                                                                                   |                                         |
|              |      | Set bits [7:6] to 0x3.                                                                                 |                                         |
|              |      | NBCFG:PCIE_NBCFG_REG4[7]=0x0 · NBMISCIND:0x34<br>B_P90PLL_BACKUP_2_GPP1<br>Clear bit [7] to 0x0.       |                                         |
|              |      | NBCFG:PCIE_NBCFG_REG7[23:20]=0xD · NBMISCIND:0x37<br>B_P90RX_CRPHSIZE_GPP1<br>Set bits [23:20] to 0xD. |                                         |

| ASIC Rev                         | Step | Register Settings                                                                                                                       | Function/Comment                                               |
|----------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 2    | PCIE-GPP2 Phase Filter size:<br>NBCFG:PCIE_NBCFG_REG8[15:14]=0x3 · NBMISCIND:0x38<br>B_P90RX_CRFR_ON_GPP2                               | CDR Phase Filter Size for BW control of<br>PCIE-GPP2 core.     |
|                                  |      | Set bits [7:6] to 0x3.<br>NBCFG:PCIE_NBCFG_REG4[15]=0x0 · NBMISCIND:0x34                                                                |                                                                |
|                                  |      | B_P90PLL_BACKUP_2_GPP2<br>Clear bit [7] to 0x0.                                                                                         |                                                                |
|                                  |      | NBCFG:PCIE_NBCFG_REG7[27:24]=0xD · NBMISCIND:0x37<br>B_P90RX_CRPHSIZE_GPP2<br>Set bits [27:24] to 0xD.                                  |                                                                |
|                                  | 3    | PCIE-SB Phase Filter size:<br>NBCFG:StrapsOutputMux_7[22:21]=0x3 · NBMISCIND:0x67<br>B_P90RX_CRFR_ON_SB<br>Set bits [22:21] to 0x3.     | CDR Phase Filter Size for receiver BW control of PCIE-SB core. |
|                                  |      | NBCFG:StrapsOutputMux_C[10]=0x0 · NBMISCIND:0x6C<br>B_P90PLL_BACKUP_sb<br>Set bits [10] to 0x0.                                         |                                                                |
|                                  |      | NBCFG:StrapsOutputMux_8[19:16]=0xD · NBMISCIND:0x68<br>B_P90RX_CRPHSIZE_sb<br>Set bits [19:16] to 0xD.                                  |                                                                |
|                                  | 4    | PCIE-GPP3a Phase Filter size:<br>NBCFG:PCIE_NBCFG_REG8[23:22]=0x3 · NBMISCIND:0x38<br>B_P90RX_CRFR_ON_GPP3a<br>Set bits [23:22] to 0x3. | CDR Phase Filter Size for BW control of PCIE-GPP3a core.       |
|                                  |      | NBCFG:PCIE_NBCFG_REG4[23]=0x0 · NBMISCIND:0x34<br>B_P90PLL_BACKUP_GPP3a<br>Set bit [23] to 0x0.                                         |                                                                |
|                                  |      | NBCFG:PCIE_NBCFG_REG7[31:28]=0xD · NBMISCIND:0x37<br>B_P90RX_CRPHSIZE_GPP3a<br>Set bits [31:28] to 0xD.                                 |                                                                |
|                                  | 5    | PCIE-GPP3b Phase Filter size:<br>NBCFG:PCIE_NBCFG_REG14[1:0]=0x3 · NBMISCIND:0x2C<br>B_P90RX_CRFR_ON_GPP3b<br>Set bits [1:0] to 0x3.    | CDR Phase Filter Size for BW control of PCIE-GPP3b core.       |
|                                  |      | NBCFG:PCIE_NBCFG_REG14[19]=0x0 · NBMISCIND:0x2C<br>B_P90PLL_BACKUP_GPP3b<br>Set bit [19] to 0x0.                                        |                                                                |
|                                  |      | NBCFG:PCIE_NBCFG_REG13[27:24]=0xD · NBMISCIND:0x2B<br>B_P90RX_CRPHSIZE_GPP3b<br>Set bits [27:24] to 0xD.                                |                                                                |

Table 4-28 Optimal PCIe Cores PHY Parameters (Continued)

| ASIC Rev             | Step | Register Settings                                                                                                                        | Function/Comment                                                                                             |
|----------------------|------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 | 6    | NBCFG:PCIE_NBCFG_REG2[21:20]=0x2 · NBMISCIND:0x32<br>B_PG2PLL_IDLEDET_TH[1:0] for PCIE-GPP1                                              | Sets threshold for Electrical Idle Detector circuit.                                                         |
| All Revs             |      | Set bits [21:20] to 0x2.                                                                                                                 |                                                                                                              |
|                      |      | NBCFG:PCIE_NBCFG_REG2[23:22]= 0x2 · NBMISCIND: 0x32<br>B_PG2PLL_IDLEDET_TH[1:0] for PCIE-GPP2                                            |                                                                                                              |
|                      |      | Set bits [23:22] to 0x2.                                                                                                                 |                                                                                                              |
|                      |      | NBCFG:StrapsOutputMux_7[11:10]=0x2 · NBMISCIND:0x67<br>B_PG2PLL_IDLEDET_TH[1:0] for SB.<br>Set bits [11:20] to 0x2.                      |                                                                                                              |
|                      |      | NBCFG:PCIE_NBCFG_REG2[25:24]=0x2 · NBMISCIND:0x32<br>B_PG2PLL_IDLEDET_TH[1:0] for GPP3a<br>Set bits [25:24] to 0x2.                      |                                                                                                              |
|                      |      | NBCFG:PCIE_NBCFG_REG12[17:16]=0x2 · NBMISCIND:0x2A<br>B_PG2PLL_IDLEDET_TH[17:16] for GPP3b<br>Set bits [17:16] to 0x2.                   |                                                                                                              |
|                      | 7    | NBCFG:StrapsOutputMux_B[30: 29]=0x3 · NBMISCIND:0x6B<br>B_P90RX_INCAL_FORCE_GPP1<br>B_P90RX_INCAL_FORCE_GPP2<br>Set bits [30:29] to 0x3. | Turn off Offset Cancellation circuit.                                                                        |
|                      |      | NBCFG:StrapsOutputMux_B[28]=0x1 · NBMISCIND:0x6B<br>B_P90RX_INCAL_FORCE_sb                                                               |                                                                                                              |
|                      |      | Set bit [28] to 0x1.                                                                                                                     |                                                                                                              |
|                      |      | NBCFG:StrapsOutputMux_B[31]=0x1 · NBMISCIND:0x6B<br>B_P90RX_INCAL_FORCE_GPP3a<br>Set bit [31] to 0x1.                                    |                                                                                                              |
|                      |      | NBCFG:StrapsOutputMux_B[27]=0x1 · NBMISCIND:0x6B                                                                                         |                                                                                                              |
|                      |      | B_P90RX_INCAL_FORCE_GPP3b<br>Set bit [27] to 0x1.                                                                                        |                                                                                                              |
|                      | 8    | NBCFG:PCIE_NBCFG_REG7[12:11]=0x0 · NBMISCIND:0x37<br>B_P90RX_CLKG_EN_GPP1<br>B_P90RX_CLKG_EN_GPP2                                        | Disables Rx Clock gating in CDR circuit.                                                                     |
|                      |      | Clear bits [12:11] to 0x0.                                                                                                               |                                                                                                              |
|                      |      | NBCFG:StrapsOutputMux_7[26]=0x0 · NBMISCIND:0x67<br>B_P90RX_CLKG_EN_SB<br>Clear bit [26] to 0x0.                                         |                                                                                                              |
|                      |      | NBCFG:PCIE_NBCFG_REG7[13]=0x0 · NBMISCIND:0x37<br>B_P90RX_CLKG_EN_GPP3a<br>Clear bit [13] to 0x0.                                        |                                                                                                              |
|                      |      | NBCFG:PCIE_NBCFG_REG14[10]=0x0 · NBMISCIND:0x2C<br>B_P90RX_CLKG_EN_GPP3b<br>Clear bit [10] to 0x0.                                       |                                                                                                              |
|                      | 9    | BIF_NBP:PCIE_LC_CNTL2[28]=0x1·PCIEIND_P:0xB1<br>LC_ENABLE_RX_CR_EN_DEASSERTION                                                           | Enables de-assertion of PG2RX_CR_EN<br>lock clock recovery parameter when lane<br>in electrical idle in L0s. |
|                      |      | Set bit [28] to 0x1.                                                                                                                     | ווי בובטנווטמו ועול ווו בטט.                                                                                 |

 Table 4-28 Optimal PCIe Cores PHY Parameters (Continued)

| ASIC Rev     | Step | Register Settings                                | Function/Comment                    |
|--------------|------|--------------------------------------------------|-------------------------------------|
| SR5690/5670/ | 10   | BIF_NBP:PCIE_LC_CNTL2[19]=0x1 · PCIEIND_P:0xB1   | De-asserts RX_EN in L0s.            |
| 5650         |      | LC_DEASSERT_RX_EN_IN_L0s                         |                                     |
| All Revs     |      |                                                  |                                     |
| _            |      | Set bit [19] to 0x1.                             |                                     |
|              | 11   | NBCFG:PCIE_NBCFG_REGA[15]=0x1 · NBMISCIND:0x22   | Optimum Receiver Equalizer Setting. |
|              |      | B_PG2RX_EQ_GPP1                                  |                                     |
|              |      | Set bit [15] to 0x1.                             |                                     |
|              |      | NBCFG:PCIE_NBCFG_REGA[19]=0x1 · NBMISCIND:0x22   |                                     |
|              |      | B PG2RX EQ GPP2                                  |                                     |
|              |      | Set bit [19] to 0x1.                             |                                     |
|              |      |                                                  |                                     |
|              |      | NBCFG:StrapsOutputMux_C[19]=0x1 · NBMISCIND:0x6C |                                     |
|              |      | B_PG2RX_EQ_sb                                    |                                     |
|              |      | Set bit [19] to 0x1.                             |                                     |
|              |      | NBCFG:PCIE_NBCFG_REGA[23]=0x1 · NBMISCIND:0x22   |                                     |
|              |      | B_PG2RX_EQ_GPP3a                                 |                                     |
|              |      | Set bit [23] to 0x1.                             |                                     |
|              |      |                                                  |                                     |
|              |      | NBCFG:PCIE_NBCFG_REG13[15]=0x1 · NBMISCIND:0x2B  |                                     |
|              |      | B_PG2RX_EQ_GPP3b                                 |                                     |
|              |      | Set bit [15] to 0x1.                             |                                     |

#### Table 4-28 Optimal PCIe Cores PHY Parameters (Continued)

#### • Step 7: System BIOS Compile Flags

SBIOS needs to provide Compile Flags to bypass the training sequence for unsupported PCIe devices. When the training is bypassed, the corresponding port should be powered down as well.

#### • Step 8: Releasing Resets for PCIe Links (CMOS Option - Enabled by Default)

SR5690/5670/5650 has a number of software controllable GPIOs which can be used to control resets to endpoint devices. End-point devices can be connected to SR5690/5670/5650 PCIe ports either via PCIe slot (standard, hot-plug implemented slot etc...) or can be directly mounted on the platform. Each hot-plug implemented slot should have a dedicated software controllable GPIO to control reset to the slot, while non-hot-plug PCIe links can share one or more software controllable GPIOs. The most flexible and hence most desirable platform solution would ideally have each PCIe link reset independently controlled.

Available SR5690/5670/5650 software controllable GPIOs to control resets to PCIe slots are: PCIE\_RESET\_GPIO1, PCIE\_RESET\_GPIO2, PCIE\_RESET\_GPIO4, PCIE\_RESET\_GPIO5. Additional software controllable GPIOs to control resets to PCIe slots can be derived from a number of other places on a platform such as Super IOs, South Bridge etc.

If SR5690/5670/5650 software controllable GPIOs are used to control reset of PCIe links, follow the programming sequence described in Step10.1in order to release reset to the endpoint connected. If software controllable GPIOs to control resets to PCIe links come from other platform resources, then this programming sequence does not apply and the programming sequence to release resets to these links should be obtained from other documentation resources.

• Step 8.1: Programming Sequence for SR5690/5670/5650 Software Controllable GPIOs to Release Resets to PCIe Links

This step describes a generic programming sequence of a dedicated GPIO in order to de-assert reset to a PCIe link.

| Table 4-29 Programming Sequence for SR5690/5670/5650 Software Controllable GPIOs to Release Resets to PCIe |  |
|------------------------------------------------------------------------------------------------------------|--|
| Links                                                                                                      |  |

| ASIC Rev     | Step | Register Settings                            | Function/Comment                                    |
|--------------|------|----------------------------------------------|-----------------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:GPIO_17_20[2:0]=0x7 · NBMISCIND:0x4E   | Set OE, A and OR register bits for PCIE_RESET_GPIO1 |
| 5650         |      | Set bits [2:0] to 0x7.                       | to de-assert the reset for the PCIe link GPIO1 is   |
| All Revs     |      |                                              | connected to.                                       |
|              | 2    | NBCFG:GPIO_17_20[10:8]=0x7 · NBMISCIND:0x4E  | Set OE, A and OR register bits for PCIE_RESET_GPIO2 |
|              |      |                                              | to de-assert the reset for the PCIe link GPIO2 is   |
|              |      | Set bits [2:0] to 0x7.                       | connected to.                                       |
|              | 3    | NBCFG:GPIO_17_20[26:24]=0x7 · NBMISCIND:0x4E | Set OE, A and OR register bits for PCIE_RESET_GPIO4 |
|              |      |                                              | to de-assert the reset for the PCIe link GPIO4 is   |
|              |      | Set bits [26:24] to 0x7.                     | connected to.                                       |
|              | 4    | NBCFG:GPIO_21_24[2:0]=0x7 · NBMISCIND:0x4F   | Set OE, A and OR register bits for PCIE_RESET_GPIO5 |
|              |      |                                              | to de-assert the reset for the PCIe link GPIO5 is   |
|              |      | Set bits [2:0] to 0x7.                       | connected to.                                       |

#### • Step 8.2: Delay Training (CMOS Option - Default 2ms)

Some PCIe devices may require additional initialization time after a reset is de-asserted before they can train the link properly. A typical delay of 2ms is sufficient for most devices. In order to accommodate devices that require additional delay, a CMOS option with a selectable time from 0 to 200 ms, with increments of 1ms, should be implemented. Training to the links should not be released until the timer expires. One timer with a corresponding CMOS option should be used to control both PCI-GPP1 and PCIE-GPP2 links; a separate timer and CMOS option should be used to control the PCIE-GPP3a and PCIE-GPP3b links.

#### • Step 9: Peer-to-Peer DMA Writes among All Devices of PCIE-GPP1 and PCIE-GPP2 Cores (CMOS Option-Enabled by Default)

The SR5690/5670/5650 has dedicated slave paths among all ports of the PCIE GPP1 and PCIE-GPP2 cores to allow maximum efficiency of P2P DMA Writes. For optimal performance, the specialized hardware controlling these paths should be enabled.

#### Table 4-30 Peer-to-Peer DMA Writes among All Devices of PCIE-GPP1 and PCIE-GPP2 Cores

| ASIC Rev     | Step | Register Settings                                      | Function/Comment  |
|--------------|------|--------------------------------------------------------|-------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_GPP1_P2P_CONTROL [8] = 0x0 · NBMISCIND:0x48 | Enables P2P logic |
| 5650         |      | P2PPcieDis                                             |                   |
| All Revs     |      |                                                        |                   |
|              |      | Clear bit [8] to 0x0.                                  |                   |

#### • Step 10: Dynamic Slave CPL Buffer Allocation (CMOS Option – Enabled by Default)

Dynamic Slave Buffer Allocation allows oversubscribing buffer entries allocation for each port of PCIE-GPP1, PCIE-GPP2 and PCIE-GPP3a cores in order to achieve optimal performance.

The following CMOS options are available:

- PCIE-GPP1 Port 0 Dynamic Slave CPL Buffer Allocation
- PCIE-GPP1 Port 1 Dynamic Slave CPL Buffer Allocation
- PCIE-GPP2 Port 0 Dynamic Slave CPL Buffer Allocation (Not applicable to SR5650)
- PCIE-GPP2 Port 1 Dynamic Slave CPL Buffer Allocation (Not applicable to SR5670 and SR5650)
- PCIE-GPP3a Port 0 Dynamic Slave CPL Buffer Allocation
- PCIE-GPP3a Port 1 Dynamic Slave CPL Buffer Allocation
- PCIE-GPP3a Port 2 Dynamic Slave CPL Buffer Allocation

- PCIE-GPP3a Port 3 Dynamic Slave CPL Buffer Allocation
- PCIE-GPP3a Port 4 Dynamic Slave CPL Buffer Allocation
- PCIE-GPP3a Port 5 Dynamic Slave CPL Buffer Allocation

To enable dynamic slave buffer allocation for each port of PCIE-GPP1 or PCIE-GPP2 core, when configured in 8:8 configuration, system BIOS must follow the programming sequence described in the table below.

However, when PCIE-GPP1 or PCIE-GPP2 core is configured in 16:0 configuration, all 128 entries of the slave completion buffer are allocated to a single port of the corresponding core. As this is the default buffer setting after a power-on or a warm reset event, there are no programming requirements, and hence the programming sequence indicated in the table below should be bypassed in this case.

| Table 4-31 Enabling Dynamic Slave CPL | Buffer Allocation Feature for PC | IE-GPP1 and PCIE-GPP2 Ports |
|---------------------------------------|----------------------------------|-----------------------------|
|                                       |                                  |                             |

| ASIC Rev                         | Step | Register Settings                            | Function/Comment                                                                                     |
|----------------------------------|------|----------------------------------------------|------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    | CI_SLV_CPL_STATIC_ALLOC_LIMIT                | Configuration 16:0<br>Skip this sequence (leave the default value for<br>Port 0 of 128 entries)      |
|                                  |      | Set bit[14:8] depending on the configuration | Configuration 8:8:<br>PCIE-GPP1 Port 0: set bit[14:8] =0x60<br>PCIE-GPP1 Port 1: set bit[14:8] =0x60 |
|                                  | 2    |                                              | Enables buffer allocation limits based on<br>programmed register values in Step1.                    |
|                                  |      | Set bit [11] to 0x1                          |                                                                                                      |

To enable dynamic slave buffer allocation for each of PCIE-GPP3a ports, SBIOS must follow the programming sequence described below.

| ASIC Rev     | Step | Register Settings                              | Function/Comment                          |
|--------------|------|------------------------------------------------|-------------------------------------------|
| SR5690/5670/ | 1    | BIF_NBP:PCIEP_PORT_CNTL[14:8] · PCIEIND_P:0x10 | Configuration 4:2:0:0:0:0                 |
| 5650         |      | CI_SLV_CPL_STATIC_ALLOC_LIMIT                  | PCIE-GPP3a Port0: set bit[14:8] =0x38     |
| All Revs     |      |                                                | PCIE-GPP3a Port1: set bit[14:8] =0x1C     |
|              |      | Set bit[14:8] depending on the configuration   |                                           |
|              |      | (the default is 0, meaning 128 slots)          | Configuration 4:1:1:0:0:0                 |
|              |      |                                                | PCIE-GPP3a Port0: set bit[14:8] =0x38     |
|              |      |                                                | PCIE-GPP3a Port1: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port2: set bit[14:8] =0xE      |
|              |      |                                                | Configuration 2:2:2:0:0:0                 |
|              |      |                                                | PCIE-GPP3a Port0: set bit[14:8] =0x1C     |
|              |      |                                                | PCIE-GPP3a Port1: set bit[14:8] =0x1C     |
|              |      |                                                | PCIE-GPP3a Port2: set bit[14:8] =0x1C     |
|              |      |                                                | Configuration 2:2:1:1:0:0                 |
|              |      |                                                | PCIE-GPP3a Port0: set bit[14:8] =0x1C     |
|              |      |                                                | PCIE-GPP3a Port1: set bit[14:8] =0x1C     |
|              |      |                                                | PCIE-GPP3a Port2: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port3: set bit[14:8] =0xE      |
|              |      |                                                | Configuration 2:1:1:1:0                   |
|              |      |                                                | PCIE-GPP3a Port0: set bit[14:8] =0x1C     |
|              |      |                                                | PCIE-GPP3a Port1: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port2: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port3: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port4: set bit[14:8] =0xE      |
|              |      |                                                | Configuration 1:1:1:1:1                   |
|              |      |                                                | PCIE-GPP3a Port0: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port1: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port2: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port3: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port4: set bit[14:8] =0xE      |
|              |      |                                                | PCIE-GPP3a Port5: set bit[14:8] =0xE      |
|              | 2    | BIF_NB:PCIE_CI_CNTL[11]=0x1 · PCIEIND:0x20     | Enables buffer allocation limits based on |
|              |      | CI_SLV_CPL_ALLOC_MODE<br>Set bit [11] to 0x1.  | programmed register values in Step1.      |

# • Step 11: PCIe Link Bandwidth Notification Capability Enabled (CMOS Option - Enabled by Default)

| ASIC Rev             | Step | Register Settings                                                                           | Function/Comment                                                                       |
|----------------------|------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 | 1    | NBCFG:PCIE_NBCFG_REGD[24]=0x1 · NBMISCIND:0x25<br>STRAP_BIF_LINK_BW_NOTIFICATION_CAP_EN for | If the link BW changes in order to attempt to<br>correct unreliable link operation,    |
| All Revs             |      | PCIE-GPP1                                                                                   | LINK_BW_MANAGEMENT_STATUS will get set                                                 |
|                      |      |                                                                                             | once the feature is enabled for all ports of                                           |
|                      |      |                                                                                             | PCIE-GPP1 core.                                                                        |
|                      |      |                                                                                             | If the link BW changes intentionally,<br>LINK AUTONOMOUS BW STATUS will get set        |
|                      |      |                                                                                             | once feature is enabled for all ports of                                               |
|                      |      | Set bit [24] to 0x1.                                                                        | PCIE-GPP1 core.                                                                        |
|                      | 2    | NBCFG:PCIE_NBCFG_REGD[25]=0x1 · NBMISCIND:0x25                                              | IIf the link BW changes due to security reasons,                                       |
|                      |      | STRAP_BIF_LINK_BW_NOTIFICATION_CAP_EN for                                                   | LINK_BW_MANAGEMENT_STATUS will get set                                                 |
|                      |      | PCIE-GPP2                                                                                   | once the feature is enabled for all ports of                                           |
|                      |      |                                                                                             | PCIE-GPP2 core.<br>If the link BW changes intentionally,                               |
|                      |      |                                                                                             | LINK_AUTONOMOUS_BW_STATUS will get set                                                 |
|                      |      |                                                                                             | once feature is enabled for all ports of                                               |
|                      |      | Set bit [25] to 0x1.                                                                        | PCIE-GPP2 core.                                                                        |
|                      | 3    |                                                                                             | If the link BW changes in order to attempt to                                          |
|                      |      | STRAP_BIF_LINK_BW_NOTIFICATION_CAP_EN for                                                   | correct unreliable link operation,                                                     |
|                      |      | PCIE-GPP3a                                                                                  | LINK_BW_MANAGEMENT_STATUS will get set<br>once the feature is enabled for all ports of |
|                      |      |                                                                                             | PCIE-GPP3a core.                                                                       |
|                      |      |                                                                                             | If the link BW changes intentionally,                                                  |
|                      |      |                                                                                             | LINK_AUTONOMOUS_BW_STATUS will get set                                                 |
|                      |      |                                                                                             | once feature is enabled for all ports of                                               |
|                      |      | Set bit [26] to 0x1.                                                                        | PCIE-GPP3a core.                                                                       |
|                      | 4    | NBCFG:StrapsOutputMux_7[14]=0x1 · NBMISCIND:0x67                                            | If the link BW changes in order to attempt to                                          |
|                      |      | STRAP_BIF_LINK_BW_NOTIFICATION_CAP_EN for<br>PCIE-SB                                        | correct unreliable link operation,<br>LINK BW MANAGEMENT STATUS will get set           |
|                      |      |                                                                                             | once the feature is enabled for Port0 of PCIE-SB                                       |
|                      |      |                                                                                             | core.                                                                                  |
|                      |      |                                                                                             | If the link BW changes intentionally,                                                  |
|                      |      |                                                                                             | LINK_AUTONOMOUS_BW_STATUS will get set                                                 |
|                      |      | Cat hit [14] to 0v1                                                                         | once feature is enabled for Port 0 of                                                  |
|                      | 5    | Set bit [14] to 0x1.<br>NBCFG:PCIE_NBCFG_REG16[1]=0x1 · NBMISCIND:0x2E                      | PCIE-GPP3a core.<br>If the link BW changes in order to attempt to                      |
|                      | 5    | STRAP_BIF_LINK_BW_NOTIFICATION_CAP_EN for                                                   | correct unreliable link operation,                                                     |
|                      |      | PCIE-GPP3b                                                                                  | LINK_BW_MANAGEMENT_STATUS will get set                                                 |
|                      |      |                                                                                             | once the feature is enabled for Port 0 of                                              |
|                      |      |                                                                                             | PCIE-GPP3b core.                                                                       |
|                      |      |                                                                                             | If the link BW changes intentionally,                                                  |
|                      |      |                                                                                             | LINK_AUTONOMOUS_BW_STATUS will get set<br>once feature is enabled for Port 0 of        |
|                      |      | Set bit [1] to 0x1                                                                          | PCIE-GPP3b core.                                                                       |
|                      |      |                                                                                             |                                                                                        |

Table 4-33 Enabling Link Bandwidth Notification Capability for PCle Port(s)

# • Step 12: Static Device Mapping (CMOS Option - Enabled by Default)

This feature preserves device numbers allocated to each of the PCIE-GPP3a PCIe ports after enumeration, so that the operating system will not request driver re-installation of the same device when the topology changes due to addition or removal of new hardware. Since the desired device mapping may differ from the power-on device mapping, SR5690/5670/5650 supports the ability to redefine device mapping of each of the PCIE-GPP3a PCIe ports.

The Static Device Mapping of the PCIE-GPP3a ports in all configurations is shown in the table below.

 Table 4-34
 PCIE-GPP3a Ports
 Static
 Device
 Numbers

| ASIC Rev     | PCIE-GPP3a Configuration | PCIE-GPP3a Port | Static Device Number |
|--------------|--------------------------|-----------------|----------------------|
| SR5690/5670/ | 1:1:1:1:1                | Port 0          | Dev4                 |
| 5650         |                          | Port 1          | Dev5                 |
| All Revs     |                          | Port 2          | Dev6                 |
|              |                          | Port 3          | Dev7                 |
|              |                          | Port 4          | Dev9                 |
|              |                          | Port 5          | Dev10                |
|              | 4:2:0:0:0:0              | Port 0          | Dev4                 |
|              |                          | Port 1          | Dev9                 |
|              | 4:1:1:0:0:0              | Port 0          | Dev4                 |
|              |                          | Port 1          | Dev9                 |
|              |                          | Port 2          | Dev10                |
|              | 2:2:2:0:0:0              | Port 0          | Dev4                 |
|              |                          | Port 1          | Dev6                 |
|              |                          | Port 2          | Dev9                 |
|              | 2:2:1:1:0:0              | Port 0          | Dev4                 |
|              |                          | Port 1          | Dev6                 |
|              |                          | Port 2          | Dev9                 |
|              |                          | Port 3          | Dev10                |
| F            | 2:1:1:1:0                | Port 0          | Dev4                 |
|              |                          | Port 1          | Dev6                 |
|              |                          | Port 2          | Dev7                 |
|              |                          | Port 3          | Dev9                 |
|              |                          | Port 4          | Dev10                |

To enable the Static Device Mapping feature, follow the step in the table below:

Table 4-35 Enabling Static Device Mapping Feature

| ASIC Rev                         | Step | Register Settings | Function/Comment                                                                                                                                |
|----------------------------------|------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    |                   | Enables static device remapping so that the<br>mapping between PCIE slot and the device<br>number stays the same in different<br>configurations |

# • Step 13: PCIe Cores Common Initialization

To configure all PCIe cores and associated ports with optimal settings, system BIOS must follow the programming steps described below.

| ASIC Rev             | Step | Register Settings                                        | Function/Comment                                                                |
|----------------------|------|----------------------------------------------------------|---------------------------------------------------------------------------------|
| SR5690/5670/         | 1    | BIF_NBP:PCIE_DEVICE_CNTL2[3:0]=0x6 · pcieConfigDev*:0x80 | Sets RCB completion timeout to be 200ms.                                        |
| 5650                 |      | CPL_TIMEOUT_VALUE                                        |                                                                                 |
| All Revs             |      |                                                          |                                                                                 |
|                      |      | Set bits [3:0] to 0x6.                                   |                                                                                 |
| Ī                    | 2    | BIF_NBP:PCIE_RX_CNTL[19]= 0x1 · PCIEIND_P:0x70           | RCB completion timeout on link down to                                          |
|                      |      | RX_RCB_CPL_TIMEOUT_MODE                                  | shorten enumeration time.                                                       |
|                      |      |                                                          |                                                                                 |
| -                    |      | Set bit [19] to 0x1.                                     |                                                                                 |
|                      | 3    | BIF_NB:PCIE_CI_CNTL[8]= 0x0 · PCIEIND:0x20               | Enable slave ordering rules.                                                    |
|                      |      | CI_SLV_ORDERING_DIS                                      |                                                                                 |
|                      |      |                                                          |                                                                                 |
|                      |      | Clear bit [8] to 0x0.                                    |                                                                                 |
|                      | 4    | BIF_NB:PCIE_CNTL[12:10]=0x4 · PCIEIND:0x10               | Sets DMA payload size to 64 bytes. Should                                       |
|                      |      | RX_SB_ADJ_PAYLOAD_SIZE                                   | be set before any DMA is enabled                                                |
|                      |      | Cat hits [12:10] to 0:4                                  |                                                                                 |
| DEGODIECZO           | F    | Set bits [12:10] to 0x4.                                 |                                                                                 |
| SR5690/5670/<br>5650 | 5    | BIF_NB:PCIE_HW_DEBUG[0]=0x1 · PCIEIND:0x2<br>HW_00_DEBUG | Set REGS_DLP_IGNORE_IN_L1_EN to<br>ignore DLLPs during L1 so that Tx Clk can be |
| All Revs             |      |                                                          | turned off.                                                                     |
| All Nevs             |      | Set bit [0] to 0x1.                                      |                                                                                 |
| -                    | 6    | BIF_NBP:PCIEP_HW_DEBUG[15]=0x1 · PCIEIND_P:0x2           | Set REGS_LC_ALLOW_TX_L1_CONTROL                                                 |
|                      | 0    | HW_15_DEBUG                                              | to allow TX to prevent LC from going to L1                                      |
|                      |      | 11W_13_BEB00                                             | when there are outstanding completions.                                         |
|                      |      | Set bit [15] to 0x 1.                                    | when there are outstanding completions.                                         |
| -                    | 7    | BIF_NBP:PCIE_LC_TRAINING_CNTL[11]=0x1                    | Set                                                                             |
|                      | ,    | PCIEIND_P:0xA1_LC_DONT_GO_TO_L0S_IF_L1_ARMED             | REGS_LC_DONT_GO_TO_L0S_IF_L1_AR                                                 |
|                      |      |                                                          | MED to prevent lc to go to from L0 to                                           |
|                      |      | Set bit [11] to 0x1.                                     | Rcv_L0s if L1 is armed.                                                         |
| -                    | 8    | NBCFG:PCIE_NBCFG_REGA[27]=0x1 · NBMISCIND:0x22           | CMGOOD_OVERRIDE for all five PCIe                                               |
|                      |      |                                                          | cores.                                                                          |
|                      |      | Set bit [27] to 0x1.                                     |                                                                                 |
| -                    | 9    | BIF_NBP:PCIE_LC_CNTL2[20]=0x1 · PCIEIND_P:0xB1           | Prevents Electrical Idle from causing a                                         |
|                      |      | LC_BLOCK_EL_IDLE_IN_L0                                   | transition from Rcv_L0 to Rcv_L0s.                                              |
|                      |      |                                                          |                                                                                 |
|                      |      | Set bit [20] to 0x1.                                     |                                                                                 |
| F                    | 10   | BIF_NBP:PCIE_LC_TRAINING_CNTL[11]=0x1 ·                  | Prevents the LTSSM from going to Rcv_L0s it                                     |
|                      |      | PCIEIND_P:0xA1                                           | it has already acknowledged a request to go                                     |
|                      |      | LC_DONT_GO_TO_L0S_IF_L1_ARMED                            | to L1 but it has not transitioned there yet.                                    |
|                      |      |                                                          |                                                                                 |
|                      |      | Set bit [11] to 0x1.                                     |                                                                                 |
|                      | 11   | BIF_NBP:PCIE_LC_N_FTS_CNTL[9]=0x1 · PCIEIND_P:0xA3       | Transmits FTS before Recovery.                                                  |
|                      |      | LC_XMIT_FTS_BEFORE_RECOVERY                              |                                                                                 |
|                      |      |                                                          |                                                                                 |
|                      |      | Set bit [9] to 0x1.                                      |                                                                                 |
| Γ                    | 12   | BIF_NB:PCIE_CNTL2[10:0]= 0x109 · PCIEIND:0x1C            | Sets TX arbitration algorithm to round robin                                    |
|                      |      | TX_ARB_ROUND_ROBIN_EN set to 0x1.                        | for PCIE-GPP1, PCIE-GPP2, PCIE-GPP3a                                            |
|                      |      | TX_ARB_SLV_LIMIT set to 0x4.                             | and PCIE-GPP3b cores only.                                                      |
| ļ                    |      | TX_ARB_MST_LIMIT set to 0x4.                             |                                                                                 |
|                      | 13   | BIF_NBP:PCIE_LC_CNTL[7:4]=0x3 · PCIEIND_P:0xA0           | Sets number of TX Clocks to drain TX Pipe to                                    |
|                      |      | LC_16X_CLEAR_TX_PIPE                                     | 0x3.                                                                            |
|                      |      | 0-1-1-1-1-0-0                                            |                                                                                 |
|                      |      | Set bits [7:4] to 0x3.                                   |                                                                                 |

| Table 4-36 | PCIe Cores | Common | Initialization |
|------------|------------|--------|----------------|
|------------|------------|--------|----------------|

| ASIC Rev     | Step | Register Settings                                       | Function/Comment                                  |
|--------------|------|---------------------------------------------------------|---------------------------------------------------|
| SR5690/5670/ | 14   | BIF_NB:PCIE_P_CNTL[15:14]=0x2 · PCIEIND:0x40            | Lets PI use Electrical Idle from PHY when         |
| 5650         |      | P_ELEC_IDLE_MODE                                        | turning off PLL in L1 at Gen 2 speed instead      |
| All Revs     |      |                                                         | of Inferred Electrical Idle                       |
|              |      | Set bits [15:14] to 0x2.                                | NOTE: LC still uses Inferred Electrical Idle.     |
|              | 15   | BIF_NB:PCIE_STRAP_PI[25]=0x1 · PCIEIND:0xC2             | Turn on rx_fronten_en for all active lanes        |
|              |      | STRAP_PHY_RX_INCAL_FORCE                                | upon exit from Electrical Idle, rather than       |
|              |      |                                                         | being tied to PLL_PDNB.                           |
|              |      | Set bit [25] to 0x1.                                    |                                                   |
|              | 16   | BIF_NBP:PCIEP_STRAP_MISC[3:0]=0xC · PCIEIND_P:0xC1      | Advertises TX L0s and L1 exit latency.            |
|              |      | STRAP_EXIT_LATENCY                                      | TX L0s exit latency to be 100b: 512ns to less     |
|              |      | Cat hits [2:0] to 0:0                                   | than 1us;                                         |
|              |      | Set bits [3:0] to 0xC.                                  | L1 exit latency to be 011b: 4us to less than 8us. |
|              |      | For Hot-Plug Slots:                                     | ous.                                              |
|              |      | BIF_NBP:PCIEP_STRAP_MISC[3:0]=0xF · PCIEIND_P:0xC1      | For Hot-Plug Slots:                               |
|              |      | STRAP_EXIT_LATENCY                                      | Advertise TX L0s and L1 exit latency.             |
|              |      |                                                         | TX L0s exit latency to be 110b: 2us to 4us.       |
|              |      | Set bits [3:0] to 0xF.                                  | L1 exit latency to be 111b: more than 64us.       |
|              | 17   | For PCIE-SB port only:                                  | Always ACK an ASPM L1 entry DLLP to               |
|              |      | BIF_NBP:PCIE_LC_CNTL[23]=0x1 · PCIEIND_P:0xA0           | workaround credit control issue on PM_NAK         |
|              |      | LC_L1_IMMEDIATE_ACK                                     | message of SB700 and SB800.                       |
|              |      |                                                         | _                                                 |
|              |      | Set bit [23] to 0x1.                                    |                                                   |
|              | 18   | For PCIE-SB port only:                                  | To allow advertising Gen 2 capabilities to        |
|              |      | BIF_NB:PCIE_STRAP_MISC2[1]=0x1 · PCIEIND:0xC1           | Southbridge.                                      |
|              |      | STRAP_GEN2_COMPLIANCE                                   |                                                   |
|              |      | Set bit [1] to 0x1.                                     |                                                   |
|              | 19   | BIF_NBP:LINK_CNTL2[3:0]=0x2 · pcieCopcieConfigDev*:0x88 | CMOS Option (Gen 2 AUTO-Part 1 - Enabled          |
|              |      | TARGET_LINK_SPEED                                       | by Default)                                       |
|              |      | Set bits [3:0] to 0x2.                                  |                                                   |
|              |      |                                                         |                                                   |
|              |      | BIF_NBP:PCIE_LC_SPEED_CNTL[0]=0x1 · PCIEIND_P:0xA4      |                                                   |
|              |      | LC_GEN2_EN_STRAP                                        |                                                   |
|              |      | Set bit [0] to 0x1.                                     |                                                   |
|              |      | BIF_NBP:PCIE_LC_SPEED_CNTL [29]=0x1 · PCIEIND_P:0xA4    |                                                   |
|              |      | LC_MULT_UPSTREAM_AUTO_SPD_CHNG_EN                       |                                                   |
|              |      | Set bit [29] to 0x1.                                    |                                                   |
|              | 20   | BIF_NBP:LINK_CNTL2[3:0]=0x2 · pcieCopcieConfigDev*:0x88 | CMOS Option (RC Advertised Gen 2-Part1 -          |
|              |      | TARGET_LINK_SPEED                                       | Disabled by Default)                              |
|              |      | Set bits[3:0] to 0x2                                    |                                                   |
|              |      |                                                         |                                                   |
|              |      | BIF_NBP:PCIE_LC_SPEED_CNTL[0]=0x1 · PCIEIND_P:0xA4      |                                                   |
|              |      | LC_GEN2_EN_STRAP                                        |                                                   |
|              |      | Set bit [0] to 0x1.                                     |                                                   |

| Table 4-36 | PCIe Cores | Common | Initialization | (Continued) |
|------------|------------|--------|----------------|-------------|
|------------|------------|--------|----------------|-------------|

| ASIC Rev     | Step | Register Settings                                           | Function/Comment                               |
|--------------|------|-------------------------------------------------------------|------------------------------------------------|
| SR5690/5670/ | 21   | Legacy Hot Plug - CMOS option (disabled by default)         |                                                |
| 5650         |      | NOTE: This feature can be enabled only for Hot-Plug slots i | mplemented on SR5690 platform.                 |
| All Revs     |      | BIF_NBP:PCIE_CAP[8]=0x1 · pcieConfigDev*:0x5a               | This bit when set indicates that the PCIe Link |
|              |      | SLOT_IMPLEMENTED                                            | associated with this port is connected to a    |
|              |      |                                                             | slot.                                          |
|              |      | Set bit [8] to 0x1.                                         |                                                |
|              |      | BIF_NBP:PCIE_SLOT_CAP[6]=0x1 · pcieConfigDev*:0x6c          | This bit when set indicates that this slot is  |
|              |      | HOTPLUG_CAPABLE                                             | capable of supporting Hot-Plug operations.     |
|              |      |                                                             |                                                |
|              |      | Set bit [6] to 0x1.                                         |                                                |
|              |      | BIF_NBP:PCIE_TX_CNTL[19]=0x0 · PCIEIND_P:0x20               | Enables flushing of TLPs when Data Link is     |
|              |      | TX_FLUSH_TLP_DIS                                            | down.                                          |
|              |      |                                                             |                                                |
|              |      | Clear bit [19] to 0x0.                                      |                                                |
| SR5690/5670/ | 22   | Native PCIe Mode - CMOS option (enabled by default)         |                                                |
| 5650         |      | BIF_NBP:PCIEP_PORT_CNTL[3]=0x1 · PCIEIND_P:0x10             | Enable native PME.                             |
| All Revs     |      | NATIVE_PME_EN                                               |                                                |
|              |      |                                                             |                                                |
|              |      | Set bit [3] to 0x1                                          |                                                |
|              |      | BIF_NBP:PCIE_CAP[8]=0x1 · pcieConfigDev*:0x5a               | This bit when set indicates that the PCIe Link |
|              |      | SLOT_IMPLEMENTED                                            | associated with this port is connected to a    |
|              |      |                                                             | slot.                                          |
|              |      | Set bit [8] to 0x1                                          |                                                |
|              |      | BIF_NBP:PCIE_SLOT_CAP[6] = 0x1 · pcieConfigDev*:0x6c        | This bit when set indicates that this slot is  |
|              |      | HOTPLUG_CAPABLE                                             | capable of supporting Hot-Plug operations.     |
|              |      |                                                             |                                                |
|              |      | Set bit [6] to 0x1                                          |                                                |
|              |      | BIF_NBP:PCIE_TX_CNTL[19] = 0x0 · PCIEIND_P:0x20             | Enable flushing TLPs when Data Link is         |
|              |      | TX_FLUSH_TLP_DIS                                            | down.                                          |
|              |      |                                                             |                                                |
|              |      | Clear bit [19] to 0x0                                       |                                                |
| SR5690/5670/ | 23   | BIF_NBP:PCIE_RX_CNTL · PCIEIND_P:0x70                       | Do not ignore receiver errors for AER.         |
| 5650         | 25   | Clear the following bits to 0:                              |                                                |
| All Revs     |      | RX_IGNORE_IO_ERR                                            |                                                |
|              |      | RX_IGNORE_BE_ERR                                            |                                                |
|              |      | RX_IGNORE_MSG_ERR                                           |                                                |
|              |      | RX_IGNORE_CRC_ERR                                           |                                                |
|              |      | RX_IGNORE_CFG_ERR                                           |                                                |
|              |      | RX_IGNORE_CPL_ERR                                           |                                                |
|              |      | RX_IGNORE_EP_ERR                                            |                                                |
|              |      | RX_IGNORE_LEN_MISMATCH_ERR                                  |                                                |
|              |      | RX_IGNORE_MAX_PAYLOAD_ERR                                   |                                                |
|              |      | RX_IGNORE_TC_ERR                                            |                                                |

#### Table 4-36 PCIe Cores Common Initialization (Continued)

#### • Step 14: Server Class Hot Plug Feature

#### [NOTE: This feature is not supported on SR5670 and SR5650.]

SR5690 PCIE-GPP1 (Ports 0 and 1), PCIE-GPP2 (Ports 0 and 1), PCIE-GPP3a (Ports 0, 1 and 2) and PCIE-GPP3b Port 0 can support full PCIe defined hot-plug through the use of up to four  $I^2C$  GPIO expanders (PCA9539). Each expander supports up to two hot-plug slots.

# • Step 14.1: Advertising Hot Plug Capabilities

Based on an SR5690 server system configuration, and hence the selection of which of the above PCIe ports are configured with server-class hot-pug support in a particular system implementation, SBIOS is responsible for advertising hot-plug capabilities in each of the device-specific configuration spaces by following the steps described in the table below.

| ASIC Rev | Step | Register Settings                                                                        | Function/Comment                                                          |
|----------|------|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| SR5690   | 1    | BIF_NBP:PCIE_CAP[8]=0x1 · pcieConfigDev*:0x5a                                            | This bit when set indicates that the                                      |
| All Revs |      | SLOT_IMPLEMENTED                                                                         | PCI Express Link associated with<br>this Port is connected to a slot      |
|          |      | Set bit [8] to 0x1.                                                                      |                                                                           |
|          | 2    | BIF_NBP:PCIE_SLOT_CAP[0]=0x1 · pcieConfigDev*:0x6c                                       | This bit when set indicates that an                                       |
|          |      | ATTN_BUTTON_PRESENT                                                                      | Attention Button is implemented on                                        |
|          |      | 0-4-1-1-101-40-4                                                                         | the chassis for this slot.                                                |
|          |      | Set bit [0] to 0x1.                                                                      |                                                                           |
|          | 3    | BIF_NBP:PCIE_SLOT_CAP[1]=0x1 · pcieConfigDev*:0x6c<br>PWR CONTROLLER PRESENT             | This bit when set indicates that a<br>Power Controller is implemented for |
|          |      |                                                                                          | this slot.                                                                |
|          |      | Set bit [1] to 0x1.                                                                      |                                                                           |
|          | 3    | BIF_NBP:PCIE_SLOT_CAP[3]=0x1 · pcieConfigDev*:0x6c                                       | This bit when set indicates that an                                       |
|          |      | ATTN_INDICATOR_PRESENT                                                                   | Attention Indicator is implemented                                        |
|          |      | Set bit [3] to 0x1.                                                                      | on the chassis for this slot.                                             |
|          | 4    | BIF_NBP:PCIE_SLOT_CAP[4]=0x1 · pcieConfigDev*:0x6c                                       | This bit when set indicates that a                                        |
|          | •    | PWR_INDICATOR_PRESENT                                                                    | Power Indicator is implemented on                                         |
|          |      |                                                                                          | the chassis for this slot.                                                |
|          |      | Set bit [4] to 0x1.                                                                      |                                                                           |
|          | 5    | BIF_NBP:PCIE_SLOT_CAP[6]=0x1 · pcieConfigDev*:0x6c                                       | This bit when set indicates that this                                     |
|          |      | HOTPLUG_CAPABLE                                                                          | slot is capable of supporting<br>Hot-Plug operations.                     |
|          |      | Set bit [6] to 0x1.                                                                      |                                                                           |
|          | 6    | BIF_NBP:PCIE_SLOT_CAP[17]=0x1 · pcieConfigDev*:0x6c                                      | This bit when set indicates that an                                       |
|          |      | ELECTROMECH_INTERLOCK_PRESENT                                                            | Electromechanical Interlock is                                            |
|          |      | Set bit [17] to 0x1.                                                                     | implemented on the chassis for this slot.                                 |
|          | 7    | BIF_NBP:PCIE_SLOT_CAP[18]=0x0 · pcieConfigDev*:0x6c                                      |                                                                           |
|          | 1    | NO_COMMAND_COMPLETED_SUPPORTED                                                           | This bit when cleared indicates that this slot generates software         |
|          |      |                                                                                          | notification when an issued                                               |
|          |      |                                                                                          | command is completed by the                                               |
|          |      | Clear bit [18] to 0x0.                                                                   | Hot-Plug Controller.                                                      |
|          | 8    | BIF_NBP:PCIE_SLOT_CAP[31:19] · pcieConfigDev*:0x6c                                       | This hardware initialized field                                           |
|          |      | PHYSICAL_SLOT_NUM assigned in a customer-specific manner, algorithm to be defined by the | indicates the physical slot number attached to this Port.                 |
|          |      | customer.                                                                                |                                                                           |
|          | 9    | BIF_NBP:PCIEP_PORT_CNTL[4]=0x1 · PCIEIND_P:0x10                                          |                                                                           |
|          |      | PWR_FAULT_EN                                                                             |                                                                           |
|          |      | Set bit [4] to 0x1.                                                                      |                                                                           |
|          |      |                                                                                          |                                                                           |

# Table 4-37 Advertising Hot Plug Capabilities

# • Step 14.2: Firmware Upload

• Step 14.2.1: Register Initialization for Firmware Upload

In this step, SBIOS is responsible for initializing two groups of registers to help firmware complete successful initialization of PCA modules: Initializing Hot-Plug Descriptors and Clearing Slot Status Register.

• Step 14.2.1.1: Initializing Hot Plug Descriptors

SBIOS is responsible for reflecting the system hot-plug topology by updating PCIE\_HOTPLUG\_CNTL0 and PCIE\_HOTPLUG\_CNTL1 registers by following the steps below:

| ASIC Rev | Step | Register Settings                                                                | Function/Comment                                              |
|----------|------|----------------------------------------------------------------------------------|---------------------------------------------------------------|
| SR5690   | 1    | CLKCFG.HOTPLUG_SPARE_0[3:0] · clkconfig:0xf0                                     | PCIE-GPP1 Port 0 descriptor bits are                          |
| All Revs |      |                                                                                  | located in bits [3:0].                                        |
|          |      | CLKCFG.HOTPLUG_SPARE_0[0] = Byte Mapping                                         |                                                               |
|          |      | Clear bit [0] to 0x0 if PCIE-GPP1 Port 0 is mapped to Port 0 of a PCA<br>Module. |                                                               |
|          |      | Set bit [0] to 0x1 if PCIE-GPP1 Port 0 mapped to Port 1 of PCA9539               |                                                               |
|          |      | devices Module.                                                                  |                                                               |
|          |      | CLKCFG.HOTPLUG_SPARE_0[2:1]=DeviceMapping                                        |                                                               |
|          |      | Write PCA9539 DeviceID that PCIE-GPP1 Port 0 is mapped to into bits [2:1].       |                                                               |
|          |      | CLKCFG.HOTPLUG_SPARE_0[3]=Port Active                                            |                                                               |
|          |      | Set bit [3] if PCIE-GPP1 Port 0 is hot-plugged configured.                       |                                                               |
|          | 2    | CLKCFG.HOTPLUG_SPARE_0[11:8] · clkconfig:0xf0                                    | PCIE-GPP1 Port 1 descriptor bits are                          |
|          |      |                                                                                  | located in bits [11:8].                                       |
|          |      | CLKCFG.HOTPLUG_SPARE_0[8] = Byte Mapping                                         |                                                               |
|          |      | Clear bit [8] to 0x0 if PCIE-GPP1 Port 1 is mapped to Port 0 of a                |                                                               |
|          |      | PCA9539 Module.                                                                  |                                                               |
|          |      | Set bit [8] to 0x1 if PCIE-GPP1 Port 1 mapped to Port 1 of PCA9539<br>Module.    |                                                               |
|          |      | CLKCFG.HOTPLUG_SPARE_0[10:9]=DeviceMapping                                       |                                                               |
|          |      | Write PCA9539 DeviceID that PCIE-GPP1 Port 1 is mapped to into bits [10:9].      |                                                               |
|          |      | CLKCFG.HOTPLUG SPARE 0[11]=Port Active                                           |                                                               |
|          |      | Set bit [11] if PCIE-GPP1 Port 1 is hot-plugged configured.                      |                                                               |
|          | 3    | CLKCFG.HOTPLUG_SPARE_0[19:16] · clkconfig:0xf0                                   | PCIE-GPP2 Port 0 descriptor bits are located in bits [19:16]. |
|          |      | CLKCFG.HOTPLUG_SPARE_0[16] = Byte Mapping                                        |                                                               |
|          |      | Clear bit [0] to 0x0 if PCIE-GPP2 Port 0 is mapped to Port 0 of a                |                                                               |
|          |      | PCA9539 Module.                                                                  |                                                               |
|          |      | Set bit [16] to 0x1 if PCIE-GPP2 Port 0 mapped to Port 1 of PCA9539              |                                                               |
|          |      | Module.                                                                          |                                                               |
|          |      | CLKCFG.HOTPLUG_SPARE_0[18:17]=DeviceMapping                                      |                                                               |
|          |      | Write PCA9539 DeviceID that PCIE-GPP2 Port 0 is mapped to into bits [18:17].     |                                                               |
|          |      | CLKCFG.HOTPLUG_SPARE_0[19]=Port Active                                           |                                                               |
|          |      | Set bit [19] if PCIE-GPP2 Port 0 is hot-plugged configured.                      |                                                               |

#### Table 4-38 Initializing Hot-Plug Descriptors with System Hot-Plug Topology

| ASIC Rev | Step | Register Settings                                                                                                                                                                                                                                          | Function/Comment                                               |
|----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| SR5690   | 4    | CLKCFG.HOTPLUG_SPARE_0[27:24] · clkconfig:0xf0                                                                                                                                                                                                             | PCIE-GPP2 Port 1 descriptor bits are                           |
| All Revs |      | CLKCFG.HOTPLUG_SPARE_0[24] = Byte Mapping<br>Clear bit [0] to 0x0 if PCIE-GPP2 Port 1 is mapped to Port 0 of a<br>PCA9539 Module.<br>Set bit [0] to 0x1 if PCIE-GPP2 Port 1 mapped to Port 1 of PCA9539<br>Module.                                         | located in bits [27:24].                                       |
|          |      | CLKCFG.HOTPLUG_SPARE_0[26:25]=DeviceMapping<br>Write PCA9539 DeviceID that PCIE-GPP2 Port 1 is mapped to into bits<br>[26:25].                                                                                                                             |                                                                |
|          |      | CLKCFG.HOTPLUG_SPARE_0[27]=Port Active<br>Set bit [27] if PCIE-GPP2 Port 1 is hot-plugged configured.                                                                                                                                                      |                                                                |
|          |      | NOTE: This step is not applicable to SR5670.                                                                                                                                                                                                               |                                                                |
|          | 5    | CLKCFG.HOTPLUG_SPARE_1[3:0] · clkconfig:0xf4                                                                                                                                                                                                               | PCIE-GPP3a Port 0 descriptor bits are located in bits [3:0].   |
|          |      | CLKCFG.HOTPLUG_SPARE_1[0] = Byte Mapping<br>Clear bit [0] to 0x0 if PCIE-GPP3a Port 0 is mapped to Port 0 of a<br>PCA9539 Module.<br>Set bit [0] to 0x1 if PCIE-GPP3a Port 0 mapped to Port 1 of PCA9539<br>Module.                                        |                                                                |
|          |      | CLKCFG.HOTPLUG_SPARE_1[2:1]=DeviceMapping<br>Write PCA9539 DeviceID that PCIE-GPP3a Port 0 is mapped to into bits<br>[2:1].                                                                                                                                |                                                                |
|          |      | CLKCFG.HOTPLUG_SPARE_1[3]=Port Active<br>Set bit [3] if PCIE-GPP3a Port 0 is hot-plugged configured.                                                                                                                                                       |                                                                |
|          | 6    | CLKCFG.HOTPLUG_SPARE_1[11:8] · clkconfig:0xf4                                                                                                                                                                                                              | PCIE-GPP3a Port 1 descriptor bits are located in bits [11:8].  |
|          |      | CLKCFG.HOTPLUG_SPARE_1[8] = Byte Mapping<br>Clear bit [8] to 0x0 if PCIE-GPP1 Port 1 is mapped to Port 0 of a<br>PCA9539 Module.<br>Set bit [8] to 0x1 if PCIE-GPP1 Port 1 mapped to Port 1 of PCA9539                                                     |                                                                |
|          |      | Module.1<br>CLKCFG.HOTPLUG_SPARE_1[10:9]=DeviceMapping<br>Write PCA9539 DeviceID that PCIE-GPP1 Port 1 is mapped to into bits<br>[10:9].                                                                                                                   |                                                                |
|          |      | CLKCFG.HOTPLUG_SPARE_1[11]=Port Active<br>Set bit [11] if PCIE-GPP3a Port 1 is hot-plugged configured.                                                                                                                                                     |                                                                |
|          | 7    | CLKCFG.HOTPLUG_SPARE_1[19:16] · clkconfig:0xf4<br>CLKCFG.HOTPLUG_SPARE_1[16] = Byte Mapping<br>Clear bit [0] to 0x0 if PCIE-GPP2 Port 2 is mapped to Port 0 of a<br>PCA9539 Module.<br>Set bit [16] to 0x1 if PCIE-GPP2 Port 2 mapped to Port 1 of PCA9539 | PCIE-GPP3a Port 2 descriptor bits are located in bits [19:16]. |
|          |      | Module.<br>CLKCFG.HOTPLUG_SPARE_1[18:17]=DeviceMapping<br>Write PCA9539 DeviceID that PCIE-GPP3a Port 2 is mapped to into bits<br>[18:17].                                                                                                                 |                                                                |
|          |      | CLKCFG.HOTPLUG_SPARE_1[19]=Port Active<br>Set bit [19] if PCIE-GPP3a Port 2 is hot-plugged configured.                                                                                                                                                     |                                                                |

| ASIC Rev | Step | Register Settings                                                                                                                                                                                                    | Function/Comment                                               |
|----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
|          | 8    | 0                                                                                                                                                                                                                    | PCIE-GPP3b Port 0 descriptor bits are located in bits [27:24]. |
|          |      | CLKCFG.HOTPLUG_SPARE_0[24] = Byte Mapping<br>Clear bit [0] to 0x0 if PCIE-GPP3b Port 0 is mapped to Port 0 of a<br>PCA9539 Module.<br>Set bit [0] to 0x1 if PCIE-GPP3b Port 0 mapped to Port 1 of PCA9539<br>Module. |                                                                |
|          |      | CLKCFG.HOTPLUG_SPARE_0[26:25]=DeviceMapping<br>Write PCA9539 DeviceID that PCIE-GPP3b Port 0 is mapped to into bits<br>[26:25].                                                                                      |                                                                |
|          |      | CLKCFG.HOTPLUG_SPARE_0[27]=Port Active<br>Set bit [27] if PCIE-GPP3b Port 0 is hot-plugged configured.                                                                                                               |                                                                |
|          |      | NOTE: This step is not applicable to SR5670.                                                                                                                                                                         |                                                                |

#### Table 4-38 Initializing Hot-Plug Descriptors with System Hot-Plug Topology (Continued)

• Step 14.2.1.2: Preparing SLOT\_STATUS Register for handshaking with firmware

Two configuration register Slot Status bits - ATTN\_BUTTON\_PRESSED and PWR\_FAULT\_DETECTED - are used by firmware to acknowledge to SBIOS successful or unsuccessful upload. Hence, SBIOS must clear these Slot Status register fields for handshake with SBIOS prior to firmware upload as indicated in table below.

| Table 4-39 | SBIOS | Initialization | of Slot | Status | Register |
|------------|-------|----------------|---------|--------|----------|
|------------|-------|----------------|---------|--------|----------|

| ASIC Rev | Step | Register Settings                                      | Function/Comment                       |
|----------|------|--------------------------------------------------------|----------------------------------------|
| SR5690   | 1    | BIF_NBP:PCIE_SLOT_STATUS[0]=0x1 · pcieConfigDev2:0x72  | This bit is set when the attention     |
| All Revs |      | ATTN_BUTTON_PRESSED button is pressed.                 |                                        |
|          |      |                                                        |                                        |
|          |      | Write 0x1 to bit [0] to clear ATTN_BUTTON_PRESSED.     |                                        |
|          | 2    | BIF_NBP:PCIE_SLOT_STATUS[1]=0x1 · pcieConfigDev2:0x72  | The Power Controller detects a         |
|          |      | PWR_FAULT_DETECTED                                     | power fault at this slot.              |
|          |      | Write 0x1 to bit [1] to clear PWR_FAULT_DETECTED.      |                                        |
|          | 3    | BIF_NBP:PCIE_SLOT_STATUS[2]=0x1 · pcieConfigDev2:0x72  | A MRL Sensor state change is           |
|          |      | MRL_SENSOR_CHANGED                                     | detected                               |
|          |      | Write 0x1 to bit [2] to clear MRL_SENSOR_CHANGED.      |                                        |
|          | 3    | BIF_NBP:PCIE_SLOT_STATUS[3]=0x1 · pcieConfigDev2:0x72  | This bit is set when a Presence        |
|          |      | PRESENCE_DETECT_CHANGED                                | Detect change is detected.             |
|          |      | Write 0x1 to bit [3] to clear PRESENCE_DETECT_CHANGED. |                                        |
|          | 4    | BIF_NBP:PCIE_SLOT_STATUS[4]=0x1 · pcieConfigDev2:0x72  | This bit is set when the Hot-Plug      |
|          |      | COMMAND_COMPLETED                                      | Controller completes an issued         |
|          |      |                                                        | command.                               |
|          |      | Write 0x1 to bit [4] to clear COMMAND_COMPLETED.       |                                        |
|          | 5    | BIF_NBP:PCIE_SLOT_STATUS[8]=0x1 · pcieConfigDev2:0x72  | This bit is set when the value         |
|          |      | DL_STATE_CHANGED                                       | reported in the Data Link Layer Link   |
|          |      |                                                        | Active bit of the Link Status register |
|          |      | Write 0x1 to bit [8] to clear DL_STATE_CHANGED.        | is changed.                            |

• Step 14.2.2: Uploading Firmware

Once initial steps have been completed, SBIOS may upload the firmware into MCU.

| ASIC Rev           | Step | Register Settings                                                                                                                                                                                                                                                                      | Function/Comment                                                       |
|--------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|
| SR5690<br>All Revs |      | Write 0x00030000 to the MC_CFG_INDEX register and 0x00000ee1 to MC_CFG_DATA register.                                                                                                                                                                                                  | Assert reset to MCU.                                                   |
|                    |      | If address from the hex file is less then 0x0200 then write 0x0001XXXX to MC_CFG_INDEX register and if adder is higher or equal to 0x0200 write 0x0000XXXX to the MC_CFG_INDEX register. The data is read from the hex file in 4 bytes chunks and written to the MC_CFG_DATA register. | Load the Hex File into the RAM memory.                                 |
|                    | 3    | Repeat step 2 until all hex file is transferred into the MCU RAM.                                                                                                                                                                                                                      |                                                                        |
|                    | 4    | Write 0x0003000 to MC_CFG_INDEX register. Write 0x00000ee2 to MC_CFG_DATA.                                                                                                                                                                                                             | SBIOS will start MCU to execute the firmware (de-assert reset to MCU). |

Table 4-40 Uploading Firmware

• Step 14.2.3: Checking for Successful Firmware Upload

Once firmware has been uploaded, the first step that it has to do is to initialize all PCA9539 devices. The firmware will then attempt to access all PCA9539 devices, and for each device found, configure PCA9539 ports in the following manner: For each hot-plug slot/link/port, it will assign 8 GPIOS. The first four IOs (IOx.0 – IOx.3) are inputs: PRSTN, PWRFLT, ATNSW and EMILS, and the last four IOs (IOx.4 – IOx.7) are outputs: PWREN, ATNLED, PWRLED and EMIL.

It will then download the descriptors that SBIOS has stored in PCIE\_HOTPLUG\_CNTL0,1 registers and validate mappings against the presence of the previously detected PCA9539 devices.

If an active port is mapped to a PCA9539 device address that was not detected in the first part of the firmware, the firmware will signal an initialization error to SBIOS by updating ATTN\_BUTTON\_PRESSED and PWR\_FAULT\_DETECTED fields in PCIE\_SLOT\_STATUS register as follows:

- Assert ATTN\_BUTTON\_PRESSED in BIF\_NBP:PCIE\_SLOT\_STATUS[0]=0x1· pcieConfigDev2:0x72 register.
- Assert PWR\_FAULT\_DETECTED BIF\_NBP:PCIE\_SLOT\_STATUS[1]=0x1· pcieConfigDev2:0x72 register.

If firmware detects no mapping errors, it must signal to SBIOS that its initialization has completed successfully. To signal the successful initialization back to SBIOS, the firmware must execute the following sequence:

- Assert ATTN\_BUTTON\_PRESSED in BIF\_NBP:PCIE\_SLOT\_STATUS[0] =0x1· pcieConfigDev2:0x72 register,.
- De-assert PWR\_FAULT\_DETECTED BIF\_NBP:PCIE\_SLOT\_STATUS[1]=0x0· pcieConfigDev2:0x72 register.

Firmware is required to update the above described Slot Status register fields and acknowledge to SBIOS successful or unsuccessful upload only after updating Present Detect State field (by passing PRSNT PCA input back to the hot-plug controller).

| ASIC Rev           | Step | Register Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Function/Comment                                                                                                     |
|--------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| SR5690<br>All Revs | 1    | Start probing bits [1:0] of PCIE_SLOT_STATUS register:<br>BIF_NBP:PCIE_SLOT_STATUS[0] · pcieConfigDev2:0x72<br>ATTN_BUTTON_PRESSED<br>BIF_NBP:PCIE_SLOT_STATUS[0] · pcieConfigDev2:0x72<br>PWR_FAULT_DETECTED<br>If read back value of 1 is found only for ATTN_BUTTON_PRESSED<br>(PWR_FAULT_DETECTED remains the value of 0), then this is an indication of<br>successful firmware update, exit this sequence and move to the next hot-plug<br>configuration step.<br>If read back value of 0x1 is found for both ATTN_BUTTON_PRESSED and<br>PWR_FAULT_DETECTED then this is an indication that firmware failed to<br>initialize correctly. Go to Step2 or Step3 depending on CMOS option enabled.<br>NOTE: Software miss-configuration of hot-plug configuration should not happen | Once SBIOS has started<br>firmware execution, it must<br>keep probing bits [1:0] of<br>PCIE_SLOT_STATUS<br>register. |
|                    |      | and it is up to a customer to choose an appropriate step of action. Either CMOS option described in Steps 2 and 3 is suggested.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                      |
|                    | 2    | If a firmware initialization error happens, post a dedicated POST CODE and freeze the system.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | CMOS Option (Disabled by default)                                                                                    |
|                    | 3    | If a firmware initialization error happens, revert advertised hot-plug capabilities for the Device the error is reported:<br>Set bit [8] to 0x1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                      |
|                    |      | BIF_NBP:PCIE_SLOT_CAP[0]=0x0 · pcieConfigDev*:0x6c<br>ATTN_BUTTON_PRESENT<br>Clear bit [0] to 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                      |
|                    |      | BIF_NBP:PCIE_SLOT_CAP[1]=0x0 · pcieConfigDev*:0x6c<br>PWR_CONTROLLER_PRESENT<br>Clear bit [1] to 0x1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                      |
|                    |      | BIF_NBP:PCIE_SLOT_CAP[3]=0x0 · pcieConfigDev*:0x6c<br>ATTN_INDICATOR_PRESENT<br>Clear bit [3] to 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                      |
|                    |      | BIF_NBP:PCIE_SLOT_CAP[4]=0x0 · pcieConfigDev*:0x6c<br>PWR_INDICATOR_PRESENT<br>Clear bit [4] to 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                      |
|                    |      | BIF_NBP:PCIE_SLOT_CAP[6]=0x0 · pcieConfigDev*:0x6c<br>HOTPLUG_CAPABLE<br>Clear bit [6] to 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                      |
|                    |      | BIF_NBP:PCIE_SLOT_CAP[17]=0x0 · pcieConfigDev*:0x6c<br>ELECTROMECH_INTERLOCK_PRESENT<br>Clear bit [17] to 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                      |
|                    |      | BIF_NBP:PCIE_SLOT_CAP[18]=0x1 · pcieConfigDev*:0x6c<br>NO_COMMAND_COMPLETED_SUPPORTED<br>Set bit [18] to 0x1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                      |
|                    |      | <ul><li>and for the Device the error is reported:</li><li>1. Exit the hot-plug sequence;</li><li>2. Hide the bridge;</li><li>3. Set the hold training bit to 1;</li><li>4. Power down the port, and then move to the train the next device.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                      |

#### Table 4-41 SBIOS Check of Successful Firmware Upload

# • Step 14.3: SBIOS Acknowledgment to Firmware of Successful Firmware Upload

To acknowledge firmware that SBIOS has detected successful firmware upload, SBIOS should follow the steps in table below.

| ASIC Rev | Step | Register Settings                                                                  | Function/Comment                                                      |
|----------|------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| SR5690   | 1    | BIF_NBP:PCIE_SLOT_STATUS[0]=0x1 · pcieConfigDev2:0x72                              | This bit is set when the attention                                    |
| All Revs |      | ATTN_BUTTON_PRESSED                                                                | button is pressed.                                                    |
|          |      | Write 0x1 to bit [0] to clear ATTN_BUTTON_PRESSED.                                 |                                                                       |
|          | 2    | BIF_NBP:PCIE_SLOT_STATUS[1]=0x1 · pcieConfigDev2:0x72                              | The Power Controller detects a                                        |
|          |      | PWR_FAULT_DETECTED                                                                 | power fault at this slot.                                             |
|          |      |                                                                                    |                                                                       |
|          |      | Write 0x1 to bit [1] to clear PWR_FAULT_DETECTED.                                  |                                                                       |
|          | 3    | BIF_NBP:PCIE_SLOT_STATUS[2]=0x1 · pcieConfigDev2:0x72<br>MRL_SENSOR_CHANGED        | A MRL Sensor state change is<br>detected                              |
|          |      |                                                                                    | delected                                                              |
|          |      | Write 0x1 to bit [2] to clear MRL_SENSOR_CHANGED.                                  |                                                                       |
|          | 4    | BIF_NBP:PCIE_SLOT_STATUS[3]=0x1 · pcieConfigDev2:0x72                              | This bit is set when a Presence                                       |
|          |      | PRESENCE_DETECT_CHANGED                                                            | Detect change is detected.                                            |
|          |      | Write 0x1 to bit [3] to clear PRESENCE_DETECT_CHANGED.                             |                                                                       |
|          | 5    | BIF_NBP:PCIE_SLOT_STATUS[4]=0x1 · pcieConfigDev2:0x72                              | This bit is set when the Hot-Plug                                     |
|          | Ű    | COMMAND_COMPLETED                                                                  | Controller completes an issued                                        |
|          |      |                                                                                    | command.                                                              |
|          |      | Write 0x1 to bit [4] to clear COMMAND_COMPLETED.                                   |                                                                       |
|          | 6    | BIF_NBP:PCIE_SLOT_STATUS[8]=0x1 · pcieConfigDev2:0x72                              | This bit is set when the value                                        |
|          |      | DL_STATE_CHANGED                                                                   | reported in the Data Link Layer<br>Link Active bit of the Link Status |
|          |      | Write 0x1 to bit [8] to clear DL_STATE_CHANGED.                                    | register is changed.                                                  |
|          | 7    | BIF_NBP:PCIE_SLOT_CNTL [0]=0x1 · pcieConfigDev*:0x70                               | This bit when set enables the                                         |
|          |      | ATTN_BUTTON_PRESSED_EN                                                             | generation of Hot-Plug interrupt or                                   |
|          |      | Set bit [0] to 0x1.                                                                | wakeup event on an attention<br>button pressed event.                 |
|          | 8    | BIF_NBP:PCIE_SLOT_CNTL [1]=0x1 · pcieConfigDev*:0x70                               | This bit when set enables                                             |
|          |      | PWR_FAULT_DETECTED_EN                                                              | software notification on a power                                      |
|          |      |                                                                                    | fault event.                                                          |
|          |      | Set bit [1] to 0x1.                                                                |                                                                       |
|          | 9    | BIF_NBP:PCIE_SLOT_CNTL [3]=0x1 · pcieConfigDev*:0x70<br>PRESENCE_DETECT_CHANGED_EN | This bit when set enables the<br>generation of Hot-Plug interrupt or  |
|          |      |                                                                                    | wakeup event on a presence                                            |
|          |      | Set bit [3] to 0x1.                                                                | detect changed event.                                                 |
|          | 10   | BIF_NBP:PCIE_SLOT_CNTL [4]=0x1 · pcieConfigDev*:0x70                               | This bit when set enables the                                         |
|          |      | COMMAND_COMPLETED_INTR_EN                                                          | generation of Hot-Plug interrupt                                      |
|          |      | Set bit [4] to 0x1.                                                                | when a command is completed by<br>the Hot-Plug Controller.            |
|          | 11   | BIF_NBP:PCIE_SLOT_CNTL [5]=0x1 · pcieConfigDev*:0x70                               | This bit when set enables                                             |
|          |      | HOTPLUG_INTR_EN                                                                    | generation of Hot-Plug interrupt                                      |
|          |      |                                                                                    | on enabled Hot-Plug events.                                           |
|          |      | Set bit [5] to 0x1.                                                                | <b>T</b>                                                              |
|          | 12   | BIF_NBP:PCIE_SLOT_CNTL [7:6]=20x3 · pcieConfigDev*:0x70<br>ATTN_INDICATOR_CNTL     | Turn off attention indicator.                                         |
|          |      |                                                                                    |                                                                       |
|          |      | Set bits [7:6] to 0x3.                                                             |                                                                       |
|          | 13   | BIF_NBP:PCIE_SLOT_CNTL [9:8]=0x1 · pcieConfigDev*:0x70                             | Turn on power indicator on.                                           |
|          |      | PWR_INDICATOR_CNTL                                                                 |                                                                       |
|          |      | Set hits [0:8] to 0x1                                                              |                                                                       |
|          |      | Set bits [9:8] to 0x1.                                                             |                                                                       |

Table 4-42 SBIOS Acknowledgment to Firmware of Successful Firmware Upload

| ASIC Rev | Step | Register Settings                                     | Function/Comment                    |
|----------|------|-------------------------------------------------------|-------------------------------------|
| SR5690   | 14   | BIF_NBP:PCIE_SLOT_CNTL [10]=0x0 · pcieConfigDev*:0x70 | Power On.                           |
| All Revs |      | PWR_CONTROLLER_CNTL                                   |                                     |
|          |      | Clear bit [10] to 0x0.                                |                                     |
|          | 15   | BIF_NBP:PCIE_SLOT_CNTL [11]=0x1 · pcieConfigDev*:0x70 | Lock the Slot.                      |
|          |      | ELECTROMECH_INTERLOCK_CNTL                            |                                     |
|          |      | Set bit [11] to 0x1.                                  |                                     |
|          | 16   | BIF_NBP:PCIE_SLOT_CNTL [12]=0x1 · pcieConfigDev*:0x70 | If the Data Link Layer Link Active  |
|          |      | DL_STATE_CHANGED_EN                                   | Capability is implemented, this bit |
|          |      |                                                       | when set enables software           |
|          |      |                                                       | notification when Data Link Layer   |
|          |      |                                                       | Link Active Reporting bit is        |
|          |      | Set bit [12] to 0x1.                                  | changed.                            |

| Table 4-42 SBIOS Acknowledgment to Firmware of Successful Firmware Upload | (Continued) |  |
|---------------------------------------------------------------------------|-------------|--|
| Table 4-42 Obioo Acknowledgment to Finnware of Ouccessful Finnware opioad | (Commucu)   |  |

# • Step 14.4: Check for Device Present in the Hot-Plug Slot on Initial Boot-up

Once successful firmware upload has been accomplished, SBIOS can check whether a device is present in the slot by performing steps in the table below.

| ASIC Rev | Step | Register Settings                                                                                           | Function/Comment             |
|----------|------|-------------------------------------------------------------------------------------------------------------|------------------------------|
| SR5690   | 1    | Read back bit [6] of Slot Status Register of in each of the                                                 | SBIOS checks presence of the |
| All Revs |      | device-specific configuration spaces:                                                                       | adapter in the slot.         |
|          |      | BIF_NBP:PCIE_SLOT_STATUS[6] · pcieConfigDev2:0x72                                                           |                              |
|          |      | PRESENCE_DETECT_STATE                                                                                       |                              |
|          |      | If read back value is 0x0, there is no device present in the slot, go to Step 14-4.                         |                              |
|          |      | If read back value is 0x1, there is device present in the slot, exit the Hot Plug sequence for this Device. |                              |

Table 4-43 SBIOS Checks whether a Device Is Present in the Slot

# • Step 14.5: Complete Hot-Plug Algorithm for the Desired Functional Mode for Signaling Hot-Plug Events when the Device is Not Present in Hot-Plug Slot on Initial Boot-up

| ASIC Rev | Step | Register Settings                                      | Function/Comment                            |
|----------|------|--------------------------------------------------------|---------------------------------------------|
| SR5690   | 1    | BIF_NBP:PCIE_SLOT_CNTL [0]=0x1 · pcieConfigDev*:0x70   | This bit when set enables the generation of |
| All Revs |      | ATTN_BUTTON_PRESSED_EN                                 | Hot-Plug interrupt or wakeup event on an    |
|          |      |                                                        | attention button pressed event.             |
|          |      | Set bit [0] to 0x1.                                    |                                             |
|          | 2    | BIF_NBP:PCIE_SLOT_CNTL [1]=0x1 · pcieConfigDev*:0x70   | This bit when set enables software          |
|          |      | PWR_FAULT_DETECTED_EN                                  | notification on a power fault event.        |
|          |      | Set bit [1] to 0x1                                     |                                             |
|          | 3    | BIF_NBP:PCIE_SLOT_CNTL [3]=0x1 · pcieConfigDev*:0x70   | This bit when set enables the generation of |
|          |      | PRESENCE_DETECT_CHANGED_EN                             | Hot-Plug interrupt or wakeup event on a     |
|          |      |                                                        | presence detect changed event.              |
|          |      | Set bit [3] to 0x1                                     |                                             |
|          | 4    | BIF_NBP:PCIE_SLOT_CNTL [4]=0x1 · pcieConfigDev*:0x70   | This bit when set enables the generation of |
|          |      | COMMAND_COMPLETED_INTR_EN                              | Hot-Plug interrupt when a command is        |
|          |      |                                                        | completed by the Hot-Plug Controller.       |
|          |      | Set bit [4] to 0x1                                     |                                             |
|          | 5    | BIF_NBP:PCIE_SLOT_CNTL [5]=0x1 · pcieConfigDev*:0x70   | This bit when set enables generation of     |
|          |      | HOTPLUG_INTR_EN                                        | Hot-Plug interrupt on enabled Hot-Plug      |
|          |      |                                                        | events.                                     |
|          |      | Set bit [5] to 0x1                                     |                                             |
|          | 6    | BIF_NBP:PCIE_SLOT_CNTL [7:6]=0x3 · pcieConfigDev*:0x70 | Turn off attention indicator.               |
|          |      | ATTN_INDICATOR_CNTL                                    |                                             |
|          |      | Set bits [7:6] to 0x3.                                 |                                             |
|          | 7    | BIF_NBP:PCIE_SLOT_CNTL [9:8]=0x3 · pcieConfigDev*:0x70 | Turn off power indicator on.                |
|          |      | PWR_INDICATOR_CNTL                                     |                                             |
|          |      | Set bits [9:8] to 0x3.                                 |                                             |
|          | 8    | BIF_NBP:PCIE_SLOT_CNTL [10]=0x1 · pcieConfigDev*:0x70  | Power Off.                                  |
|          |      | PWR_CONTROLLER_CNTL                                    |                                             |
|          |      | Set bit [10] to 0x1.                                   |                                             |
|          | 9    | BIF_NBP:PCIE_SLOT_CNTL [11]=0x0 · pcieConfigDev*:0x70  | Unlock the Slot.                            |
|          |      | ELECTROMECH_INTERLOCK_CNTL                             |                                             |
|          |      | Clear bit [11] to 0x0.                                 |                                             |

| ASIC Rev | Step | Register Settings                                     | Function/Comment                              |
|----------|------|-------------------------------------------------------|-----------------------------------------------|
| SR5690   | 10   | BIF_NBP:PCIE_SLOT_CNTL [12]=0x0 · pcieConfigDev*:0x70 | If the Data Link Layer Link Active Capability |
| All Revs |      | DL_STATE_CHANGED_EN                                   | is implemented, this bit when set enables     |
|          |      |                                                       | software notification when Data Link Layer    |
|          |      |                                                       | Link Active Reporting bit is changed.         |
|          |      |                                                       |                                               |
|          |      | Set bit [12] to 0x1.                                  |                                               |

#### Table 4-44 Complete Hot-Plug Algorithm when the Device Is Not Present on Initial Boot-up (Continued)

# 4.4.3 PCIe<sup>®</sup> Links Training

# 4.4.3.1 Allow all PCIe Links to Start Training

[NOTE: For all Hot-Plug capable devices, release the link to start training regardless whether a corresponding slot is populated or not.]

# • Step 15: Allow all PCIe Links to Start Training

To let all PCIe links present in the system to start training, follow the programming sequence below.

NOTE: If the compile flag for Dev\* is not set, bypass training for Dev\*; otherwise, follow the sequence in the table below.

| Table 4-45 | Allow all PCIe | Links to | Start Training |
|------------|----------------|----------|----------------|
|------------|----------------|----------|----------------|

| ASIC Rev                         | Step | Register Settings                                                                | Function/Comment                                                                           |
|----------------------------------|------|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    | NBCFG:PCIE_LINK_CFG[4]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN0_GPP1                   | Releases hold training for:<br>PCIE-GPP1 Port 0 (Device 2)                                 |
|                                  |      | Clear bit [4] to0x0.                                                             |                                                                                            |
|                                  | 2    | NBCFG:PCIE_LINK_CFG[5]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN1_GPP1                   | Releases hold training for PCIE-GPP1 Port 1<br>(Device 3) in Dual PCIE-GPP1 Configuration. |
|                                  |      | Clear bit [5] to 0x0.                                                            |                                                                                            |
|                                  | 3    | NBCFG:PCIE_LINK_CFG[6]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN0_GPP2                   | Releases hold training for PCIE-GPP2 Port 0<br>(Device11)                                  |
|                                  |      | Clear bit [6] to 0x0.<br>NOTE: This step is not applicable to SR5650.            |                                                                                            |
|                                  | 4    | NBCFG:PCIE_LINK_CFG[7]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN0_GPP2                   | Releases hold training for PCIE-GPP2 Port 1<br>(Device12) in PCIE-GPP2 Dual configuration  |
|                                  |      | Clear bit [7] to 0x0.<br>NOTE: This step is not applicable to SR5670 and SR5650. |                                                                                            |
|                                  | 5    | NBCFG:PCIE_LINK_CFG[21]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN1_GPP3a                 | Releases hold training for PCIE-GPP3a Port 0                                               |
|                                  |      | Clear bit [21] to 0x0.                                                           |                                                                                            |
|                                  | 6    | NBCFG:PCIE_LINK_CFG[22]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN2_GPP3a                 | Releases hold training for PCIE-GPP3a Port 1                                               |
|                                  |      | Clear bit [22] to 0x0.                                                           |                                                                                            |
|                                  | 7    | NBCFG:PCIE_LINK_CFG[23]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN3_GPP3a                 | Releases hold training for PCIE-GPP3a Port 2                                               |
|                                  |      | Clear bit [23] to 0x0.                                                           |                                                                                            |
|                                  | 8    | NBCFG:PCIE_LINK_CFG[24]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN4_GPP3a                 | Releases hold training for PCIE-GPP3a Port 3                                               |
|                                  |      | Clear bit [24] to 0x0.                                                           |                                                                                            |
|                                  | 9    | NBCFG:PCIE_LINK_CFG[25]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN5_GPP3a                 | Releases hold training for PCIE-GPP3a Port 4                                               |
|                                  |      | Clear bit [25] to 0x 0.                                                          |                                                                                            |
|                                  | 10   | NBCFG:PCIE_LINK_CFG[26]=0x0 · NBMISCIND:0x8<br>HOLD_TRAIN6_GPP3a                 | Releases hold training for PCIE-GPP3a Port 5                                               |
|                                  |      | Clear bit [26] to 0x0.                                                           |                                                                                            |

| ASIC Rev     | Step | Register Settings                                              | Function/Comment                             |
|--------------|------|----------------------------------------------------------------|----------------------------------------------|
| SR5690/5670/ | 11   | NBCFG:PCIE_NBCFG_REG12[4]=0x0 · NBMISCIND:0x2A                 | Releases hold training for PCIE-GPP3b Port 0 |
| 5650         |      | HOLD_TRAIN6_GPP3b                                              |                                              |
| All Revs     |      |                                                                |                                              |
|              |      | Clear bit [4] to 0.                                            |                                              |
|              |      | NOTE: This step is not applicable to SR5670 and SR5650.        |                                              |
|              | 12   | For each port whose link is released to start training; follow | Performs PCIe Link Training Sequence for all |
|              |      | the sequence described in <i>Section 4.4.3.2</i>               | active devices in parallel.                  |

#### Table 4-45 Allow all PCIe Links to Start Training (Continued)

# 4.4.3.2 PCIe<sup>®</sup> Link Training Sequence

#### • Step 16: PCIe Links Training

[NOTE: The link training sequence cannot be interrupted, and no other SBIOS code can be added in between.] For each PCIe link, follow the sequence described below in order to train the link.

# Table 4-46 PCIe Link Training Sequence

| ASIC Rev     | Step | Register Settings                                                            | Function/Comment                                                                       |
|--------------|------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_LINK_CFG · NBMISCIND:0x8                                          | Releases hold training for Device* by clearing                                         |
| 5650         |      | NBCFG:PCIE_NBCFG_REG12 [4] · NBMISCIND:0x2A                                  | the corresponding bit to 0x0.                                                          |
| All Revs     | 2    | Delay 200us.                                                                 |                                                                                        |
|              | 3    | BIF_NBP:PCIE_LC_STATE0 · PCIEIND_P:0xA5                                      | Detects if there is any card present from<br>reading back PCIE_LC_STATE0 in Port Index |
|              |      | Read back the following values:                                              | space of Device*.                                                                      |
|              |      | LC_CURRENT_STATE = [5:0]                                                     |                                                                                        |
|              |      | LC_PREV_STATE1 = [13:8]                                                      |                                                                                        |
|              |      | LC_PREV_STATE2 = [21:16]                                                     |                                                                                        |
|              |      | LC_PREV_STATE3 = [29:24]                                                     |                                                                                        |
|              |      | If any read back value is 0x3F, then perform CF9 reset;                      |                                                                                        |
|              |      | If LC_CURRENT_STATE = 0x00 to 0x04, then keep checking for                   |                                                                                        |
|              |      | up to 40ms. If no device is present, go to step 12; otherwise, go to step 4. |                                                                                        |

| ASIC Rev                         | Step | Register Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Function/Comment     |
|----------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| SR5690/5670/<br>5650<br>All Revs | 4    | Note: To identify lane reversal in the sequence below, check bit [0]<br>of the following register:<br>BIF_NBP:PCIE_P_PORT_LANE_STATUS[0] · PCIEIND_P:0x50<br>PORT_LANE_REVERSAL<br>If bit [0] = 0x0, then port lane order is normal.<br>If bit [0] = 0x1, then port lane order is reversed.<br>Broken Transmitter Lane Algorithm:<br>Read back the following register fields:<br>BIF_NBP:PCIE_LC_STATE0 · PCIEIND_P:0xA5<br>LC_CURRENT_STATE = [5:0]<br>LC_PREV_STATE1 = [13:8]<br>LC_PREV_STATE2 = [21:16]<br>LC_PREV_STATE3 = [29:24]<br>If the read back value of 0x062A is found in any of the fields<br>above, then read back the expected link width and the actual<br>number of receivers detected by reading bits [2:0] and bits [6:4]<br>respectively of the following register:<br>BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[6:4] · PCIEIND_P:0xA2<br>LC_LINK_WIDTH<br>LC_LINK_WIDTH_RD<br>If the number of receivers detected is less than the expected width<br>of the link to be trained and:<br>if [6:4]=0x4 and lane reversal is not enabled, set:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]=0xF · PCIEIND:0x65<br>B_PTX_PDNB_FDIS<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]=0xF · PCIEIND:0x65<br>B_PTX_PDNB_FDIS<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]=0xF · PCIEIND:0x65<br>B_PTX_PDNB_FDIS | enabled by default). |
|                                  |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                      |

# Table 4-46 PCIe Link Training Sequence (Continued)

| ASIC Rev                         | Step | Register Settings                                                                                                                                                                                            | Function/Comment |
|----------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| SR5690/5670/<br>5650<br>All Revs | 4    | Step 4 continued from the previous page                                                                                                                                                                      |                  |
|                                  |      | if [6:4]=0x4 and lane reversal is enabled, set:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]=0xF · PCIEIND:0x65<br>B_PTX_PDNB_FDIS<br>BIF_NB:PCIE_P_PAD_FORCE_D[11:8]=0xF · PCIEIND:0x65<br>B_PRX_PDNB_FDIS           |                  |
|                                  |      | if [6:4]=0x3 and lane reversal is not enabled, set:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[7:2]=0x3F· PCIEIND:0x65<br>B_PTX_PDNB_FDIS<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[15:10]=0x3F·<br>PCIEIND:0x65<br>B_PRX_PDNB_FDIS |                  |
|                                  |      | if [6:4]=0x3 and lane reversal is enabled, set:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[5:0]=0x3F · PCIEIND:0x65<br>B_PTX_PDNB_FDIS<br>BIF_NB:PCIE_P_PAD_FORCE_D[13:8]=0x3F · PCIEIND:0x65<br>B_PRX_PDNB_FDIS         |                  |
|                                  |      | If [6:4]=0x2 and lane reversal is not enabled, set:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[7:1]=0x7F · PCIEIND:0x65<br>B_PTX_PDNB_FDIS<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[15:9]=0x7F · PCIEIND:0x65                      |                  |
|                                  |      | If [6:4]=0x2 and lane reversal is enabled, set:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[6:0]=0x7F · PCIEIND:0x65<br>B_PTX_PDNB_FDIS<br>BIF_NB:PCIE_P_PAD_FORCE_D[14:8]=0x7F · PCIEIND:0x65<br>B_PRX_PDNB_FDIS         |                  |
|                                  |      | Toggle GPIO reset to the PCIe link.                                                                                                                                                                          |                  |
|                                  |      | Go to Step 5.                                                                                                                                                                                                |                  |
|                                  |      | If bits [6:4] take any other values than those described above, or in all other cases, go to Step 5.                                                                                                         |                  |
|                                  | 5    | Based on the CMOS option selected, either Gen2 AUTO or Gen2<br>Advertised RC, implement Step 6 or Step 7.                                                                                                    |                  |

#### Table 4-46 PCle Link Training Sequence (Continued)

| ASIC Rev                                     | Step | Register Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Function/Comment |
|----------------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| ASIC Rev<br>SR5690/5670/<br>5650<br>All Revs | 6    | Step 6 continued from the previous page         PCIE-GPP3a Port0:         NBCFG:PCIE_NBCFG_REG10[2]=0x0 · NBMISCIND:0x28         STRAP_BIF_DE_EMPHASIS_SEL_A_GPP3a         Clear bit [2] to 0x0.         PCIE-GPP3a Port1:         NBCFG:PCIE_NBCFG_REG10[3]=0x0 · NBMISCIND:0x28         STRAP_BIF_DE_EMPHASIS_SEL_B_GPP3a         Clear bit [3] to 0x0.         PCIE-GPP3a Port2:         NBCFG:PCIE_NBCFG_REG10[4]=0x0 · NBMISCIND:0x28         STRAP_BIF_DE_EMPHASIS_SEL_C_GPP3a         Clear bit [4] to 0x0.         PCIE-GPP3a Port2:         NBCFG:PCIE_NBCFG_REG10[5]=0x0 · NBMISCIND:0x28         STRAP_BIF_DE_EMPHASIS_SEL_D_GPP3a         Clear bit [5]=0x0         PCIE-GPP3a Port4:         NBCFG:PCIE_NBCFG_REG10[6]=0x0 · NBMISCIND:0x28         STRAP_BIF_DE_EMPHASIS_SEL_E_GPP3a         Clear bit [6] to 0x0.         PCIE-GPP3a Port5:         NBCFG:PCIE_NBCFG_REG10[7]= 0x0 · NBMISCIND:0x28         STRAP_BIF_DE_EMPHASIS_SEL_F_GPP3a         Clear bit [6] to 0x0.         PCIE-GPP3b Port0:         NBCFG:PCIE_NBCFG_REG15[5]=0x0 · NBMISCIND:0x20         STRAP_BIF_DE_EMPHASIS_SEL_A_GPP3b         Clear bit [7] to 0x0.         PCIE-GPP3b Port0:         NBCFG:PCIE_NBCFG_REG15[5]=0x0 · NBMISCIND:0x2D         STRAP_BIF_DE |                  |

| SR5690:6670/<br>5650       7       BIF_MBP:PCIE_LC_STATE: PCIEIND_P:0xA5       CMOS Option (RC Advertised Gen:<br>Disabled by Default)         All Revs       LC_PREV_STATE: = [5:0]       LC_PREV_STATE: = [21:16]         LC_PREV_STATE: = [21:16]       LC_PREV_STATE: = [29:24]       If the read back value of 0x062A or 0x092A is found in any of the<br>fields above, set the following registers to the values specified<br>below:         BIF_MBP:UNK_CNTL2[3:0]=0x1 · pcieCopcieConfigDev*:0x88       TARGET_LINK_SPEED         Set bits [3:0] to 0x1.       BIF_MBP:PCIE_LC_SPEED_CNTL[0]=0x0 · PCIEIND_P:0xA4         LC_GEN2_EN_STRAP       Clear bit [0] to 0x0.         Clear bit [0] to 0x0.       BIF_MBP:PCIE_LC_LINK_WIDTH_CNTL[13]=0x1 ·<br>PCIE:MD_P:0xA2         LC_UPCONFIGURE_DIS       Set bit [13] to 0x1.         and for the link in training clear corresponding de-emphasis select<br>bit:       Dit         DIE_DE_DP:00:E_LMBCFG_REG10[0=0x0 · NBMISCIND:0x28       STRAP_BIF_DE_EMPHASIS_SEL_A_GPP1         Clear bit [10] to 0x0.       PCIE:GPP1 Pont0:         NBCFGPCIE_NBCFG_REG10[1=0x0 · NBMISCIND:0x27       STRAP_BIF_DE_EMPHASIS_SEL_A_GPP2         Clear bit [10] to 0x0.       PCIE:GPP2 Pont0:         NBCFGPCIE_NBCFG_REGF[31]=0x0 · NBMISCIND:0x27       STRAP_BIF_DE_EMPHASIS_SEL_A_GPP2         Clear bit [30] to 0x0.       PCIE:GPP2 PAnt0:         NBCFGPCIE_NBCFG_REGF[31]=0x0 · NBMISCIND:0x27       STRAP_BIF_DE_EMPHASIS_SEL_B_GPP2 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STRAP_BIF_DE_EMPHASIS_SEL_A_GPP3a<br>Clear bit [2] to 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| ASIC Rev     | Step | Register Settings                                                                                                            | Function/Comment                                |
|--------------|------|------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| SR5690/5670/ | 7    | Step 7 continued from the previous page                                                                                      |                                                 |
| 5650         |      | DCIE CDD2a Dat1:                                                                                                             |                                                 |
| All Revs     |      | PCIE-GPP3a Port1:<br>NBCFG:PCIE_NBCFG_REG10[3]=0x0 · NBMISCIND:0x28                                                          |                                                 |
|              |      | STRAP_BIF_DE_EMPHASIS_SEL_B_GPP3a                                                                                            |                                                 |
|              |      | Clear bit [3] to 0x0.                                                                                                        |                                                 |
|              |      |                                                                                                                              |                                                 |
|              |      | PCIE-GPP3a Port2:<br>NBCFG:PCIE NBCFG REG10[4]=0x0 · NBMISCIND:0x28                                                          |                                                 |
|              |      | STRAP_BIF_DE_EMPHASIS_SEL_C_ GPP3a                                                                                           |                                                 |
|              |      | Clear bit [4] to 0x0.                                                                                                        |                                                 |
|              |      | PCIE-GPP3a Port3:                                                                                                            |                                                 |
|              |      | NBCFG:PCIE_NBCFG_REG10[5]=0x0 · NBMISCIND:0x28                                                                               |                                                 |
|              |      | STRAP_BIF_DE_EMPHASIS_SEL_D_GPP3a                                                                                            |                                                 |
|              |      | Clear bit [5] to 0x0.                                                                                                        |                                                 |
|              |      | PCIE-GPP3a Port4:                                                                                                            |                                                 |
|              |      | NBCFG:PCIE_NBCFG_REG10[6]=0x0 · NBMISCIND:0x28                                                                               |                                                 |
|              |      | STRAP_BIF_DE_EMPHASIS_SEL_E_ GPP3a<br>Clear bit [6] to 0x0.                                                                  |                                                 |
|              |      |                                                                                                                              |                                                 |
|              |      | PCIE-GPP3a Port5:                                                                                                            |                                                 |
|              |      | NBCFG:PCIE_NBCFG_REG10[7]= 0x0 · NBMISCIND:0x28                                                                              |                                                 |
|              |      | STRAP_BIF_DE_EMPHASIS_SEL_F_ GPP3a<br>Clear bit [7] to 0x0 <sup>.</sup>                                                      |                                                 |
|              |      |                                                                                                                              |                                                 |
|              |      | PCIE-GPP3b Port0:                                                                                                            |                                                 |
|              |      | NBCFG:PCIE_NBCFG_REG15[5]=0x0 · NBMISCIND:0x2D<br>STRAP_BIF_DE_EMPHASIS_SEL_A_GPP3b                                          |                                                 |
|              |      | Clear bit [5] to 0x0.                                                                                                        |                                                 |
|              |      | NOTE: This step is not applicable to SR5670.                                                                                 |                                                 |
|              |      | Toggle GPIO reset to the PCIe link.                                                                                          |                                                 |
|              |      |                                                                                                                              |                                                 |
|              | 8    | Go to Step 8.<br>BIF_NBP:PCIE_LC_STATE0 · PCIEIND_P:0xA5                                                                     | Detects if link is in Compliance State or it is |
|              | 0    |                                                                                                                              | trained to L0 from reading back                 |
|              |      | Read back bits [5:0].                                                                                                        | PCIE_LC_STATE0 [5:0] in Device*.                |
|              |      | If LC_CURRENT_STATE = 0x07 -> Device is in compliance state                                                                  |                                                 |
|              |      | (training sequence is done). Move to train the next device;                                                                  |                                                 |
|              |      | If LC_CURRENT_STATE = 0x10 -> go to Step 9                                                                                   |                                                 |
|              |      | Otherwise, keep polling for up to 2 seconds, then perform CF9 reset. This should only be repeated for a maximum of 15 times. |                                                 |
|              |      | If LC_CURRENT_STATE can not reach 0x10 or 0x07 -> go to Step 13.                                                             |                                                 |

| ASIC Rev     | Step | Register Settings                                                       | Function/Comment                               |
|--------------|------|-------------------------------------------------------------------------|------------------------------------------------|
| SR5690/5670/ | 9    | BIF_NBP:PCIE_VC0_RESOURCE_STATUS[1]                                     | Detects if Data Link Negotiation is performed, |
| 5650         |      |                                                                         | by reading bit [1] of                          |
| All Revs     |      | VC_NEGOTIATION_PENDING                                                  | BIF_NBP:PCIE_VC0_RESOURCE_STATUS[              |
|              |      |                                                                         | 1] · pcieConfigDev*:0x12a                      |
|              |      | Read bit [1].                                                           |                                                |
|              |      | Read back value of 0x0 means link negotiation is successful             |                                                |
|              |      | Read back value of 0x1 means the link needs to be re-trained ->         |                                                |
|              |      | go to step 10.                                                          |                                                |
|              | 10   | For the following register, set bit [8] and make bits [2:0] to be equal | Retrains the link.                             |
|              |      | to bits [6:4]:                                                          |                                                |
|              |      | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL PCIEIND_P:0xA2                          |                                                |
|              |      | LC_RECONFIG_NOW, bit [8]                                                |                                                |
|              |      | LC_LINK_WIDTH, bit [2:0] <- LC_LINK_WIDTH_RD, bit [6:4]                 |                                                |
|              |      | Wait for 5ms after the bits above are set, and then go back to step     |                                                |
|              |      | 2 (stay in this loop indefinitely).                                     |                                                |
| SR5690/5670/ | 11   | For device in non hot-plug implemented slot:                            | When the link cannot be trained properly,      |
| 5650         |      | 1. Hide the bridge                                                      | these 3 steps should be performed.             |
| All Revs     |      | 2. Set the hold training bit to 1 (find the corresponding bit from      |                                                |
|              |      | Step 1);                                                                |                                                |
|              |      | 3. Power down the port, than move to the train the next device.         |                                                |
|              |      | NOTE: For hot-plug implemented slots, after releasing link to start     |                                                |
|              |      | training when no add-in card is plugged into the slot on initial        |                                                |
|              |      | boot-up, just move to train the next device and leave NB port in        |                                                |
|              |      | Receiver Detection loop.                                                |                                                |

# 4.4.4 PCIe<sup>®</sup> Power Control

#### 4.4.4.1 Dynamic Link Width Control (CMOS Option)

#### • Step 17: Dynamic Link Width Control (CMOS Option)

Dynamic Link Width Control is a power saving feature that allows fewer PCIe lanes to be active as compared to the number of lanes physically connected on the PCIe link. This feature is initiated by software and completely controlled by hardware.

The following CMOS options are available:

- PCIE-GPP1 Port 0 Link Width: x16, x8, x4, x2, x1
- PCIE-GPP1 Port 1 Link Width: x8, x4, x2, x1 [NOTE: This CMOS option should be available only in Dual Port configuration and greyed out in Single Port configuration]
- PCIE-GPP2 Port 0 Link Width: x16, x8, x4, x2, x1 (Not applicable to SR5650)
- PCIE-GPP2 Port 1 Link Width: x8, x4,x2,x1 (Not applicable to SR5670, SR5650) [NOTE: This CMOS option should be available only in Dual Port configuration and grey out in Single Port configuration]
- PCIE-SB Port 0 Link Width: x4, x2, x1
- PCIE-GPP3a Port 0 Link Width: x4, x2, x1
- PCIE-GPP3a Port 1 Link Width: x2, x1
- PCIE-GPP3a Port 2 Link Width: x2, x1
- PCIE-GPP3a Port 3 Link Width: x1
- PCIE-GPP3a Port 4 Link Width: x1
- PCIE-GPP3a Port 5 Link Width: x1
- PCIE-GPP3b Port 0 Link Width: x4, x2, x1 (Not applicable to SR5670 and SR5650)

If the Southbridge has low bandwidth requirements, for example, when SATA ports are not utilized, it is recommended to configure the northbridge-southbridge link in x1 in order to reduce power consumption.

There are two methods of dynamic link width control:

- Long Reconfiguration (The link goes down and retrains to a different width)
- Up/Down Reconfiguration (PCIe 2.0 Base Specification Compliant Link Width Reconfiguration)

#### 4.4.4.1.1 Long Reconfiguration

Long reconfiguration is used with v1.1 or v1.0a PCIe specification compliant endpoint devices. This method of changing the number of active lanes causes the link to go down and is not recommended on an already active PCIe link without making sure that there is no traffic on the link during link width reconfiguration described in table below.

| Table 4-47 | Long Reco | nfiguration |
|------------|-----------|-------------|
|------------|-----------|-------------|

| ASIC Rev     | Step | Register Settings                                     | Function/Comment                      |
|--------------|------|-------------------------------------------------------|---------------------------------------|
| SR5690/5670/ | 1    | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[2:0] · PCIEIND_P:0xA2 | Sets the desired link width using the |
| 5650         |      | LC_LINK_WIDTH                                         | encoding scheme of the link width:    |
| All Revs     |      |                                                       | 000 = x16                             |
|              |      |                                                       | 001 = x1                              |
|              |      |                                                       | 010 = x2                              |
|              |      |                                                       | 011 = x4                              |
|              |      |                                                       | 100 = x8                              |
|              |      |                                                       | 101 = x12 (not supported)             |
|              |      |                                                       | 110 = x16                             |
|              |      | Set bits [2:0] to desired link width.                 | based on CMOS option selected.        |

| ASIC Rev         | Step | Register Settings                                                                                                                                                                        | Function/Comment                                                                                        |
|------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| SR5690/5670/     | 2    | Read back current link width by reading bits [6:4] of the following                                                                                                                      | This step prevents users from trying to                                                                 |
| 5650<br>All Revs |      | register:                                                                                                                                                                                | train the link to greater link width than                                                               |
|                  |      | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[6:4] · PCIEIND_P:0xA2<br>LC_LINK_WIDTH_RD                                                                                                                | maximum value limited with number of physical lanes connected on PCIE link.                             |
|                  |      | Read back intended link width by reading bits [2:0] of the same register:                                                                                                                | This step prevents users from trying to train the link in x12, and it downgrades to                     |
|                  |      | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[2:0] · PCIEIND_P:0xA2<br>LC_LINK_WIDTH                                                                                                                   | the first lower link width value supported, which is x8.                                                |
|                  |      | If the current link width is less than the intended link width based on<br>the CMOS option selected, then grey out the link width selected in the<br>CMOS option and skip this sequence. |                                                                                                         |
|                  |      | If the current link width is equal 101, then the link must be retrained to x8, and then proceed with the sequence, and in step 4 set desired link width to 100.                          |                                                                                                         |
|                  |      | If the current link width is equal to the intended link width, then skip this sequence.                                                                                                  |                                                                                                         |
|                  |      | If the current link width is greater than the intended link width, then proceed with the sequence.                                                                                       |                                                                                                         |
|                  | 3    | BIF_NB:PCIE_P_CNTL[0]=0x1 · PCIEIND:0x40                                                                                                                                                 | Enables powering down transmitter and                                                                   |
|                  |      | P_PWRDN_EN                                                                                                                                                                               | receiver pads along with PLL macros.                                                                    |
|                  |      | Set bit [0] to 0x1.                                                                                                                                                                      | For AMD graphics devices only.                                                                          |
|                  |      | In the proprietary register space of the AMD graphics card located behind the device that is initiating reconfiguration, set:                                                            |                                                                                                         |
|                  |      | BIF:PCIE_P_CNTL[0]=0x0 · PCIEIND:0xB0<br>P_PWRDN_EN                                                                                                                                      |                                                                                                         |
|                  |      | Set bit [0] to 0x0.                                                                                                                                                                      |                                                                                                         |
| -                | 4    | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[7]=0x1 · PCIEIND_P:0xA2<br>LC_RECONFIG_ARC_MISSING_ESCAPE                                                                                                | For Long Reconfiguration shorten the timeout from Recovery.Idle to Detect                               |
|                  |      | Set bit [7] to 0x1.                                                                                                                                                                      |                                                                                                         |
| -                | 5    | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[8]=0x1 · PCIEIND_P:0xA2<br>LC_RECONFIG_NOW                                                                                                               | Starts reconfiguration.                                                                                 |
| -                |      | Set bit [8] to 0x1.                                                                                                                                                                      |                                                                                                         |
|                  | 6    | BIF_NBP:LINK_STATUS[11] · pcieConfigDev*:0x6a<br>LINK_TRAINING                                                                                                                           | Ensures that link training is completed.<br>Hardware clears this bit once link training<br>is complete. |
|                  |      | Poll bit [11] until 0x0.                                                                                                                                                                 |                                                                                                         |
|                  | 7    | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[8] · PCIEIND_P:0xA2<br>LC_RECONFIG_NOW                                                                                                                   | Ensures that reconfiguration is completed. Hardware clears this bit once                                |
|                  |      |                                                                                                                                                                                          | reconfiguration is complete.                                                                            |
|                  | 8    |                                                                                                                                                                                          | Ensures that virtual channel negotiation                                                                |
|                  | 0    | BIF_NBP:PCIE_VC0_RESOURCE_STATUS[1]<br>· pcieConfigDev*:0x12a<br>VC_NEGOTIATION_PENDING                                                                                                  | is done.                                                                                                |
|                  |      | 1                                                                                                                                                                                        |                                                                                                         |

# Table 4-47 Long Reconfiguration (Continued)

| ASIC Rev             | Step | Register Settings                                                                                                                                  | Function/Comment                                                                                      |
|----------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 | 9    | Link width change is completed.                                                                                                                    | Unused lanes should be powered off.<br>Follow steps for powering down unused                          |
| All Revs             |      | Power down unused lanes.                                                                                                                           | lanes described in <i>Section 4.4.2</i><br>"PCIe® Cores Initialization" on<br>page 4-19               |
|                      | 10   | BIF_NB:PCIE_P_CNTL[0]=0x0 · PCIEIND:0x40<br>P_PWRDN_EN<br>Clear bit [0] to 0x0.                                                                    | Disables powering down transmitter and receiver pads along with PLL macros.                           |
|                      |      | On the AMD end points, behind the device initiating reconfiguration:<br>BIF:PCIE_P_CNTL[0]=0x1 · PCIEIND:0xB0<br>P_PWRDN_EN<br>Set bit [0] to 0x1. | For AMD graphics cards only in dual<br>PCIE-GPP1 or PCIE- GPP2<br>configuration.                      |
|                      | 11   | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[7]=0x0 · PCIEIND_P:0xA2<br>LC_RECONFIG_ARC_MISSING_ESCAPE                                                          | Clears the register which shortens the timeout from Recovery.Idle to Detect for Long Reconfiguration. |
|                      |      | Clear bit [7] to 0x0.                                                                                                                              |                                                                                                       |

#### Table 4-47 Long Reconfiguration (Continued)

#### 4.4.4.1.2 Up/Down Reconfiguration

Up/Down Reconfiguration is feasible only with PCIe 2.0 Base Specification compliant endpoint devices. To allow PCIe link to train to a shorter link width than that defined with the numbers of physical lanes connected in the link, follow the programming sequence specified below.

| ASIC Rev    | Step | Register Settings                                                                          | Function/Comment                      |
|-------------|------|--------------------------------------------------------------------------------------------|---------------------------------------|
| SR5690/5670 | 1    | Read back bit [9] of the following register:                                               | Checks if the endpoint device         |
| /5650       |      | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[9] · PCIEIND_P:0xA2                                        | supports Up/Down Reconfiguration.     |
| All Revs    |      | LC_RENEGOTIATION_SUPPORT                                                                   |                                       |
|             |      | If the read back value of bit [9] is 0x0, then skip this sequence; otherwise go to step 2. |                                       |
|             |      | BIF NBP:PCIE LC LINK WIDTH CNTL[12]=0x1 · PCIEIND P:0xA2                                   | Advertises support for Up/Down        |
|             |      | LC_UPCONFIGURE_SUPPORT                                                                     | Reconfiguration.                      |
|             |      | Set bit [12] to 1.                                                                         |                                       |
|             | 3    | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[2:0] · PCIEIND_P:0xA2                                      | Sets the desired link width using the |
|             |      | LC_LINK_WIDTH                                                                              | encoding scheme:                      |
|             |      |                                                                                            | 000 = x16                             |
|             |      |                                                                                            | 001 = x1                              |
|             |      |                                                                                            | 010 = x2                              |
|             |      |                                                                                            | 011 = x4                              |
|             |      |                                                                                            | 100 = x8                              |
|             |      |                                                                                            | 101 = x12 (not supported)             |
|             |      |                                                                                            | 110 = x16                             |
|             |      | Set bits [2:0] to desired link width.                                                      | based on CMOS option selected.        |

| ASIC Rev                         | Step | Register Settings                                                                                                                                                                  | Function/Comment                                                                                              |
|----------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| SR5690/5670<br>/5650<br>All Revs | 4    | Read back current link width by reading bits [6:4] of the following register:<br>BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[6:4] · PCIEIND_P:0xA2<br>LC_LINK_WIDTH_RD                         | to train the link to greater link width than maximum value limited by the                                     |
|                                  |      | Read back intended link width by reading bits [2:0] of the same register:<br>BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[2:0] · PCIEIND_P:0xA2<br>LC_LINK_WIDTH                                | number of physical lanes<br>connected on PCIE link.<br>This step prevents users from trying                   |
|                                  |      | If the current link width is less than the intended link width based on the CMOS option selected, then grey out the link width selected in the CMOS option and skip this sequence. | to train the link in x12, and it<br>downgrades to the first lower link<br>width value supported, which is x8. |
|                                  |      | If the current link width is equal to 3'b101, the link must be retrained to x8, and then proceed with the sequence, and in step 4 set desired link width to 3'b100.                |                                                                                                               |
|                                  |      | If the current link width is equal to the intended link width, skip this sequence.                                                                                                 |                                                                                                               |
|                                  |      | If the current link width is greater than intended link width, then proceed with the sequence.                                                                                     |                                                                                                               |
|                                  | 5    | For AMD end point only, in the proprietary register space of AMD graphics<br>device:<br>BIF_NBP:PCIE_LC_CNTL2[23]=0x1· PCIEIND_P:0xB1<br>LC_WAIT_FOR_LANES_IN_LW                   | Makes ConfigStep2-2b timeout 1us.                                                                             |
|                                  |      | Set bit [23] to 0x1.                                                                                                                                                               |                                                                                                               |
|                                  | 6    | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[10]=0x1 · PCIEIND_P:0xA2<br>LC_RENEGOTIATE_EN                                                                                                      | Enables Up/Down Reconfiguration                                                                               |
|                                  | 7    | Set bit [10] to 0x1.<br>BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[8]=0x1 · PCIEIND_P:0xA2                                                                                                    | Starts Up/Down Reconfiguration                                                                                |
|                                  |      | LC_RECONFIG_NOW<br>Set bit [8] to 0x1.                                                                                                                                             |                                                                                                               |

Table 4-48 Up/Down Reconfiguration (Continued)

# 4.4.5 Static PCIe<sup>®</sup> Port Power Down Control

- Step 18: Static PCIe Port Power Down Control
  - Step 18.1: Instructions for Non-Connected GPP1/GPP2 REFCLK

#### Table 4-49 Instructions for Non-Connected GPP1/GPP2 REFCLK

| ASIC Rev     | Step | Register Settings                             | Function/Comment                                 |
|--------------|------|-----------------------------------------------|--------------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_PDNB_CNTL[0] = 0x1 · NBMISCIND:0x7 | This step must be performed for any design where |
| 5650         |      | TXCLK_OFF_GPP1                                | GPP1_REFCLK is not connected at the platform     |
| All Revs     |      | Set bit [0] to 0x1.                           | level.                                           |
|              | 2    | NBCFG:PCIE_PDNB_CNTL[1] = 0x1 · NBMISCIND:0x7 | This step must be performed for SR5650, and any  |
|              |      | TXCLK_OFF_GPP2                                | SR5690/SR5670 design where GPP2_REFCLK is        |
|              |      | Set bit [1] to 0x1.                           | not connected at the platform level.             |

• Step 18.2: PCIE-GPP1 Port 0 (Device 2) Power Down Control – Single/Dual PCIE-GPP1 Link Configuration

#### Table 4-50 PCIE-GPP1 Port 0 (Device 2) Power Down Control Programming Sequence

| ASIC Rev     | Step | Register Settings                                                                                             | Function/Comment                 |
|--------------|------|---------------------------------------------------------------------------------------------------------------|----------------------------------|
| SR5690/5670/ | 1    | If link width is x8 in PCIE- GPP1 Single Configuration, and Lane Reversal                                     |                                  |
| 5650         |      | is NOT enabled in CMOS:                                                                                       | Turns off PLL1.                  |
| All Revs     |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0] = 0xF0F0 ·PCIEIND:0x65                                                      |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [1] = 0x1 · NBMISCIND:0x23                                                              |                                  |
|              |      | B_PPLL_PDNB_FDIS[1]                                                                                           |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [3] = 0x1 · NBMISCIND:0x23                                                              |                                  |
|              |      | B_PPLL_BUF_PDNB_FDIS[1]                                                                                       |                                  |
|              | 2    | If link width is x8 in PCIE- GPP1 Single Configuration, and Lane Reversal                                     | Turns off Tx/RX PADs for Ln0-7   |
|              |      | is enabled:                                                                                                   | Turns off PLL0 for Lane Reversed |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0x0F0F · PCIEIND:0x65<br>Turn off PLL0:                                    | PCIE-GPP1 Single Configuration.  |
|              |      | NBCFG:PCIE_NBCFG_REGB [0]=0x1 · NBMISCIND:0x23                                                                |                                  |
|              |      | B_PPLL_PDNB_FDIS[0]                                                                                           |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [2]=0x1 · NBMISCIND:0x23                                                                |                                  |
|              |      | B_PPLL_BUF_PDNB_FDIS[0]                                                                                       |                                  |
|              | 3    | If link width is x4 in PCIE- GPP1 Single Configuration, and Lane Reversal                                     |                                  |
|              |      | is NOT enabled in CMOS:                                                                                       | Turns off PLL1 in PCIE-GPP1      |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0xFCFC · PCIEIND:0x65                                                      | Single Configuration.            |
|              |      | For PCIE-GPP1 Single configuration, turn off PLL1:                                                            |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [1]=0x1 · NBMISCIND:0x23                                                                |                                  |
|              |      | B_PPLL_PDNB_FDIS[1]                                                                                           |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [3]=0x1 · NBMISCIND:0x23                                                                |                                  |
|              |      | B_PPLL_BUF_PDNB_FDIS[1]                                                                                       |                                  |
|              | 4    | If link width is x4 in PCIE-GPP1 Dual Configuration, and Lane Reversal is                                     | Turns off Tx/RX PADs for Ln4-7   |
|              |      | NOT enabled in CMOS:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0xC · PCIEIND:0x65                                  |                                  |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0xC · PCIEIND:0x05<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0xC · PCIEIND:0x65 |                                  |
|              | 5    | If Llink width is x4 in PCIE- GPP1 Single Configuration, and Lane Reversal                                    | Turns off Tx/RX PADs for Ln0-11. |
|              |      | is enabled in CMOS:                                                                                           | Turns off PLL0 for Lane Reversed |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0x3F3F · PCIEIND:0x65                                                      | PCIE-GPP1 Single Configuration.  |
|              |      | Turn off PLL0:                                                                                                |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [0]=0x1 · NBMISCIND:0x23                                                                |                                  |
|              |      |                                                                                                               |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [2]=0x1 · NBMISCIND:0x23<br>B_PPLL_BUF_PDNB_FDIS[0]                                     |                                  |
|              |      |                                                                                                               |                                  |

| ASIC Rev     | Step | Register Settings                                                           | Function/Comment                 |
|--------------|------|-----------------------------------------------------------------------------|----------------------------------|
| SR5690/5670/ | 6    | If link width is x4 in PCIE- GPP1 Dual Configuration, and Lane Reversal is  | Turns off Tx/RX PADs for Ln0-3.  |
| 5650         |      | enabled in CMOS:                                                            |                                  |
| All Revs     |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0x3 · PCIEIND:0x65                        |                                  |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0x3 · PCIEIND:0x65                       |                                  |
| -            | 7    | If link width is x2 in PCIE-GPP1 Single Configuration, and Lane Reversal is |                                  |
|              |      | NOT enabled in CMOS:                                                        | Turns off PLL1 in PCIE-GPP1      |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0xFEFE · PCIEIND:0x65                    | Single Configuration.            |
|              |      | For PCIE-GPP1 Single configuration, turn off PLL1:                          |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [1]=0x1 · NBMISCIND:0x23                              |                                  |
|              |      | B_PPLL_PDNB_FDIS[1]                                                         |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [3]=0x1 · NBMISCIND:0x23                              |                                  |
|              |      | B_PPLL_BUF_PDNB_FDIS[1]                                                     |                                  |
|              | 8    | If link width is x2 in PCIE- GPP1 Dual Configuration, and Lane Reversal is  | Turns off Tx/RX PADs for Ln2-7   |
|              |      | NOT enabled in CMOS:                                                        |                                  |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0xE · PCIEIND:0x65                        |                                  |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0xE · PCIEIND:0x65                       |                                  |
|              | 9    |                                                                             | Turns off Tx/RX PADs for Ln0-13. |
|              |      | is enabled in CMOS:                                                         | Turns off PLL1 in PCIE-GPP1      |
|              |      |                                                                             | Single Configuration.            |
|              |      |                                                                             | Turns off PLL0 for Lane Reversed |
|              |      | NBCFG:PCIE_NBCFG_REGB [0]=0x1 · NBMISCIND:0x23                              | PCIE-GPP1 Single Configuration.  |
|              |      | B_PPLL_PDNB_FDIS[0]<br>NBCFG:PCIE_NBCFG_REGB [2]=0x1 · NBMISCIND:0x23       |                                  |
|              |      | B_PPLL_BUF_PDNB_FDIS[0]                                                     |                                  |
| -            | 10   | If link width is x2 in PCIE- GPP1 Dual Configuration, and Lane Reversal is  | Turns off Ty/RX PADs for L n0-5  |
|              | 10   | enabled in CMOS:                                                            |                                  |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0x7 · PCIEIND:0x65                        |                                  |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0x7 · PCIEIND:0x65                       |                                  |
| -            | 11   |                                                                             | Powers down PLLs for PCIE-GPP1   |
|              |      | down if no device is detected or link training cannot be completed:         | and switch to reference clock.   |
|              |      | This step and should also be executed for SR5650 always.                    |                                  |
|              |      | This step should also be executed if GPP1_REFCLK is not connected at        |                                  |
|              |      | the platform level.                                                         |                                  |
|              |      | NBCFG:PCIE_NBCFG_REGB [3:0]=0xF · NBMISCIND:0x23                            |                                  |
|              | 12   | For PCIE-GPP1 Dual Configuration, Port 0 can be completely powered          | Powers down Tx/Rx pads for       |
|              |      | down if no device is detected or link training can not be completed:        | PCIE-GPP1                        |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0xFFFF · PCIEIND:0x65                    |                                  |
| [            | 13   |                                                                             | Powers Down Port 0 in PCIE-GPP1  |
|              |      | <b>a</b> 1                                                                  | Dual Configuration               |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0xF · PCIEIND:0x65                        |                                  |
|              |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0xF · PCIEIND:0x65                       |                                  |
|              |      | NOTE: PLL0 cannot be shut down as PCIE-GPP1 core needs clocks from          |                                  |
|              |      | PLLO.                                                                       |                                  |

Table 4-50 PCIE-GPP1 Port 0 (Device 2) Power Down Control Programming Sequence (Continued)

• Step 18.3: PCIE-GPP1 Port 1 (Device3) Power Down Control – Dual PCIE-GPP1 Configuration

| ASIC Rev                         | Step                    | Register Settings                                                                                                                                                                                                                                                                                                              | Function/Comment                  |
|----------------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| SR5690/5670<br>/5650<br>All Revs | is NOT enabled in CMOS: |                                                                                                                                                                                                                                                                                                                                | Turns off Tx/RX PADs for Ln13-15  |
|                                  |                         | BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]= 0xC · PCIEIND:0x65<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0xC · PCIEIND:0x65                                                                                                                                                                                                                 |                                   |
|                                  | 2                       | If link width is x4 in PCIE-GPP1 Dual Configuration, and Lane Reversal<br>is enabled in CMOS:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]= 0x3 · PCIEIND:0x65<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0x3 · PCIEIND:0x65                                                                                                                | Turns off Tx/RX PADs for Ln8-11.  |
|                                  | 3                       | If link width is x2 in PCIE-GPP1 Dual Configuration, and Lane Reversal<br>is NOT enabled in CMOS:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]= 0xE · PCIEIND:0x65<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0xE · PCIEIND:0x65                                                                                                            | Turns off Tx/RX PADs for Ln11-15. |
|                                  | 4                       | If link width is x2 in PCIE-GPP1 Dual Configuration, and Lane Reversal<br>is enabled in CMOS:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]= 0x7 · PCIEIND:0x65<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0x7 · PCIEIND:0x65                                                                                                                | Turns off Tx/RX PADs for Ln8-13.  |
|                                  | 5                       | Port 1 can be completely powered down if no device is detected or link<br>training can not be completed:<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]= 0xF · PCIEIND:0x65<br>BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0xF · PCIEIND:0x65<br>NBCFG:PCIE_NBCFG_REGB [1]=0x1 · NBMISCIND:0x23<br>NBCFG:PCIE_NBCFG_REGB [3]=0x1 · NBMISCIND:0x23 | Powers Down PCIE-GPP1 Port B.     |

#### Table 4-51 PCIE-GPP1 Port 1 (Device 3) Power Down Control Programming Sequence

#### • Step 18.4: PCIE-GPP2 Port 0 (Device11) Power Down Control – Single/Dual PCIE-GPP2 Configuration

#### Table 4-52 PCIE-GPP2 Port 0 (Device 11) Power Down Control Programming Sequence

| ASIC Rev    | Step | Register Settings                                                           | Function/Comment                |
|-------------|------|-----------------------------------------------------------------------------|---------------------------------|
| SR5690/5670 | 1    | If link width is x8 in PCIE-GPP2 Single Configuration, and Lane Reversal    | Turns of Tx/RX PADs for Ln8-15. |
| All Revs    |      | is NOT enabled in CMOS:                                                     | Turns off PLL1.                 |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0xF0F0 PCIEIND:0x65                      |                                 |
|             |      | NBCFG:PCIE_NBCFG_REGB [9]=0x1 · NBMISCIND:0x23                              |                                 |
|             |      | B_PPLL_PDNB_FDIS[1]                                                         |                                 |
|             |      | NBCFG:PCIE_NBCFG_REGB [11]=0x1 · NBMISCIND:0x23                             |                                 |
|             |      | B_PPLL_BUF_PDNB_FDIS[1]                                                     |                                 |
|             |      | NOTE: This step is not applicable to SR5670.                                |                                 |
|             | 2    | If link width is x8 in PCIE-GPP2 Single Configuration, and Lane Reversal is | Turns off Tx/RX PADs for Ln 0-7 |
|             |      | enabled:                                                                    | Turnsoff PLL0 if PCIE-GPP2      |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0x0F0F PCIEIND:0x65                      | Lane Reversal enabled.          |
|             |      | NOTE: This step is not applicable to SR5670.                                |                                 |
|             |      | Turn off PLL0:                                                              | Turns off PLL0 for Lane         |
|             |      | NBCFG:PCIE_NBCFG_REGB [8]=0x1 · NBMISCIND:0x23                              | Reversed PCIE-GPP2 Single       |
|             |      | B_PPLL_PDNB_FDIS[0]                                                         | Configuration.                  |
|             |      | NBCFG:PCIE_NBCFG_REGB [10]=0x1 · NBMISCIND:0x23                             |                                 |
|             |      | B_PPLL_BUF_PDNB_FDIS[0]                                                     |                                 |
|             |      | NOTE: This step is not applicable to SR5670.                                |                                 |

| ASIC Rev    | Step | Register Settings                                                           | Function/Comment                |
|-------------|------|-----------------------------------------------------------------------------|---------------------------------|
| SR5690/5670 | 3    | If link width is x4 in PCIE-GPP2 Single Configuration, and Lane Reversal is | Turns off Tx/RX PADs for        |
| All Revs    |      | NOT enabled in CMOS:                                                        | Ln5-15.                         |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0xFCFC · PCIEIND:0x65                    | Turns off PLL1 in PCIE-GPP2     |
|             |      |                                                                             | Single Configuration.           |
|             |      | For PCIE-2GPP2 Single configuration, turn off PLL1:                         |                                 |
|             |      | NBCFG:PCIE_NBCFG_REGB [9]=0x1 · NBMISCIND:0x23                              |                                 |
|             |      | B_PPLL_PDNB_FDIS[1]                                                         |                                 |
|             |      | NBCFG:PCIE_NBCFG_REGB [11]=0x1 · NBMISCIND:0x23                             |                                 |
|             |      | B_PPLL_BUF_PDNB_FDIS[1]                                                     |                                 |
|             |      | NOTE: This step is not applicable to SR5670.                                |                                 |
|             | 4    | If link width is x4 in PCIE-GPP2 Dual Configuration, and Lane Reversal is   | Turns off Tx/RX PADs for Ln4-7  |
|             |      | NOT enabled in CMOS:                                                        |                                 |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0xC · PCIEIND:0x65                        |                                 |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0xC · PCIEIND:0x65                       |                                 |
|             | 5    | If link width is x4 in PCIE-GPP2 Single Configuration, and Lane Reversal is | Turns off Tx/RX PADs for Ln0-11 |
|             |      | enabled in CMOS:                                                            | Turns off PLL0 in PCIE-GPP2     |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0x3F3F · PCIEIND:0x65                    | Single Configuration.           |
|             |      | NOTE: This step is not applicable to SR5670.                                | 5 5                             |
|             |      |                                                                             |                                 |
|             |      | Turn off PLL0:                                                              | Turns off PLL0 for Lane         |
|             |      | NBCFG:PCIE_NBCFG_REGB [8]=0x1 · NBMISCIND:0x23                              | Reversed PCIE-GPP2 Single       |
|             |      | B PPLL PDNB FDIS[0]                                                         | Configuration.                  |
|             |      | NBCFG:PCIE_NBCFG_REGB [10]=0x1 · NBMISCIND:0x23                             | <b>3 1 1</b>                    |
|             |      | B_PPLL_BUF_PDNB_FDIS[0]                                                     |                                 |
|             |      | NOTE: This step is not applicable to SR5670.                                |                                 |
|             | 6    | If link width is x4 in PCIE-GPP2 Dual Configuration and Lane Reversal is    | Turns off Tx/RX PADs for Ln0-3. |
|             | -    | enabled in CMOS:                                                            |                                 |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0x3 · PCIEIND:0x65                        |                                 |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0x3 · PCIEIND:0x65                       |                                 |
|             | 7    | If Link width is x2 in PCIE-GPP2 Single Configuration, and Lane Reversal    | Turns off Tx/RX PADs for        |
|             |      | is NOT enabled in CMOS:                                                     | Ln2-15.                         |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0xFEFE · PCIEIND:0x65                    | Turns off PLL1 in PCIE-GPP2     |
|             |      |                                                                             | Single Configuration.           |
|             |      | For PCIE-2GPP2 Single configuration, turn off PLL1:                         |                                 |
|             |      | NBCFG:PCIE_NBCFG_REGB [9]=0x1 · NBMISCIND:0x23                              |                                 |
|             |      | B_PPLL_PDNB_FDIS[1]                                                         |                                 |
|             |      | NBCFG:PCIE_NBCFG_REGB [11]=0x1 · NBMISCIND:0x23                             |                                 |
|             |      | B_PPLL_BUF_PDNB_FDIS[1]                                                     |                                 |
|             |      | NOTE: This step is not applicable to SR5670.                                |                                 |
|             | 8    | If link width is x2 in PCIE-GPP2 Dual Configuration, and Lane Reversal is   | Turns off Tx/RX PADs for Ln2-7  |
|             | U U  | NOT enabled in CMOS:                                                        |                                 |
|             |      | BIF NB:PCIE P PAD FORCE DIS[3:0]= 0xE· PCIEIND:0x65                         |                                 |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0xE+ PCIEIND:0x65                        |                                 |
|             | 9    | If link width is x2 in PCIE-GPP2 Single Configuration, and Lane Reversal is | Turns off Tx/RX PADs for        |
|             | 5    | enabled in CMOS:                                                            | Ln0-13.                         |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0x7F7F · PCIEIND:0x65                    | Turns off PLL0 in PCIE-GPP2     |
|             |      | NOTE: This step is not applicable to SR5670.                                | Single Configuration.           |
|             |      | Turn off PLL0:                                                              |                                 |
|             |      | NBCFG:PCIE_NBCFG_REGB [8]=0x1 · NBMISCIND:0x23                              | Turns off PLL0 for Lane         |
|             |      | B_PPLL_PDNB_FDIS[0]                                                         | Reversed PCIE-GPP2 Single       |
|             |      | NBCFG:PCIE_NBCFG_REGB [10]=0x1 · NBMISCIND:0x23                             | Configuration.                  |
|             |      | B_PPLL_BUF_PDNB_FDIS[0]                                                     |                                 |
|             |      | NOTE: This step is not applicable to SR5670.                                |                                 |
|             |      | $[10 T \square. THIS STEP IS HOL APPRICADE TO STOUT U.$                     | l                               |

| ASIC Rev    | Step | Register Settings                                                         | Function/Comment                |
|-------------|------|---------------------------------------------------------------------------|---------------------------------|
| SR5690/5670 | 10   | If link width is x2 in PCIE-GPP2 Dual Configuration, and Lane Reversal is | Turns off Tx/RX PADs for Ln0-5. |
| All Revs    |      | enabled in CMOS:                                                          |                                 |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0x7 · PCIEIND:0x65                      |                                 |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0x7 · PCIEIND:0x65                     |                                 |
|             | 11   | For PCIE-GPP2 Single Configuration, Port 0 can be completely powered      | Powers down PLL for             |
|             |      | down if no device is detected or link training cannot be completed:       | PCIE-GPP2 and switch to         |
|             |      | This step should also be executed for SR5650 always.                      | reference clock                 |
|             |      | This step should also be executed for SR5690 and SR5670 if                |                                 |
|             |      | GPP2_REFCLK is not connected at the platform level.                       |                                 |
|             |      | NBCFG:PCIE_NBCFG_REGB [11:8]=0xF · NBMISCIND:0x23                         |                                 |
|             | 12   | For PCIE-GPP2 Single Configuration, Port 0 can be completely powered      | Powers down Tx/Rx pads for      |
|             |      | down if no device is detected or link training cannot be completed:       | PCIE-GPP2                       |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0]= 0xFFFF · PCIEIND:0x65                  |                                 |
|             | 13   | For PCIE-GPP2 Dual Configuration, Port 0 can be completely powered        | Powers down Port 0 in           |
|             |      | down if no device is detected or link training cannot be completed:       | PCIE-GPP2 Dual Configuration    |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[3:0]= 0xF · PCIEIND:0x65                      |                                 |
|             |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[11:8]= 0xF · PCIEIND:0x65                     |                                 |
|             |      | NOTE: PLL0 can not be shut down as PCIE-GPP2 core needs clocks from       |                                 |
|             |      | PLL0.                                                                     |                                 |

#### Table 4-52 PCIE-GPP2 Port 0 (Device 11) Power Down Control Programming Sequence (Continued)

#### • Step 18.5: PCIE-GPP2 Port 1 (Device 12) Power Down Control – Dual PCIE-GPP2 Configuration

[NOTE: This section is not applicable to SR5670 and SR5650]

| ASIC Rev | Step | Register Settings                                                      | Function/Comment                  |
|----------|------|------------------------------------------------------------------------|-----------------------------------|
| SR5690   | 1    | If link width is x4 in PCIE-GPP2 Dual Configuration, and Lane Reversal | Turns off Tx/RX PADs for Ln13-15  |
| All Revs |      | is NOT enabled in CMOS:                                                |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]=0xC · CIEIND:0x65                     |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0xC · PCIEIND:0x65                 |                                   |
|          | 2    | If link width is x4 in PCIE-GPP2 Dual Configuration, and Lane Reversal | Turns off Tx/RX PADs for Ln8-11.  |
|          |      | is enabled in CMOS:                                                    |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]= 0x3 · PCIEIND:0x65                   |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0x3 · PCIEIND:0x65                 |                                   |
|          | 3    | If link width is x2 in PCIE-GPP2 Dual Configuration, and Lane Reversal | Turns off Tx/RX PADs for Ln11-15. |
|          |      | is NOT enabled in CMOS:                                                |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]= 0xE · PCIEIND:0x65                   |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0xE · PCIEIND:0x65                 |                                   |
|          | 4    | If link width is x2 in PCIE-GPP2 Dual Configuration, and Lane Reversal | Turns off Tx/RX PADs for Ln8-13.  |
|          |      | is enabled in CMOS:                                                    |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]= 0x7 · PCIEIND:0x65                   |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0x7 · PCIEIND:0x65                 |                                   |
|          | 5    | Port 1 can be completely powered down if no device is detected or link | Powers Down PCIE-GPP2 Port 1.     |
|          |      | training cannot be completed:                                          |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[7:4]= 0xF · PCIEIND:0x65                   |                                   |
|          |      | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:12]= 0xF · PCIEIND:0x65                 |                                   |
|          |      | NBCFG:PCIE_NBCFG_REGB [9]=0x1 · NBMISCIND:0x23                         |                                   |
|          |      | NBCFG:PCIE_NBCFG_REGB [11]=0x1 · NBMISCIND:0x23                        |                                   |

#### Table 4-53 PCIE-GPP2 Port 1 (Device12) Power Down Control Programming Sequence

#### • Step 18.6: PCIE-GPP3a Port 0 Power Down Control

If one or more PCIE-GPP3a Port 0 lanes are not used in the system, SBIOS can power down those lanes to save power. Refer to table below.

#### Table 4-54 Power Down Unused Lanes for PCIE-GPP3a Port 0

| PCIE-GPP3a Configuration | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0] · PCIEIND:0x65   |
|--------------------------|----------------------------------------------------|
| 1:1:1:1:1                | Turns off Tx/RX PADs for Ln0:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[0]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[8]=0x1 · PCIEIND:0x65  |
| 4:2:0:0:0:0              | Turns off Tx/RX PADs for Ln0:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[0]=0xF · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[8]=0xF · PCIEIND:0x65  |
|                          | Turns off Tx/RX PADs for Ln1:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[1]=0xF · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[9]=0xF · PCIEIND:0x65  |
|                          | Turns off Tx/RX PADs for Ln2:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[2]=0xF · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[10]=0xF · PCIEIND:0x65 |
|                          | Turns off Tx/RX PADs for Ln3:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[3]=0xF · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[11]=0xF · PCIEIND:0x65 |

| PCIE-GPP3a Configuration | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0] · PCIEIND:0x65   |
|--------------------------|----------------------------------------------------|
| 4:1:1:0:0:0              | Turns off Tx/RX PADs for Ln0:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[0]=0xf · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[8]=0xf · PCIEIND:0x65  |
|                          | Turns off Tx/RX PADs for Ln1:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[1]=0xF · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[9]=0xF · PCIEIND:0x65  |
|                          | Turns off Tx/RX PADs for Ln2:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[2]=0xF · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[10]=0xF · PCIEIND:0x65 |
|                          | Turns off Tx/RX PADs for Ln3:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[3]=0xF · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[11]=0xF · PCIEIND:0x65 |
| 2:2:2:0:0:0              | Turns off Tx/RX PADs for Ln0:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[0]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[8]=0x3 · PCIEIND:0x65  |
|                          | Turns off Tx/RX PADs for Ln1:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[1]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[9]=0x3 · PCIEIND:0x65  |
| 2:2:1:1:0:0              | Turns off Tx/RX PADs for Ln0:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[0]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[8]=0x3 · PCIEIND:0x65  |
|                          | Turns off Tx/RX PADs for Ln1:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[1]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[9]=0x3 · PCIEIND:0x65  |
| 2:1:1:1:0                | Turns off Tx/RX PADs for Ln0:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[0]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[8]=0x3 · PCIEIND:0x65  |
|                          | Turns off Tx/RX PADs for Ln1:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[1]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[9]=0x3 · PCIEIND:0x65  |

#### Table 4-54 Power Down Unused Lanes for PCIE-GPP3a Port 0 (Continued)

#### • Step 18.7: PCIE-GPP3a Port 1 Power Down Control

If one or more PCIE-GPP3a Port 1 lanes are not used in the system, SBIOS can power down those lanes to save power. Refer to table below.

#### Table 4-55 Power Down Unused Lanes for PCIE-GPP Port 1

| PCIE-GPP3a Configuration | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0] · PCIEIND:0x65   |
|--------------------------|----------------------------------------------------|
| 1:1:1:1:1                | Turns off Tx/RX PADs for Ln1:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[1]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[9]=0x1 · PCIEIND:0x65  |
| 4:2:0:0:0:0              | Turns off Tx/RX PADs for Ln4:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[4]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[12]=0x3 · PCIEIND:0x65 |
|                          | Turns off Tx/RX PADs for Ln5:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[5]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[13]=0x3 · PCIEIND:0x65 |
| 4:1:1:0:0:0              | Turns off Tx/RX PADs for Ln4:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[4]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[12]=0x1 · PCIEIND:0x65 |

| PCIE-GPP3a Configuration | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0] · PCIEIND:0x65   |
|--------------------------|----------------------------------------------------|
| 2:2:2:0:0:0              | Turns off Tx/RX PADs for Ln2:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[2]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[10]=0x3 · PCIEIND:0x65 |
|                          | Turns off Tx/RX PADs for Ln3:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[3]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[11]=0x3 · PCIEIND:0x65 |
| 2:2:1:1:0:0              | Turns off Tx/RX PADs for Ln2:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[2]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[10]=0x3 · PCIEIND:0x65 |
|                          | Turns off Tx/RX PADs for Ln2-3:                    |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[3]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[11]=0x3 · PCIEIND:0x65 |
| 2:1:1:1:0                | Turns off Tx/RX PADs for Ln2:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[2]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[10]=0x1 · PCIEIND:0x65 |

### Table 4-55 Power Down Unused Lanes for PCIE-GPP Port 1 (Continued)

#### • Step 18.8: PCIE-GPP3a Port 2 Power Down Control

If one or more PCIE-GPP3a Port 2 lanes are not used in the system, SBIOS can power down those lanes to save power. Refer to table below.

| PCIE-GPP3a Configuration | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0] · PCIEIND:0x65   |
|--------------------------|----------------------------------------------------|
| 1:1:1:1:1                | Turns off Tx/RX PADs for Ln2:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[2]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[10]=0x1 · PCIEIND:0x65 |
| 4:2:0:0:0:0              | N/A                                                |
| 4:1:1:0:0:0              | Turns off Tx/RX PADs for Ln5:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[5]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[13]=0x1 · PCIEIND:0x65 |
| 2:2:2:0:0:0              | Turns off Tx/RX PADs for Ln4:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[4]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[12]=0x3 · PCIEIND:0x65 |
|                          | Turns off Tx/RX PADs for Ln5:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[5]=0x3 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[13]=0x3 · PCIEIND:0x65 |
| 2:2:1:1:0:0              | Turns off Tx/RX PADs for Ln4:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[4]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[12]=0x1 · PCIEIND:0x65 |
| 2:1:1:1:1:0              | Turns off Tx/RX PADs for Ln3:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[3]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[11]=0x1 · PCIEIND:0x65 |

#### • Step 18.9: PCIE-GPP3a Port 3 Power Down Control

If one or more PCIE-GPP3a Port 3 lanes are not used in the system, SBIOS can power down those lanes to save power. Refer to the table below.

| PCIE-GPP3a Configuration | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0] · PCIEIND:0x65   |
|--------------------------|----------------------------------------------------|
| 1:1:1:1:1                | Turns off Tx/RX PADs for Ln3:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[3]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[11]=0x1 · PCIEIND:0x65 |
| 4:2:0:0:0:0              | N/A                                                |
| 4:1:1:0:0:0              | N/A                                                |
| 2:2:2:0:0:0              | N/A                                                |
| 2:2:1:1:0:0              | Turns off Tx/RX PADs for Ln5:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[5]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[13]=0x1 · PCIEIND:0x65 |
| 2:1:1:1:0                | Turns off Tx/RX PADs for Ln4:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[4]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[12]=0x1 · PCIEIND:0x65 |

#### Table 4-57 Powering Down Unused Lanes for PCIE-GPP3a Port 3

#### • Step 18.10: PCIE-GPP3a Port 4 Power Down Control

If one or more PCIE-GPP3a Port 4 lanes are not used in the system, SBIOS can power down those lanes to save power. Refer to the table below.

#### Table 4-58 Power Down Unused Lanes for PCIE-GPP3a Port 4

| PCIE-GPP3a Configuration | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0] · PCIEIND:0x65   |
|--------------------------|----------------------------------------------------|
| 1:1:1:1:1                | Turns off Tx/RX PADs for Ln4:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[4]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[12]=0x1 · PCIEIND:0x65 |
| 4:2:0:0:0:0              | N/A                                                |
| 4:1:1:0:0:0              | N/A                                                |
| 2:2:2:0:0                | N/A                                                |
| 2:2:1:1:0:0              | N/A                                                |
| 2:1:1:1:0                | Turns off Tx/RX PADs for Ln5:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[5]=0x1· PCIEIND:0x65   |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[13]=0x1· PCIEIND:0x65  |

#### • Step 18.11: PCIE-GPP3a Port 5 Power Down Control

If one or more PCIE-GPP3a Port 5 lanes are not used in the system, SBIOS can power down those lanes to save power. Refer to the table below.

#### Table 4-59 Power Down Unused Lanes for PCIE-GPP3a Port 5

| PCIE-GPP3a Configuration | BIF_NB:PCIE_P_PAD_FORCE_DIS[15:0] · PCIEIND:0x65   |
|--------------------------|----------------------------------------------------|
| 1:1:1:1:1                | Turns off Tx/RX PADs for Ln5:                      |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[5]=0x1 · PCIEIND:0x65  |
|                          | BIF_NB:PCIE_P_PAD_FORCE_DIS[13]=0x1 · PCIEIND:0x65 |
| 4:2:0:0:0:0              | N/A                                                |
| 4:1:1:0:0:0              | N/A                                                |
| 2:2:2:0:0:0              | N/A                                                |
| 2:2:1:1:0:0              | N/A                                                |
| 2:1:1:1:1:0              | N/A                                                |

## • Step 18.12: Completing PCIE-GPP3a Power Down Control

Power down PLL and turn off Electrical Idle detectors when no GPP3a ports are used and no hot-plug device is supported. Refer to the table below.

Table 4-60 PCIE-GPP3a Power Down Control

| ASIC Rev     | Step | Register Settings                                                                                  | Function/Comment                         |
|--------------|------|----------------------------------------------------------------------------------------------------|------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_NBCFG_REGB [18]=0x1 · NBMISCIND:0x23                                                    | Powers down PCIE-GPP PLL when no GPP3a   |
| 5650         |      | B_PPLL_PDNB_FDIS[0] for GPP3a                                                                      | ports are used and no hot-plug device is |
| All Revs     |      | NBCFG:PCIE_NBCFG_REGB [16]=0x1 · NBMISCIND:0x23<br>B_PPLL_BUF_PDNB_FDIS[0] for GPP3a               | supported.                               |
|              | 2    | NBCFG:PCIE_NBCFG_REG7[2]=0x0 · NBMISCIND:0x37<br>B_PG2RX_IDLEDET_EN_GPP3a<br>Clear bit [2] to 0x0. | Turns off Electrical Idle Detectors.     |

#### • Step 18.13: PCIE-SB Power Down Control

#### Table 4-61 PCIE-SB Power Down Control

| ASIC Rev      | Step | Register Settings                                   | Function/Comment              |
|---------------|------|-----------------------------------------------------|-------------------------------|
| SR5690/5670/5 | 1    | Read back bit[6:4] of:                              | Encoding of LC_LINK_WIDTH_RD: |
| 650           |      | BIF_NBP:PCIE_LC_LINK_WIDTH_CNTL[6:4] PCIEIND_P:0xA2 | 000 = x16                     |
| All Revs      |      | in Dev8 to determine the current link width.        | 001 = x1                      |
|               |      |                                                     | 010 = x2                      |
|               |      | If width is $x4 \rightarrow$ skip this sequence     | 011 = x4                      |
|               |      | If width is $x2 \rightarrow go$ to Step 32.12.2     | 100 = x8                      |
|               |      | If width is $x1 \rightarrow qo$ to Step 32.12.3     | 101 = x12 (not supported)     |
|               |      |                                                     | 110 = x16                     |
|               | 2    | PCIE_P_PAD_FORCE_DIS[15:0]=0x0C0C · PCIEIND:0x65    | Powers down SB Lanes 3&2      |
|               |      | Set bits[15:0] to 0x0C0C                            |                               |
|               | 3    | PCIE_P_PAD_FORCE_DIS[15:0]=0x0E0E · PCIEIND:0x65    | Powers down SB Lanes 3-1      |
|               |      | Set bits[15:0] to 0x0E0E                            |                               |

#### • Step 18.14: PCIE-GPP3b Power Down Control

#### Table 4-62 PCIE-GPP3b Power Down Control

| ASIC Rev     | Step | Register Settings                                | Function/Comment                            |
|--------------|------|--------------------------------------------------|---------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_NBCFG_REG16[6]=0x1 · NBMISCIND:0x2E   | Powers down PCIE-GPP3b PLL when no          |
| 5650         |      | B_PPLL_PDNB_FDIS[0] for PCIE-GPP3b               | device is plugged in and no hot-plug device |
| All Revs     |      | NBCFG:PCIE_NBCFG_REGB [8]=0x1 · NBMISCIND:0x23   | is supported, or, for SR5650/SR5670, where  |
|              |      | B_PPLL_BUF_PDNB_FDIS[0] for PCIE-GPP3b           | GPP3b is not supported.                     |
|              | 2    | PCIE_P_PAD_FORCE_DIS[15:0]=0x0C0C · PCIEIND:0x65 | Powers down PCI-GPP3b Lanes 3&2             |
|              |      | Set bits[15:0] to 0x0C0C                         |                                             |
|              | 3    | PCIE_P_PAD_FORCE_DIS[15:0]=0x0E0E · PCIEIND:0x65 | Powers down PCIE-GPP3b Lanes 3-1            |
|              |      | Set bits[15:0] to 0x0E0E                         |                                             |
|              | 4    | PCIE_P_PAD_FORCE_DIS[15:0]=0x0E0E · PCIEIND:0x65 | Powers down GPP3b Lanes 3-0                 |
|              |      | Set bits[15:0] to 0x0F0F                         |                                             |
|              | 5    | NBCFG:PCIE_NBCFG_REG7[7]=0x0 · NBMISCIND:0x37    | Turns off Electrical Idle Detectors when no |
|              |      | B_PG2RX_IDLEDET_EN_GPP3b                         | GPP3b lanes are used.                       |
|              |      | Clear bit [7] to 0x0.                            |                                             |

# 4.4.6 PCIe<sup>®</sup> Enumeration and Special Features Programming Sequence

#### • Step 19: PCIe Enumeration and Special Features Programming Sequence

SBIOS scans all of the PCI buses looking for P2P bridges. When a P2P bridge is located, it is assigned bus numbers. All buses behind the bridge must reside between the secondary and subordinate bus numbers.

#### • Step 19.1: Program Common Clock Configuration

Follow the programming sequence described in the table below in order to determine common clocking configuration of components on opposite sides of each PCIe link crossing a connector and then report common clock configuration in LINK CONTROL register where applicable.

For all endpoint devices or switches integrated on the system board, SBIOS is responsible for correct programming of the Common Clock Configuration field of Link Control registers. SBIOS may reference the platform design guide specification in order to confirm common clock configuration.

| ASIC Rev                         | Step | Register Settings                                                                                                                                                                                                                                                            | Function/Comment                                                                                                                                                                                                                                                                                          |
|----------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    | the PCIE capability (PCIe Capability ID = 0x12), then read bit<br>[12] of LINK_STATUS register.<br>PCIE_LINK_STAUS[12]=0x1 · (Offset =0x12 from PCIe<br>Capability ID = 0x10).<br>SLOT_CLOCK_CFG<br>BIF_NBP:PCIE_LINK_CNTL[6]=0x1 · pcieConfigDev*:0x68                      | For each endpoint device under the root port<br>and all intervening device ports on that<br>hierarchy on the adapter, determine whether<br>the component on the adapter uses the clock<br>supplied on the slot or one generated locally<br>on the adapter.<br>In the configuration space of root port and |
|                                  |      | Follow the capability list in the device's register space to find<br>the PCIe capability (PCIe Capability $(D = 0x10)$ , then set bif[6]                                                                                                                                     | each endpoint device under the root port and<br>all intervening device ports on that hierarchy<br>for which it was found in Step1 that<br>SLOT_CLOCK_CFG= 0x1 on both sides of<br>each PCIe link, indicate common reference<br>clock configuration.                                                       |
|                                  | 3    | BIF_NBP:PCIE_LINK_CNTL[5]=0x1· pcieConfigDev*:0x68<br>RETRAIN_LINK<br>Set bit [5] to 0x1.                                                                                                                                                                                    | Re-train the link.                                                                                                                                                                                                                                                                                        |
|                                  | 4    | Read bit [11] of:<br>BIF_NBP:PCIE_LINK_STATUS[11] · pcieConfigDev*:0x6A<br>LINK_TRAINING<br>If bit [11] = 0x0, exit the loop, if not, wait 1ms and read it again.<br>If loop count = 100, exit the loop with the error flag set. This will<br>cause the bridge to be hidden. | Check whether the link has completed training.                                                                                                                                                                                                                                                            |

Table 4-63 Program Common Clock Configuration

#### • Step 19.2: Slot Power Limit

PCIe subsystem has in place software controllable mechanism to help the system control power budgeting for PCIe devices. This mechanism limits the maximum power per PCIe slot that PCIe adapter associated with that slot consumes.

System BIOS is responsible for the correct programming of Slot Power Limit Value and Slot Power Limit Scale fields of the Slot Capability registers of the downstream ports connected to the slot. After the value has been written into the register within the downstream port of root complex or switch connected to the slot, it is conveyed to the adapter using Set Slot Power Limit Message. It is then the responsibility of the device driver software associated with the adapter to configure the hardware on the adapter to guarantee that the adapter will not exceed the imposed limits.

For all endpoint devices or switches integrated on the system board, it is recommended that system BIOS reference platform design guide specification for power budget allocated to the device itself and reflects it in Slot Power Limit Message.

The programming sequence outlined in the table below should be followed to program the Slot Power Limit Value and Slot Power Limit Scale fields of the Slot Capability registers of the SR5690/5670/5650 downstream ports connected to each PCIE slot.

| ASIC Rev                         | Step | Register Settings                                                         | Function/Comment                                                                                                                                                                                                                                                                                  |
|----------------------------------|------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    | BIF_NBP:SLOT_CAP[14:7] · pcieConfigDev*:0x6c<br>SLOT_PWR_LIMIT_VALUE      | Slot Power Limit Value represents the maximum<br>power that the endpoint can draw from the PCIe<br>slot based on the maximum number of physical<br>lanes that the connector is designed for, the<br>form-factor of the card, etc. Root complex<br>convey this information to the endpoint through |
|                                  |      | BIF_NBP:SLOT_CAP[16:15]=0x0 · pcieConfigDev*:0x6c<br>SLOT_PWR_LIMIT_SCALE | Slot Power Limit Message based on the<br>programmed Slot Power Limit Value.<br>Implement x1 Multiplier.<br>Slot Power Limit Scale specifies the scale used<br>for the Slot Power Limit Value, and the available<br>range values are:                                                              |
|                                  |      | Clear bits [16:15] to 0x0.                                                | 0x0 = 1.0 x Slot Power Limit Value,<br>0x1 = 0.1 x Slot Power Limit Value,<br>0x2 = 0.01 x Slot Power Limit Value,<br>0x3 = 0.001 x Slot Power Limit Value.<br>[NOTE:<br>A write to this register will cause the Port to<br>send the Set_Slot_Power_Limit_Message, so                             |
|                                  |      |                                                                           | both fields should be set with one register write.]                                                                                                                                                                                                                                               |

Table 4-64 Slot Power Limit Programming Sequence

It is recommended that SBIOS follow the guidelines in *Table 4-65 "Recommended CEM Setting for Standard Height Add-in Card for Server I/O Applications" on page 4-75* for programming the slot power limits for each PCIe slot if standard add-in cards compliant with the PCIe Card Electromechanical (CEM) specification are used.

For all other PCIe I/O adaptors with modular form factors, system BIOS should reference appropriate electromechanical specification.

Platforms may be designed that exceed the standard power supply and cooling requirements. System BIOS may reflect this by setting the slot power limit to an appropriate value greater than the standard value.

Platforms are generally expected to be designed to support the maximum power budget for each slot simultaneously. System bios software may be developed that utilizes more advanced algorithms to more intelligently allocate power budgets based on power budgeting information from devices and by reallocating power from unused slots.

| Table 4-65 Recommended CEM Setting for Standard | d Height Add-in Card for Server I/O Applications |
|-------------------------------------------------|--------------------------------------------------|
|-------------------------------------------------|--------------------------------------------------|

| Physical Slot Width | Slot Power Limit | Notes                                                                                                                                                                                                                                                                                                                        |
|---------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| X1                  | 10W/25W          | If the platform only supports half-height cards, the<br>10W limit should be used. If both half-height and<br>full-height cards are supported, the 25W limit should<br>be used.                                                                                                                                               |
| X2/x4/x8            | 25W              |                                                                                                                                                                                                                                                                                                                              |
| X16                 | 25W/75W          | The PCIe CEM specification for x16 add-in cards<br>targeting server I/O applications provides a 25W<br>power budget. Graphics devices and stream<br>computing accelerator cards typically require/expect<br>75W from a x16 slot, and this should be the<br>advertised power budget if the platform supports such<br>devices. |

#### • Step 20: Disable Immediate Timeout on Link Down

# ASIC RevStepRegister SettingsFunction/CommentSR5690/5670/<br/>5650<br/>All Revs1BIF\_NBP:PCIE\_RX\_CNTL[19] = 0x0 PCIEIND\_P:0x70<br/>RX\_RCB\_CPL\_TIMEOUT\_MODE<br/>Clear bit [19] to 0x0.Disables immediate RCB timeout on link down

#### Table 4-66 Disabling Immediate Timeout on Link Down

#### • Step 21: Register Locking

#### Table 4-67 Register Locking Programming Sequence

| ASIC Rev                         | Step | Register Settings                                                              | Function/Comment                                     |
|----------------------------------|------|--------------------------------------------------------------------------------|------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    |                                                                                | Makes the HWINIT registers read-only for a PCIe core |
|                                  |      | NBCFG:NB_CNTL[1]=0x1 · NBMISCIND:0x0<br>HIDE_NB_AGP_CAP<br>Set bit [0] to 0x1. | Hides AGP Capabilities                               |

# • Step 22: TXCLK, LCLK Gating for any PCIe core with no PCIe links being established on initial boot up and no Hot-Plug slots implemented in platform configuration

To further reduce static power consumption, we can completely turn off TXCLK and LCLK branches going to unused PCIe cores. Each PCIe core (PCIE-GPP1, PCIE-GPP2, PCIE-GPP3a, PCIE-GPP3b) has a permanent (always-running) and dynamic (clock-gated) TXCLK and LCLK branch. When a core is not being used and no hot-plug slot is supported, both the permanent and dynamic branch to that core can be completely turned off to reduce power consumption.

The following describes the criteria and procedure for turning off PCIE TXCLK and LCLK branches. Note that the permanent LCLK branch for the PCIE-GPP1 core is also used by IOMMU and PCIE-GPP2 and PCIE-GPP3b cores, thus it can only be turned off if IOMMU is disabled and PCIE-GPP1, PCIE-GPP2 and PCIE-GPP3b are not being used.

Note: On S3 resume, all associated registers must be restored at the end of the PCIe initialization sequence, because after these registers are restored (turning off the clocks), any register access to PCIe registers will no longer take effect.

# Table 4-68 Turning off TXCLK and LCLK

| ASIC Rev                         | Step | Register Settings                                                                    | Function/Comment                                                                                                                                                                                                 |
|----------------------------------|------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 1    |                                                                                      | NOTE: This step must be performed for any design where GPP1_REFCLK is not connected at the platform level.                                                                                                       |
|                                  |      | NBCFG:PCIE_PDNB_CNTL[0]=0x1 · NBMISCIND:0x7<br>TXCLK_OFF_GPP1<br>Set bit [0] to 0x1. | Turn off TXCLK branches for PCIE-GPP1 core in<br>single port configuration when no device is<br>detected behind Device 2, or in dual port<br>configuration when no device is detected behind<br>Devices 2 and 3. |
|                                  |      | CLKCFG:CLK_TOP_SPARE_A[28]=0x1 · clkconfig:0xE0<br>Set bit [28] to 0x1.              | Turn off dynamic LCLK_GPP1 branch for<br>PCIE-GPP1 core in single port configuration<br>when no device is detected behind Device 2 or in                                                                         |
|                                  |      |                                                                                      | dual port configuration when no device is detected behind Devices 2 and 3.                                                                                                                                       |
|                                  |      | NBCFG:PCIE_NBCFG_REGF[23]=0x1 · NBMISCIND:0x27<br>Force_off_LCLK_PCIE_GPP1           | Turn off permanent LCLK_GPP1 branch for<br>PCIE-GPP1 core in single port configuration<br>when no device is detected behind Device 2 or in                                                                       |
|                                  |      | Set bit [23] to 0x1.                                                                 | dual port configuration when no device is detected behind Device s and 3.                                                                                                                                        |
|                                  |      | IOMMU_L2: L2_DEBUG_2[0]=0x1 · nbconfigfunc2:0x46                                     | Note: This permanent LCLK branch is shared<br>among PCIE-GPP1, PCIE-GPP2, PCIE-GPP3b                                                                                                                             |
|                                  |      | Set bit [0] to 0x1.                                                                  | cores and IOMMU and thus can be turned off<br>only if all these PCIE cores are not being used<br>and IOMMU is disabled.                                                                                          |
|                                  | 2    |                                                                                      | NOTE: This step must be performed for SR5650,<br>and any SR5690/SR5670 design where<br>GPP2_REFCLK is not connected at the platform<br>level.                                                                    |
|                                  |      | NBCFG:PCIE_PDNB_CNTL[1]=0x1 · NBMISCIND:0x7<br>TXCLK_OFF_GPP2                        | Turn off TXCLK braches for PCIE-GPP2 core in single port configuration when no device is detected behind Device 11or in dual port                                                                                |
|                                  |      | Set bit [1] to 0x1.                                                                  | configuration when no device is detected behind<br>Devices 11 and 12.                                                                                                                                            |
|                                  |      |                                                                                      | Turn off dynamic LCLK_GPP2 branch for<br>PCIE-GPP2 core in single port configuration                                                                                                                             |
|                                  |      | Set bit [29] to 0x1.                                                                 | when no device is detected behind Device 11or in<br>dual port configuration when no device is<br>detected behind Devices 11 and 12.                                                                              |
|                                  |      | NBCFG:PCIE_NBCFG_REGF[24]=0x1 · NBMISCIND:0x27<br>Force_off_LCLK_PCIE_GPP2           | Turn off permanent GPP2 branch for PCIE-GPP2 core in single port configuration when no device is detected behind Device 11or in dual port                                                                        |
|                                  |      | Set bit [24] to 0x1.                                                                 | configuration when no device is detected behind<br>Devices 11 and 12.                                                                                                                                            |
|                                  |      | IOMMU_L2: L2_DEBUG_2[1]=0x1 · nbconfigfunc2:0x46                                     |                                                                                                                                                                                                                  |
|                                  |      | Set bit [1] to 0x1.                                                                  |                                                                                                                                                                                                                  |

| ASIC Rev     | Step | Register Settings                                                        | Function/Comment                                                                                                                |
|--------------|------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/ | 3    | NBCFG:PCIE_PDNB_CNTL[2]=0x1 · NBMISCIND:0x7                              | Turn off TXCLK braches for PCIE-GPP3a core                                                                                      |
| 5650         |      | TXCLK_OFF_GPP3a                                                          | when no device is detected behind all Devices 4,                                                                                |
| All Revs     |      | Set bit [2] to 0x1.                                                      | 5, 6, 7, 9 and 10.                                                                                                              |
|              |      | CLKCFG:CLK_TOP_SPARE_A[30]=0x1 · clkconfig:0xe0<br>Set bit [30] to 0x1.  | Turn off dynamic LCLK_GPP3abranch for<br>PCIE-GPP3a core when no device is detected<br>behind all Devices 4, 5, 6, 7, 9 and 10. |
|              |      | NBCFG:PCIE_NBCFG_REGF[25]=0x1 · NBMISCIND:0x27                           | Turn off permanent LCLK_GPP3a branch for                                                                                        |
|              |      | Force_off_LCLK_PCIE_GPP3a                                                | PCIE-GPP3a core when no device is detected                                                                                      |
|              |      | Set bit [25] to 0x1.                                                     | behind all Devices 4, 5, 6, 7, 9 and 10.                                                                                        |
|              |      | IOMMU_L2: L2_DEBUG_2[3] =0x1 · nbconfigfunc2:0x46<br>Set bit [3] to 0x1. |                                                                                                                                 |
|              | 4    | NBCFG:PCIE_PDNB_CNTL[3]=0x1 · NBMISCIND:0x7                              | Turn off TXCLK braches for PCIE-GPP3b core                                                                                      |
|              |      | TXCLK_OFF_GPP3b                                                          | when no device is detected behind Device13.                                                                                     |
|              |      | Set bit [3] to 0x1.                                                      | NOTE: This step must be performed for SR5670 and SR5650.                                                                        |
|              |      |                                                                          | Turn off dynamic LCLK_GPP3b branch for                                                                                          |
|              |      | CLKCFG:CLK_TOP_SPARE_A[31]=0x1 · clkconfig:0xe0                          | PCIE-GPP3b core when no device is detected behind Device13.                                                                     |
|              |      | Set bit [31] to 0x1.                                                     | NOTE: This step must be performed for SR5670                                                                                    |
|              |      |                                                                          | and SR5650.                                                                                                                     |
|              |      |                                                                          | Turn off permanent LCLK_GPP3b branch for                                                                                        |
|              |      | NBCFG:PCIE_NBCFG_REGF[26]=0x1 · NBMISCIND:0x27                           | PCIE-GPP3b core when no device is detected                                                                                      |
|              |      | Force_off_LCLK_PCIE_GPP3b                                                | behind Device13.                                                                                                                |
|              |      | Set bit [26] to 0v1                                                      | NOTE: This step must be performed for SR5670 and SR5650.                                                                        |
|              |      | Set bit [26] to 0x1.                                                     |                                                                                                                                 |
|              |      | IOMMU_L2: L2_DEBUG_2[4] =0x1 · nbconfigfunc2:0x46                        |                                                                                                                                 |
|              |      | Set bit [4] to 0x1.                                                      |                                                                                                                                 |

# Table 4-68 Turning off TXCLK and LCLK (Continued)

# 4.4.7 **Optional Features**

#### • Step 23: Software Initiated Gen 2 Speed Change (CMOS Option-disabled by default)

PCIe link can be brought up to Gen 2 speed by software. This means that SR5690/5670/5650 can choose to train each PCIe link safely to operational state at Gen 1 speed by hiding Gen 2 capabilities of each Northbridge PCIe device regardless of the PCIe capabilities of the device on the other side of the link, and then once the link is safely trained at Gen 1 speed, let the software initiate Gen 2 speed change from the already safe operational state.

Software can initiate Gen 2 speed change either from the Root Complex, i.e., SR5690/5670/5650, or from the End Point, the device on the other side of the PCIe link. If the link speed change is performed from the Root Complex side, software has an option to trigger the process either from configuration space registers or from proprietary registers.

As PCIe Gen 2 link speed feature is a function of PCIe port, the following options are available:

- PCIE-GPP1 Port 0 Gen2
- PCIE-GPP1 Port 1 Gen2
- PCIE-GPP2 Port 0 Gen2 (Not applicable to SR5650)
- PCIE-GPP2 Port 1 GEN2 (Not applicable to SR5670 and SR5650)
- PCIE-SB Port 0 GEN2
- PCIE-GPP3a Port 0 GEN2
- PCIE-GPP3a Port 1 GEN2
- PCIE-GPP3a Port 2 GEN2
- PCIE-GPP3a Port 3 GEN2
- PCIE-GPP3a Port 4 GEN2
- PCIE-GPP3a Port 5 GEN2
- PCIE-GPP3b Port 0 GEN2 (Not applicable to SR5670 and SR5650)

To initiate the PCIe link speed change for each of the options listed above from configuration space register, follow the algorithm specified in the table below.

#### Table 4-69 Gen 2 Software Initiated Link Speed Change from Configuration Space Register

| ASIC Rev     | Step | Register Settings                                                | Function/Comment                         |
|--------------|------|------------------------------------------------------------------|------------------------------------------|
| SR5690/5670/ | 1    | Read back bit [24] of the:                                       | Checks if the other side of the link     |
| 5650         |      | BIF_NBP:PCIE_LC_SPEED_CNTL[24] · PCIEIND_P:0xA4                  | supports Gen 2.                          |
| All Revs     |      | LC_OTHER_SIDE_SUPPORTS_GEN2                                      |                                          |
|              |      | If read back value of bit [24] is 1 -> go to Step 2.             |                                          |
|              |      | Otherwise -> exit the sequence as the EP does not support Gen 2. |                                          |
|              | 2    | BIF_NBP:LINK_CNTL2[3:0]=0x2 · pcieCopcieConfigDev*:0x88          | Sets the highest PCIe link speed         |
|              |      | TARGET_LINK_SPEED                                                | supported by PCIe root port to be Gen 2. |
|              |      | Set bits [3:0] to 0x2.                                           |                                          |
|              | 3    | BIF_NBP:PCIE_LC_SPEED_CNTL[0]=0x1 · PCIEIND_P:0xA4               | Enables Gen 2 hardware on PCIe root      |
|              |      | LC_GEN2_EN_STRAP                                                 | port.                                    |
|              |      | Set bit [0] to 0x1.                                              |                                          |
|              | 4    | BIF_NBP:PCIE_LINK_CNTL[5]=0x1 · pcieConfigDev*:0x68              | Initiates Link Speed Change              |
|              |      | RETRAIN_LINK                                                     |                                          |
|              |      | Set bit [5] to 0x1.                                              |                                          |

To initiate the PCIe link speed change for each of the options listed above from proprietary registers, follow the algorithm specified in the table below.

| ASIC Rev     | Step | Register Settings                                                   | Function/Comment                         |
|--------------|------|---------------------------------------------------------------------|------------------------------------------|
| SR5690/5670/ | 1    | Read back bit [24] of the:                                          | Checks if the other side of the link     |
| 5650         |      | BIF_NBP:PCIE_LC_SPEED_CNTL[24] · PCIEIND_P:0xA4                     | supports Gen 2.                          |
| All Revs     |      | LC_OTHER_SIDE_SUPPORTS_GEN2                                         |                                          |
|              |      |                                                                     |                                          |
|              |      | If read back value of bit [24] is 1 -> go to Step 2                 |                                          |
|              |      | Otherwise -> exit the sequence as the endpoint does not support Gen |                                          |
|              |      | 2.                                                                  |                                          |
|              | 2    | BIF_NBP:LINK_CNTL2[3:0]=0x2 · pcieCopcieConfigDev*:0x88             | Sets the highest PCIE link speed         |
|              |      | TARGET_LINK_SPEED                                                   | supported by PCIE root port to be Gen 2. |
|              |      |                                                                     |                                          |
|              |      | Set bits[3:0] to 0x2                                                |                                          |
|              | 3    | BIF_NBP:PCIE_LC_SPEED_CNTL[0]=0x1 · PCIEIND_P:0xA4                  | Enables GEN2 hardware on PCIE root       |
|              |      | LC_GEN2_EN_STRAP                                                    | port.                                    |
|              |      |                                                                     |                                          |
|              |      | Set bit [0] to 0x1.                                                 |                                          |
|              | 4    | BIF_NBP:PCIE_LC_SPEED_CNTL[7]=0x1 · PCIEIND_P:0xA4                  | Initiates Link Speed Change              |
|              |      | LC_INITIATE_LINK_SPEED_CHANGE                                       |                                          |
|              |      |                                                                     |                                          |
|              |      | Set bit [7] to 0x1.                                                 |                                          |

| Table 4-70 Gen 2 Software Initiated PCIe Lin | k Speed Change from Proprietary Registers |
|----------------------------------------------|-------------------------------------------|
|                                              |                                           |

#### • Step 24: Transmitter L0s (CMOS Option-Enabled by Default)

[NOTE: For all Vendor IDs and Device IDs (from an internally maintained list) with known incompatible Receiver L0s implementation, detected upon enumeration in all non hot-plug implemented slots, Transmitter L0s should be disabled on the root complex side of the P2P bridge by clearing bit [0] of LINK\_CONTROL register. For all Vendor IDs and Device IDs (from the same list) with known incompatible Transmitter L0s implementation, detected upon enumeration in all non hot-plug implementation, detected upon enumeration in all non hot-plug implementation, detected upon enumeration in all non hot-plug implemented slots, Transmitter L0s should be explicitly disabled in LINK\_CNTL register of the device itself. System BIOS should follow the capability list in the device's register space to find the PCIe capability (capability ID = 0x10), then clear bit [0] of LINK\_CNTL register to 0x0. For all hot-plug implemented slots, do not enable this CMOS option by default.]

Transmitter L0s is the low power saving state of a PCIe link optimized for short entry and exit latencies. It allows each individual PCIe lane to have power substantially reduced as the transmitter scheduler becomes less active.

SR5690/5670/5650 PCIE-GPP1 and PCIE-GPP2 PCIe ports are fully capable of supporting Transmitter L0s power saving state as reported in their Link Capability register along with their L0s exit latency.

The following options are available:

- PCIE-GPP1 Port 0 L0s
- PCIE-GPP1 Port 1 L0s
- PCIE-GPP2 Port 0 L0s (Not applicable to SR5650)
- PCIE-GPP2 Port 1 L0s (Not applicable to SR5670 and SR5650)
- PCIE-SB Port 0 L0s
- PCIE-GPP3a Port 0 L0s
- PCIE-GPP3a Port 1 L0s
- PCIE-GPP3a Port 2 L0s
- PCIE-GPP3a Port 3 L0s
- PCIE-GPP3a Port 4 L0s
- PCIE-GPP3a Port 5 L0s
- PCIE-GPP3b Port 0 L0s (Not applicable to SR5670 and SR5650)

To enable Transmitter L0s on SR5690/5670/5650 PCIe ports, follow the programming sequence below.

| ASIC Rev     | Step | Register Settings                              | Function/Comment                                |
|--------------|------|------------------------------------------------|-------------------------------------------------|
| SR5690/5670/ | 1    | BIF_NBP:PCIE_LC_CNTL[11:8]=0x · PCIEIND_P:0xA0 | Sets Transmitter L0s inactivity timer to 40 ns. |
| 5650         |      | LC_L0S_INACTIVITY                              |                                                 |
| All Revs     |      |                                                |                                                 |
|              |      | Set bits [11:8] to 0x1.                        |                                                 |
|              | 2    | BIF_NBP:LINK_CNTL[0]=0x1 · pcieConfigDev*:0x68 | Enables Transmitter L0s on SR5690/5670/5650     |
|              |      | PM_CONTROL                                     | PCIe ports.                                     |
|              |      |                                                |                                                 |
|              |      | Set bit [0] to 0x1.                            |                                                 |

Table 4-71 Enabling Transmitter L0s for the PCle Port(s)

To enable Transmitter L0s in external devices, follow the programming sequence below:

Table 4-72 Enabling Transmitter L0s in the External Device(s)

| ASIC Rev | Step | Register Settings                                             | Function/Comment                              |
|----------|------|---------------------------------------------------------------|-----------------------------------------------|
| N/A      | 1    | In the configuration space of the device, read bit[10] of the | Bit[10] = 0x1 means the device supports       |
|          |      | following register:                                           | Transmitter L0s ->go to Step 2.               |
|          |      | LINK_CAP[10] · (Offset 0x0C)                                  |                                               |
|          |      | LINK_CAP                                                      | Bit[10] = 0 means the device does not support |
|          |      |                                                               | Transmitter L0s, exit the sequence.           |
|          |      | If read back value of but [10] is 0x1 -> go to next step.     |                                               |
|          |      | Otherwise, skip this sequence.                                |                                               |
|          | 2    | In the configuration space of the device, set bit[0] of the   | Enables Transmitter L0s on external PCIe      |
|          |      | following register:                                           | device.                                       |
|          |      | LINK_CNTL[0]=0x1 · (Offset 0x10 from PCIe capability          |                                               |
|          |      | ID=0x10)                                                      |                                               |
|          |      | PM_CONTROL                                                    |                                               |
|          |      |                                                               |                                               |
|          |      | Set bit [0] to 0x1.                                           |                                               |

#### • Step 25: Active State Power Management-ASMP L1 (CMOS Option – Enabled by Default)

[NOTE: This feature should be disabled for all Vendor IDs and Device IDs (from an internally maintained list) with known incompatible ASPM L1 hardware implementation. To explicitly disable ASPM L1 feature on such external devices, follow the capability list in the device's register space to find the PCIe capability (capability ID = 0x10), then clear bit [1] of LINK\_CNTL register to 0x0.]

ASPM L1 is the high power saving state of PCIe link that maximizes power savings at a cost of increased entry and exit latencies. By placing the PCIe link into electrical idle state whenever it is not in use, substantial amount of power is saved by avoiding link synchronization maintenance even where there is no data to be sent.

SR5690/5670/5650 PCIe ports are fully capable of supporting ASPM L1 power saving state as reported in their Link Capability register along with their ASPM L1 exit latency.

The following options are available:

- PCIE-GPP1 Port 0 ASPM L1
- PCIE-GPP1 Port 1 ASPM L1
- PCIE-GPP2 Port 0 ASPM L1 (Not applicable to SR5650)
- PCIE-GPP2 Port 1 ASPM L1 (Not applicable to SR5670 and SR5650)
- PCIE-GPP3a Port 0 ASPM L1
- PCIE-GPP3a Port 1 ASPM L1
- PCIE-GPP3a Port 2 ASPM L1
- PCIE-GPP3a Port 3 ASPM L1
- PCIE-GPP3a Port 4 ASPM L1

- PCIE-GPP3a Port 5 ASPM L1
- PCIE-GPP3b Port 0 ASPM L1 (Not applicable to SR5670 and SR5650)

To enable ASPM L1 for each of the options listed above, follow the programming sequence below.

|              | -    |                                                                                                                |                                                     |
|--------------|------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| ASIC Rev     | Step | Register Settings                                                                                              | Function/Comment                                    |
| SR5690/5670/ | 1    | For each PCIe endpoint device under the root port and all                                                      | Check advertised level of ASPM L1 support           |
| 5650         |      | intervening device ports on that hierarchy, read bit [11] of                                                   | for each endpoint device under the root port        |
| All Revs     |      | LINK_CAPABILITY register:                                                                                      | and all intervening device ports on that hierarchy. |
|              |      | LINK_CAP[11] · (Offset 0x0C from PCIE Capability ID)<br>PM_SUPPORT                                             | inerarchy.                                          |
|              |      |                                                                                                                |                                                     |
|              |      | If device behind root port is a switch, and bit [11] = 0x0, go to                                              |                                                     |
|              |      | Step 4.                                                                                                        |                                                     |
|              |      | If device behind root port is a switch, and bit [11] = 0x1, go to                                              |                                                     |
|              |      | Step 2.                                                                                                        |                                                     |
|              |      | If device behind root port is an endpoint device, and bit [11] =                                               |                                                     |
|              |      | 0x0, exit the sequence.                                                                                        |                                                     |
|              |      | If device behind root port is an endpoint device, and bit $[11] = 0x1$                                         |                                                     |
|              |      | go to Step 2.                                                                                                  |                                                     |
|              | 2    | For each endpoint under this root port, read back L1 exit latency                                              | CMOS Option (exit latency calculation taken         |
|              |      | by reading bits [14:12] of PCIE_LINK_CAP register in                                                           | into account for enabling L1 – enabled by           |
|              |      | configuration spaces of each of these devices:<br>PCIE LINK CAP[17:15] · (Offset 0x0C from PCIE Capability ID) | default)                                            |
|              |      | L1_EXIT_LATENCY                                                                                                |                                                     |
|              |      |                                                                                                                |                                                     |
|              |      | and then calculate Actual L1 Latency:                                                                          |                                                     |
|              |      | Actual_L1_Latency = 4us + (number of links in between EP and                                                   |                                                     |
|              |      | root port - 0x1) * 1us                                                                                         |                                                     |
|              |      |                                                                                                                |                                                     |
|              |      | Read back endpoint acceptable latency:                                                                         |                                                     |
|              |      | BIF_NBP:PCIE_DEVICE_CAP[11:9] · (Offset 0x04 from PCIE                                                         |                                                     |
|              |      | Capability ID)                                                                                                 |                                                     |
|              |      | L1_ACCEPTABLE_LATENCY                                                                                          |                                                     |
|              |      | If endpoint L1 ACCEPTABLE LATENCY >= Actual L1 Latency,                                                        |                                                     |
|              |      | go to step 3; otherwise exit the sequence.                                                                     |                                                     |
|              | 3    | BIF_NBP:LINK_CNTL[1]=0x1· pcieConfigDev*:0x68                                                                  | Enables ASPM L1 capability in                       |
|              | 0    | PM_CONTROL                                                                                                     | SR5690/5670/5650 PCIe port.                         |
|              |      |                                                                                                                |                                                     |
|              |      | Set bit [1] to 0x1.                                                                                            |                                                     |
|              | 4    | In the configuration space of each endpoint device under the root                                              | Enables ASPM L1 entry in each PCIe link             |
|              |      | port and all intervening device ports on that hierarchy in which it                                            | under the root port accordingly.                    |
|              |      | was found in Step 1 that PM_SUPPORT = 0x1 on both sides of                                                     |                                                     |
|              |      | each PCIe link:                                                                                                |                                                     |
|              |      |                                                                                                                |                                                     |
|              |      | LINK_CNTL[1]=0x1· (Offset 0x10 from PCIE Capability ID)                                                        |                                                     |
|              |      | PM_CONTROL                                                                                                     |                                                     |
|              |      | Set bit [1] to 0x1.                                                                                            |                                                     |
|              |      |                                                                                                                |                                                     |

Table 4-73 Algorithm for Enabling ASPM L1

#### • Step 26: Turning Off PLLs in L1/L23 (CMOS Option – Enabled by Default)

[NOTE: This feature requires ASMP L1 to be enabled.]

SR5690/5670/5650 PCIe ports offer more aggressive PCIe link power savings in ASPM L1 state by being able to shut off their internal PLLs in this state at a slight cost of increased exit latency.

This PCIe CMOS option should be enabled by default to allow systems to take full advantage of ASPM L1 power savings.

The following options are available:

- Turn Off PLLs in L1/L23 for PCIE-GPP1 Core
- Turn Off PLLs in L1/L23 for PCIE-GPP2 Core (Not applicable to SR5650)
- Turn Off PLLs in L1/L23 for PCIE-GPP3a Core
- Turn Off PLLs in L1/L23 for PCIE-GPP3b Core (Not applicable to SR5670 and SR5650)

The PLL for the PCIE\_SB core should not be turned off in L1. To enable Turning Off PLLs during ASPM L1 for each of the options listed above, follow the programming sequence below.

| Table 4-74 | Programming | Sequence to | Enable Turnin | g Off PLLs During L1 |
|------------|-------------|-------------|---------------|----------------------|
| Table 4-74 | FIUgramming | Sequence to |               | y on FLLS During LT  |

| ASIC Rev     | Step | Register Settings                                         | Function/Comment                                   |
|--------------|------|-----------------------------------------------------------|----------------------------------------------------|
| SR5690/5670/ | 1    | For each endpoint under this root port, read back L1 exit |                                                    |
| 5650         |      | latency by reading bits [14:12] of PCIE_LINK_CAP          | account for enabling Turning Off PLLs in L1/L23 –  |
| All Revs     |      | register in configuration spaces of each of these         | enabled by default)                                |
|              |      | devices:                                                  |                                                    |
|              |      | PCIE_LINK_CAP[17:15]                                      |                                                    |
|              |      | L1_EXIT_LATENCY                                           |                                                    |
|              |      | and than calculate Actual_L1_Latency:                     |                                                    |
|              |      | Actual_L1_Latency = 34us + (number of links in            |                                                    |
|              |      | between EP and root port - 0x1) * 1us                     |                                                    |
|              |      | Read back endpoint acceptable latency:                    |                                                    |
|              |      | BIF_NBP:PCIE_DEVICE_CAP[11:9]                             |                                                    |
|              |      | L1_ACCEPTABLE_LATENCY                                     |                                                    |
|              |      | If endpoint L1_ACCEPTABLE_LATENCY >=                      |                                                    |
|              |      | Actual_L1_Latency, go to Step 2; otherwise exit the       |                                                    |
|              |      | sequence.                                                 |                                                    |
|              | 2    | Set bits [0] and [3] and clear bits [4] and [9] of the    | Enable powering down PLLs in L1 or L23 Ready       |
|              |      | following register:                                       | states.                                            |
|              |      | BIF_NB:PCIE_P_CNTL[0]=0x1 · PCIEIND:0x40                  |                                                    |
|              |      | BIF_NB:PCIE_P_CNTL[3]=0x1 · PCIEIND:0x40                  |                                                    |
|              |      | BIF_NB:PCIE_P_CNTL[4]=0x0 · PCIEIND:0x40                  |                                                    |
|              |      | BIF_NB:PCIE_P_CNTL[9]=0x0 · PCIEIND:0x40                  |                                                    |
|              |      | P_PWRDN_EN (set bit [0] to 1)                             |                                                    |
|              |      | P_PLL_PWRDN_IN_L1L23 (set bit [3] to 1)                   |                                                    |
|              |      | P_PLL_BUF_PDNB (clear bit [4] to 0])                      |                                                    |
|              |      | P_PLL_PDNB (clear bit [9] to 0)                           |                                                    |
|              | 3    | Set bit [12] of the following register:                   | Turns off PHY's RX FRONTEND during L1 when PLL     |
|              | -    | BIF_NB:PCIE_P_CNTL[12]=0x1 · PCIEIND:0x40                 | power down is enabled                              |
|              |      | P_ALLOW_PRX_FRONTEND_SHUTOFF                              |                                                    |
|              |      | Set bit [12] to 0x1.                                      |                                                    |
|              | 4    | Set bit [8] of the following register:                    | Fix the race problem between PLL calibrator and LC |
|              |      | BIF_NB:PCIE_HW_DEBUG[8]=0x1 · PCIEIND:0x2                 | wake up from L1.                                   |
|              |      | HW_08_DEBUG                                               |                                                    |
|              |      | Set bit [8] to 0x1.                                       |                                                    |

#### 4.4.7.1 TXCLK Gating in L1 (CMOS Option - Enabled by Default)

[NOTE: This option requires ASPM L1 to be enabled.]

SR5690/5670/5650 PCIe cores have the ability to dynamically gate off their respective dynamic TXCLK clock branches whenever the associated PCIe link goes to ASPL L1 power saving state, thereby affecting the amount of power savings that can actually be achieved.

As SR5690/5670/5650 platforms should aim for optimum power savings, this PCIe CMOS option should be enabled by default.

The following options are available:

- PCIE-GPP1 TXCLK Clock Gating in L1
- PCIE-GPP2 TXCLK Clock Gating in L1 (Not applicable to SR5650)
- PCIE-SB TXCLK Clock Gating in L1
- PCIE-GPP3a TXCLK Clock Gating in L1
- PCIE-GPP3b TXCLK Clock Gating in L1 (Not applicable to SR5670 and SR5650)

To enable TXCLK gating for the PCIE-GPP1 core, follow the programming sequence below.

#### Table 4-75 PCIE-GPP1 TXCLK Clock Gating In L1

| ASIC Rev     | Step | Register Settings                               | Function/Comment                          |
|--------------|------|-------------------------------------------------|-------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_PDNB_CNTL[4]=0x1 · NBMISCIND:0x7     | Enables PCIE-GPP1 TXCLK gating in L1      |
| 5650         |      | TXCLK_DYN_CLKGATE_EN_GPP1                       |                                           |
| All Revs     |      |                                                 |                                           |
|              |      | Set bit [4] to 0x1.                             |                                           |
|              | 2    | BIF_NB:PCIE_P_CNTL[6]=0x1 · PCIEIND:0x40        | Enables powering down TXCLK clock pads on |
|              |      | P_TXCLK_RCV_PWRDN                               | the receive side.                         |
|              |      |                                                 |                                           |
|              |      | Set bit [6] to 0x1.                             |                                           |
|              | 3    | BIF_NB:PCIE_CONFIG_CNTL[3:0]=0xC · PCIEIND:0x11 | Programs dynamic clock gating latency in  |
|              |      | DYN_CLK_LATENCY                                 | PCIE-GPP1.                                |
|              |      |                                                 |                                           |
|              |      | Set bits [3:0] to 0xC.                          |                                           |

To enable TXCLK gating for PCIE-GPP2 core, follow the programming sequence below.

#### Table 4-76 PCIE-GPP2 TXCLK Clock Gating In L1

| ASIC Rev    | Step | Register Settings                               | Function/Comment                         |
|-------------|------|-------------------------------------------------|------------------------------------------|
| SR5690/5670 | 1    | NBCFG:PCIE_PDNB_CNTL[5]=0x1 · NBMISCIND:0x7     | Enables PCIE-GPP2 TXCLK gating in L1     |
| All Revs    |      | TXCLK_DYN_CLKGATE_EN_GPP2                       |                                          |
|             |      | Set bit [5] to 1.                               |                                          |
|             | 2    | BIF_NB:PCIE_P_CNTL[6]=0x1 · PCIEIND:0x40        | Enables powering down TXCLK clock pads   |
|             |      | P_TXCLK_RCV_PWRDN                               | on the receive side.                     |
|             |      | Set bit [6] to 1.                               |                                          |
|             | 3    | BIF_NB:PCIE_CONFIG_CNTL[3:0]=0xC · PCIEIND:0x11 | Programs dynamic clock gating latency in |
|             |      | DYN_CLK_LATENCY                                 | PCIE-GPP2 core.                          |
|             |      | Set bits [3:0] to 0xC.                          |                                          |

To enable TXCLK gating for PCIE\_SB core, follow the programming sequence below.

| Table 4-77 | PCIE-SB | TXCLK     | Clock | Gating |
|------------|---------|-----------|-------|--------|
|            |         | 17.0 - 1. | 01001 | Guing  |

| ASIC Rev     | Step | Register Settings                               | Function/Comment                              |
|--------------|------|-------------------------------------------------|-----------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_PDNB_CNTL[7]=0x1 · NBMISCIND:0x7     | Enables PCIE-SB TXCLK gating in L1            |
| 5650         |      | TXCLK_DYN_CLKGATE_EN_SB                         |                                               |
| All Revs     |      |                                                 |                                               |
|              |      | Set bit [7] to 0x1.                             |                                               |
|              | 2    | BIF_NB:PCIE_P_CNTL[6]=0x1 · PCIEIND:0x40        | Enables powering down TXCLK clock pads        |
|              |      | P_TXCLK_RCV_PWRDN                               | on the receive side. Each clock pad           |
|              |      |                                                 | corresponds to logic associated with 4 lanes. |
|              |      | Set bit [6] to 0x1.                             |                                               |
|              | 3    | BIF_NB:PCIE_CONFIG_CNTL[3:0]=0xC · PCIEIND:0x11 | Programs dynamic clock gating latency in      |
|              |      | DYN_CLK_LATENCY                                 | PICE-SB.                                      |
|              |      |                                                 |                                               |
|              |      | Set bits [3:0] to 0xC.                          |                                               |

To enable TXCLK gating for PCIE-GPP3a core, follow the programming sequence below.

Table 4-78 PCIE-GPP3a TXCLK Clock Gating

| ASIC Rev     | Step | Register Settings                               | Function/Comment                                |
|--------------|------|-------------------------------------------------|-------------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:PCIE_PDNB_CNTL[6]=0x1 · NBMISCIND:0x7     | Enables PCIE-GPP3a TXCLK gating in L1           |
| 5650         |      | TXCLK_DYN_CLKGATE_EN_GPP3a                      |                                                 |
| All Revs     |      |                                                 |                                                 |
|              |      | Set bit [6] to 1.                               |                                                 |
|              | 2    | BIF_NB:PCIE_P_CNTL[6]=0x1 · PCIEIND:0x40        | Enables powering down TXCLK clock pads on       |
|              |      | P_TXCLK_RCV_PWRDN                               | the receive side. Each clock pad corresponds to |
|              |      |                                                 | logic associated with 4 lanes.                  |
|              |      | Set bit [6] to 0x1.                             |                                                 |
|              | 3    | BIF_NB:PCIE_CONFIG_CNTL[3:0]=0xC · PCIEIND:0x11 | Programs dynamic clock gating latency in        |
|              |      | DYN_CLK_LATENCY                                 | PCIE-GPP3a core                                 |
|              |      |                                                 |                                                 |
|              |      | Set bits [3:0] to 0xC.                          |                                                 |

To enable TXCLK gating for PCIE-GPP3b core, follow the programming sequence below.

#### Table 4-79 PCIE-GPP3b TXCLK Clock Gating

| ASIC Rev | Step | Register Settings                               | Function/Comment                             |
|----------|------|-------------------------------------------------|----------------------------------------------|
| SR5690   | 1    | NBCFG:PCIE_PDNB_CNTL[24]=0x1 · NBMISCIND:0x7    | Enables PCIE-GPP3b TXCLK gating in L1        |
| All Revs |      | TXCLK_DYN_CLKGATE_EN_GPP3b                      |                                              |
|          |      |                                                 |                                              |
|          |      | Set bit [24] to 0x1.                            |                                              |
|          | 2    | BIF_NB:PCIE_P_CNTL[6]=0x1 · PCIEIND:0x40        | Enables powering down TXCLK clock pads on    |
|          |      | P_TXCLK_RCV_PWRDN                               | the receive side. Each clock pad corresponds |
|          |      |                                                 | to logic associated with 4 lanes.            |
|          |      | Set bit [6] to 1.                               |                                              |
|          | 3    | BIF_NB:PCIE_CONFIG_CNTL[3:0]=0xC · PCIEIND:0x11 | Programs dynamic clock gating latency in     |
|          |      | DYN_CLK_LATENCY                                 | PCIE-GPP3b core.                             |
|          |      |                                                 |                                              |
|          |      | Set bits [3:0] to 0xC.                          |                                              |

## • Step 27: LCLK Gating (CMOS Option - Enabled by Default)

#### [NOTE: This option requires ASPM L1 to be enabled.]

Dynamic power consumption can be further decreased by gating off the LCLK clock branches of the SR5690/5670/5650 PCIe cores whenever all associated PCIe links go to ASPL L1 power saving state.

This CMOS options should be enabled by default.

To enable gating off LCLK dynamic branches, follow the programming sequence below.

#### Table 4-80 LCLK Clock Gating

| ASIC Rev     | Step | Register Settings                               | Function/Comment                        |
|--------------|------|-------------------------------------------------|-----------------------------------------|
| SR5690/5670/ | 1    | CLKCFG:CLKGATE_DISABLE[22]=0x0 · clkconfig:0x94 | Enables LCLK gating for PCIE-GPP1 LCLK  |
| 5650         |      |                                                 | dynamic branch.                         |
| All Revs     |      | Clear bit [22] to 0x0.                          |                                         |
|              | 2    | CLKCFG:CLK_TOP_SPARE_C[28]=0x1 · clkconfig:0xE8 | Enables LCLK gating for PCIE-GPP2 LCLK  |
|              |      |                                                 | dynamic branch.                         |
|              |      | Set bit [28] to 0x1.                            |                                         |
|              | 3    | CLKCFG:CLKGATE_DISABLE[24]=0x0 clkconfig:0x94   | Enables LCLK gating for PCIE-SB LCLK    |
|              |      |                                                 | dynamic branch.                         |
|              |      | Clear bit [24] to 0x0.                          |                                         |
|              | 4    | CLKCFG:CLK_TOP_SPARE_C[31]=0x1 · clkconfig:0xe8 | Enables LCLK gating for PCIE-GPP3a LCLK |
|              |      |                                                 | dynamic branch.                         |
|              |      | Set bit [31] to 0x1.                            |                                         |
|              | 5    | CLKCFG:CLK_TOP_SPARE_C[25]=0x1 · clkconfig:0xe8 | Enables LCLK gating for PCIE-GPP3b LCLK |
|              |      |                                                 | dynamic branch.                         |
|              |      | Set bit [25] to 0x1.                            |                                         |

#### 4.4.8 PCIe Workarounds

#### • Step 28: Workaround for Broadcom ASPM L1 Issue

Follow the programming sequence described in *Section 4.4.8.1 "Workaround for Broadcom 5709C ASPM L1 Issue"* on page 4-87.

# 4.4.8.1 Workaround for Broadcom 5709C ASPM L1 Issue

The following programming sequence should be executed when system BIOS detects a Broadcom 5709C Device (Vendor ID: 0x14E4, Device ID: 0x1639) present in the system. This should be done for the root-complex PCIe port that the device is connected to

#### Table 4-81 Broadcom 5709C Workaround

| ASIC Rev | Step | Register Settings                                                                                             | Function/Comment |
|----------|------|---------------------------------------------------------------------------------------------------------------|------------------|
| N/A      |      | BIF_NBP:PCIE_LC_TRAINING_CNTL[26]=0x0· PCIEIND_P:0xA1<br>LC_RESET_ASPM_L1_NAK_TIMER<br>Clear bit [26] to 0x0. |                  |

# Chapter 5 HTIU Settings

# 5.1 HyperTransport<sup>™</sup> Link Initialization

The SR5690/5670/5650 northbridge is expected to be the only HyperTransport<sup>™</sup> (HT) device on the same HT chain with the processor. Moving the chipset off of unit ID 0 to look for additional devices, as described in various AMD processor BKDGs and the HyperTransport specification, is neither necessary, nor is it supported. All devices on PCI bus 0 are expected to be located within the northbridge and the southbridge. The use of an HT tunnel device between the processor and the SR5690/5670/5650 is not supported. If multiple northbridges are used, the ones not connected to the southbridge must be placed on separate logical PCI buses.

# 5.2 HTIU Indirect Register Space

Many non-standard HTIU related registers are located in an indirect register space HTIUNBIND. This is accessed through HTIU\_NB\_INDEX (with write-enable in bit [8], and index in bits [6:0]), and HTIU\_NB\_DATA in the NBCFG space. The location of the index/data pair is located in chipset primary bus number, device 0x0, function 0x0, registers 0x94 and 0x98.

## 5.3 CPU Register Access

#### 5.3.1 Normal Registers

For a single-socket platform, the processor will be accessible through bus 0x0 device 0x18 with various function numbers. Note: In this document, these registers will be referred to as CPU\_FX (where X stands for function number) x offset.

#### 5.3.2 PHY Dataport Register Access

Refer to the section entitled "Link Phy Offset Registers (Function 4 registers 0x180, 188, 190, 198)" in the AMD family 10h processor BKDG to see how to program the processor HyperTransport PHY registers. Note: In the HTIU section of this document, these registers will be referred to as CPU\_PHY 0xYY, where YY is the register offset.

The northbridge will always be connected to Link 0 so that CPU function 4 registers 0x180 and 0x184 will be used to control the PHY.

#### 5.3.3 Link Dependent Registers

The processor supports multiple HT links, each of which can be coherent or non-coherent depending on system design. This document will focus on non-coherent link programming with respect to SR5690/5670/5650. Some of the register settings will depend on specific link used to connect with SR5690/5670/5650. To cover all the possible scenarios, registers that are link dependent will be shown according to this format: CPU F# x Link3 Offset/Link1 Offset/Link0 Offset

Please only program the appropriate link that is connected to the chipset.

# 5.4 Changing to High-Speed Mode

The HT link starts at 200MHz/8-bit mode on initial power-up. Software is responsible for reprogramming both the processor(s) and northbridge(s) for higher speed operation. Generating a warm reset will cause the system to restart using the new higher speeds.

#### 5.4.1 Identifying Supported HT Frequencies

The HT frequency capability register located in NBCFG x D0[31:16] determines which HT frequencies are supported by the northbridge. The bits in this 16-bit register denote which frequency codes are valid. For example, a value of 0x25 indicates that frequency codes 0x0, 0x2, and 0x5 are valid indicating 200Mhz, 400Mhz, and 800Mhz support. Similarly, the HT frequency capability register in the processor is located in CPU\_F0 x E8/C8/A8/88 bits [31:16] and are encoded in the same manner. Both the northbridge and the processor must be set to the same frequency. Note that the lower

frequencies require HyperTransport 1 mode to operate while higher frequencies require HyperTransport 3 mode to operate.

| HT Frequency | Frequency Code | IBIAS | Comments              |
|--------------|----------------|-------|-----------------------|
| 200Mhz       | 0x0            | 0x44  | HyperTransport 1 only |
| 400Mhz       | 0x2            | 0x44  | HyperTransport 1 only |
| 600Mhz       | 0x4            | 0xB6  | HyperTransport 1 only |
| 800Mhz       | 0x5            | 0x44  | HyperTransport 1 only |
| 1Ghz         | 0x6            | 0x96  | HyperTransport 1 only |
| 1.2Ghz       | 0x7            | 0xB6  | HyperTransport 3 only |
| 1.4Ghz       | 0x8            | 0x23  | HyperTransport 3 only |
| 1.6Ghz       | 0x9            | 0x44  | HyperTransport 3 only |
| 1.8Ghz       | 0xa            | 0x64  | HyperTransport 3 only |
| 2.0Ghz       | 0xb            | 0x96  | HyperTransport 3 only |
| 2.2Ghz       | 0xc            | 0xA6  | HyperTransport 3 only |
| 2.4Ghz       | 0xd            | 0xB6  | HyperTransport 3 only |
| 2.6Ghz       | 0xe            | 0xC6  | HyperTransport 3 only |

#### Table 5-1Identifying Supported HT Frequencies

# 5.4.2 Changing to High-Speed HT 1 Mode

The following registers in *Table 5-2* must be programmed to enable one of the high-speed HT1 modes.

#### Table 5-2Enabling High-Speed HT1 Modes

| ASIC Rev       | Register                     | Setting                   | Function/Comment                                            |
|----------------|------------------------------|---------------------------|-------------------------------------------------------------|
| SR5690/5670/56 | NBCFG x D0 [11:8]            | HT1 Frequency Code from   | Sets HT Frequency in the chipset                            |
| 50             |                              | Table 5-1                 |                                                             |
| All Revs       | NBCFG x C8 [26:24]           | 0x1 = 16 bit              | Sets input HT link width on the chipset side to be 16-bit.  |
| AII NEVS       |                              | 0x0 = 8 bit               | Only 8-bit and 16-bit widths are supported.                 |
|                | NBCFG x C8 [30:28]           | 0x1 =16 bit               | Sets output HT link width on the chipset side to be 16-bit. |
|                |                              | 0x0 = 8 bit               | Only 8-bit and 16-bit widths are supported.                 |
|                | CLKCFG x D8 [9:0]            | IBIAS Code from Table 5-1 | Sets the chipset HT PLL ibias setting                       |
|                | HTIUNBIND x 2A [1:0]         | 0x3                       | Optimize chipset HT transmitter drive strength              |
|                | CPU_F0 x E8/C8/A8/88[11:8]   | HT1 Frequency Code from   | Sets HT Frequency in the processor                          |
|                |                              | Table 5-1                 |                                                             |
|                | CPU_F0 x E4/C4/A4/84 [26:24] | 0x1 = 16 bit              | Sets input HT link width on the processor side to be        |
|                |                              | 0x0 = 8 bit               | 16-bit. Only 8-bit and 16-bit widths are supported.         |
|                | CPU_F0 x E4/C4/A4/84 [30:28] | 0x1 = 16 bit              | Sets output HT link width on the processor side to be       |
|                |                              | 0x0 = 8 bit               | 16-bit. Only 8-bit and 16-bit widths are supported.         |

Note: Once these registers are programmed, a warm-reset must be performed to switch to high-speed mode.

# 5.4.3 Changing to HT 3 Mode

HT 3 capability in the northbridge can be detected by searching the PCI capability linked list for a header with Capability\_ID 0x8 and Capability\_Type 0xD0. Assuming the processor is HT 3 capable, HT 3 modes can be enabled by programming the following registers in Table 5-3. This can be done directly from the 200Mhz/8-bit bootup mode. Please note that to program HT3 capability registers properly, NBCFG x 9c[17:16] must be set to 0x0.

| ASIC Rev       | Register             | Setting                       | Function/Comment                                    |
|----------------|----------------------|-------------------------------|-----------------------------------------------------|
| SR5690/5670/56 | NBCFG x D0 [11:8]    | HT3 Frequency Code from Table | Sets HT Frequency in the chipset                    |
| 50             |                      | 5-1                           |                                                     |
| All Revs       | NBCFG x C8 [26:24]   | 0x1 = 16 bit                  | Sets input HT link width on the chipset side to be  |
| All Nevs       |                      | 0x0 = 8 bit                   | 16-bit. Only 8-bit and 16-bit widths are supported  |
|                | NBCFG x C8 [30:28]   | 0x1 = 16 bit                  | Sets output HT link width on the chipset side to be |
|                |                      | 0x0 = 8 bit                   | 16-bit. Only 8-bit and 16-bit widths are supported  |
|                | CLKCFG x D8 [9:0]    | IBIAS Code from Table 5-1     | Sets the chipset HT PLL IBIAS setting               |
|                | NBCFG x 44 [0]       | 0x1                           | Enables error-retry mode                            |
|                | NBCFG x AC [3]       | 0x1                           | Enables scrambling                                  |
|                | NBCFG x A4 [31]      | 0x1                           | Enables transmitter de-emphasis                     |
|                | NBCFG x A4 [26:24]   | See Function/Comment.         | Enables transmitter de-emphasis level               |
|                |                      |                               | This depends on the PCB design and the trace        |
|                |                      |                               | length between NB and processor                     |
|                |                      |                               | Use 0x4 for bringup.                                |
|                |                      |                               | See section 5.5.7 (transmitter de-emphasis) for     |
|                |                      |                               | programming guidelines.                             |
|                | NBCFG x A0 [5:0]     | LS0 = 0us                     | Sets Training 0 time. These settings are chosen to  |
|                |                      | LS1 = 2us                     | match the processor requirements. See Table 5-5     |
|                |                      | LS2 = CPU_PHY x [530A,520A]   | for encodings                                       |
|                |                      | [Ls2ExitTime] + 2us           |                                                     |
|                | NBCFG x AC [14]      | 0x1                           | Disables command throttling                         |
|                | HTIUNBIND x 15 [22]  | 0x1                           | Enables strict TM4 detection                        |
|                | HTIUNBIND x 2A [1:0] | 0x1                           | Optimizes chipset HT transmitter drive strength     |

#### Table 5-4CPU Register Settings for HT 3

| ASIC Rev                     | Register                    | Setting                              | Function/Comment                                                                                                                                                                                                                                                                                                                         |
|------------------------------|-----------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/5650<br>All Revs | CPU_F0 x E8/C8/A8/88[11:8]  | HT3 Frequency Code from<br>Table 5-1 | Sets HT Frequency in the processor.                                                                                                                                                                                                                                                                                                      |
|                              | CPU_F0 x E4/C4/A4/84[26:24] | 0x1                                  | Sets input HT link width on the processor side to be 16-bits.                                                                                                                                                                                                                                                                            |
|                              | CPU_F0 x E4/C4/A4/84[30:28] | 0x1                                  | Sets output HT link width on the processor side to be 16-bits.                                                                                                                                                                                                                                                                           |
|                              | CPU_F0 x 13C/138/134/130[0] | 0x1                                  | Enables error-retry mode.                                                                                                                                                                                                                                                                                                                |
|                              | CPU_F0 x 17C/178/174/170[3] | 0x1                                  | Enables scrambling.                                                                                                                                                                                                                                                                                                                      |
|                              | CPU_PHY x C5                | See Function/Comment                 | Enables transmitter de-emphasis.<br>This depends on the PCB design and the trace length<br>between NB and processor.<br>For bringup, use the -3dB settings described in the<br>appropriate processor BKDG (for Family 10h, this is<br>located under "Link PHY De-emphasis Value<br>Registers").<br>This register is also link dependent. |

| ASIC Rev                     | Register         | Setting                                                                         | Function/Comment                                                                                                                                                                                                                                                                                                                          |
|------------------------------|------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/5650<br>All Revs | CPU_PHY x D5     | See Function/Comment                                                            | Enables transmitter de-emphasis.<br>This depends on the PCB design and the trace length<br>between NB and processor.<br>For bring-up, use the -3dB settings described in the<br>appropriate processor BKDG (for Family 10h, this is<br>located under "Link PHY De-emphasis Value<br>Registers").<br>This register is also link dependent. |
|                              | CPU_F0 x168[10]  | 0x1                                                                             | Disables command throttling                                                                                                                                                                                                                                                                                                               |
|                              | CPU_F0 x16C[5:0] | LS0 = 0us<br>LS1 = 2us<br>LS2 = CPU_PHY x<br>[530A,520A] [Ls2ExitTime] +<br>2us | Sets Training 0 Time. See <i>Table 5-5</i> for the encodings.                                                                                                                                                                                                                                                                             |

## Table 5-4CPU Register Settings for HT 3 (Continued)

## Table 5-5T0Time Settings From the HT 3 Specification

| T0Time [2:0] | T0Time[5:4] |        |       |          |  |
|--------------|-------------|--------|-------|----------|--|
| T0Time [3:0] | 0x0         | 0x1    | 0x2   | 0x3      |  |
| 0x 0         | 0.0us       | 0.0 us | 0 us  | 0.0us    |  |
| 0x 1         | 0.1us       | 0.5 us | 2 us  | 20 us    |  |
| 0x 2         | 0.2 us      | 1.0 us | 4 us  | 40 us    |  |
| 0x 3         | 0.3 us      | 1.5 us | 6 us  | 60 us    |  |
| 0x 4         | 0.4 us      | 2.0 us | 8 us  | 80 us    |  |
| 0x 5         | 0.5 us      | 2.5 us | 10 us | 100 us   |  |
| 0x 6         | 0.6 us      | 3.0 us | 12 us | 120 us   |  |
| 0x 7         | 0.7 us      | 3.5 us | 14 us | 140 us   |  |
| 0x 8         | 0.8 us      | 4.0 us | 16 us | 160 us   |  |
| 0x 9         | 0.9 us      | 4.5 us | 18 us | 180 us   |  |
| 0xA          | 1.0 us      | 5.0 us | 20 us | 200 us   |  |
| 0xB          | 1.1 us      | 5.5 us | 22 us | Reserved |  |
| 0xC          | 1.2 us      | 6.0 us | 24 us | Reserved |  |
| 0xD          | 1.3 us      | 6.5 us | 26 us | Reserved |  |
| 0xE          | 1.4 us      | 7.0 us | 28 us | Reserved |  |
| 0xF          | 1.5 us      | 7.5 us | 30 us | Reserved |  |

# 5.5 HT Register Settings

# 5.5.1 General Register Settings

## Table 5-6HT General Register Settings

| ASIC Rev    | Setting                  | Function/Comment                                                  |
|-------------|--------------------------|-------------------------------------------------------------------|
| SR5690/5670 | HTIUNBIND x 1C [17] = 1  | Prevent AllowLdtStop from being asserted during HT link recovery. |
| /5650       | HTIUNBIND x 05 [8] = 0x1 | Enable PC checking for FCB release.                               |
| All Revs    | HTIUNBIND x 06 [0] = 0x0 | Enable writes to pass in-progress reads.                          |
|             | HTIUNBIND x 06 [1] = 0x1 | Enable streaming of CPU writes.                                   |
|             | HTIUNBIND x 06 [9] = 0x1 | Enable extended write buffer for CPU writes.                      |

| ASIC Rev     | Setting                                                                     | Function/Comment                                                                     |
|--------------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| SR5690/5670  | HTIUNBIND x 06 [13] = 0x1                                                   | Enable additional response buffers.                                                  |
| /5650        | HTIUNBIND x 06 [17] = 0x1                                                   | Enable special reads to pass writes.                                                 |
| All Revs     | HTIUNBIND x 06 [16:15] = 0x3                                                | Enable decoding of C1e/C3 and FID cycles.                                            |
|              | HTIUNBIND x 06 [25] = 0x1                                                   | Enable HTIU-display handshake bypass.                                                |
|              | HTIUNBIND x 06 [30] = 0x1                                                   | Enable tagging fix.                                                                  |
|              | HTIUNBIND x 07 [0] = 0x1                                                    | Enable byte-write optimization for IOC requests.                                     |
|              | HTIUNBIND x 07 [1] = 0x0                                                    | Disable delaying STPCLK de-assert during FID sequence.                               |
|              | HTIUNBIND x 07 [2] = 0x0                                                    | Disable upstream system-management delay.                                            |
|              | HTIUNBIND x 16 [11] = 0x1                                                   | Enable transmit PHY to reinitialize in HT1 mode when tristate is enabled             |
|              | HTIUNBIND x 1D [2] = 0x0                                                    | Enable datarate matching circuitry in the chipset                                    |
|              | HTIUNBIND x 1D [4] = 0x0                                                    | Enable sync flood detection in the chipset                                           |
|              |                                                                             | esigned to avoid DMA Deadlock. Program these registers in the order they are listed. |
|              | Also, any LPC memory-mapped regions<br>space addresses that may be accessed | ns must not be covered by one of the CPU's MMIO ranges. This includes ROM            |
|              |                                                                             | No limit for NP transactions                                                         |
|              | SB AXINDC x 10 [9] = 0x1                                                    | Enable special NP protocol in the southbridge PCIe.                                  |
|              | SB PCIEIND x 10 [9] = 0x1                                                   | Enable special NP protocol in the northbridge PCIe port attached to the southbridge. |
|              | HTIUNBIND x 06 [26] = 1                                                     | Enable special NP protocol in HTIU.                                                  |
|              | HTIUNBIND x 16 [10] = 1                                                     | Enable proper DLL reset sequence.                                                    |
|              | HTIUNBIND x 2B [31:28] = 0xF                                                | Enable BIAS circuit for all lanes.                                                   |
|              | HTIUNBIND x 0C [15:0] = 0x101                                               | Change GCM WRR to burst length of 1 for performance                                  |
| SR5690/5670/ | HTIUNBIND x 5 [3] = 0x1                                                     | Generate Disconnect Nop without credit release                                       |
| 5650         | HTIUNBIND x 5 [4] = 0x1                                                     | Reduce HT1 LDTSTOP disconnect delay                                                  |
| Rev A21      | HTIUNBIND x 5 [6] = 0x1                                                     | Prevent false error logging due to reset skew                                        |
|              | HTIUNBIND x 5 [10] = 0x1                                                    | Fix Data Rate Matching feature for 16 bit link                                       |
|              | HTIUNBIND x 5 [12] = 0x1                                                    | Allow DMA P request to pass NP request                                               |
|              | HTIUNBIND x 5 [13] = 0x1                                                    | Enable earlier CDR freeze prior to disconnect                                        |
|              | HTIUNBIND x 5 [14] = 0x1                                                    | Enhance error detection during training2                                             |
|              | HTIUNBIND x 5 [15] = 0x1                                                    | Enable proper parity error reporting for IOMMU L2A and L2B                           |
|              | HTIUNBIND x 5 [16] = 0x1                                                    | Prevent Nop insertion in extended address command in HT1                             |
|              | HTIUNBIND x 5 [17] = 0x1                                                    | Enable proper handling of 64 bit register access to IOMMU/IOAPIC space               |
|              | HTIUNBIND x 5 [18] = 0x1                                                    | Reduce false retry reporting due to LDTSTOP disconnect                               |
|              | HTIUNBIND x 5 [19] = 0x1                                                    | Improve power reduction during link disconnect                                       |

# Table 5-6HT General Register Settings (Continued)

# 5.5.2 UnitID Clumping (Optional)

The SR5690/5670/5650 supports UnitID clumping to increase the number of outstanding requests supported by a single device. Clumping is supported in Family 10h processors. It may be enabled for PCIe GPP links when using only the lower number bridge within each PCIe GPP core. For example, when using bridge 2, and not bridge 3 (UnitIDs 0x2 and 0x3), to support a single x8 or x16 PCIe link, the UnitIDs reserved for both bridges may be clumped together. Clumping may also be used with bridges 11 and 12 (UnitIDs 0xB and 0xC). The clumping register must be enabled the same in both the chipset and processor.

NOTE: If the unused/empty bridge is designed as a hot-plug slot, then clumping should be disabled.

| ASIC Rev      | Register                      | Setting | Function/Comments                                                 |
|---------------|-------------------------------|---------|-------------------------------------------------------------------|
| SR5690/5670/  | NBCFG x 5C [3]                | 0x1     | Enables clumping of UnitIDs 2 and 3.                              |
| 5650 All Revs | CPU_F0 x 11C/118/114/110 [3]  | 0x1     | Enables clumping of UnitIDs 2 and 3 in family 10h processors.     |
|               | NBCFG x 5C [12]               | 0x1     | Enables clumping of UnitIDs 0xB and 0xC.                          |
|               | CPU_F0 x 11C/118/114/110 [12] | 0x1     | Enables clumping of UnitIDs 0xB and 0xC in family 10h processors. |

Table 5-7Register Settings for UnitID Clumping

Note: These registers take effect immediately. Clumping registers are cleared on warm-reset and should be programmed before DMA traffic is enabled. CPU programming depends on the link that the chipset is connected to.

UnitID Clumping options in the SBIOS menu should be as follows:

- UnitID Clumping Disabled (default)
- Clump UnitIDs 0x2 + 0x3 and 0xB + 0xC
- Clump UnitIDs 0x2 + 0x3
- Clump UnitIDs 0xB + 0xC

If a particular pair of UnitIDs cannot be clumped because they do not meet the criteria described above, then clumping should not be enabled, regardless of the menu selection.

# 5.5.3 Extended Address Support

SR5690/5670/5650 supports HT Extended Address Packet for up to 52 bits of physical addressing in a system. Processors may not share the same address size limit (please refer to appropriate processor BKDG for more details on enabling >40-bit addressing, such as configuring the extended memory-map). The table below describes the register settings to enable this feature. Care should be taken to ensure that both NB and CPU are enabled prior to any device issuing request to high-order addresses. Also, all other HT link on the processor should enable this feature at the same time since extended address request can move between any link.

| ASIC Rev                      | Register                            | Setting    | Function/Comments                           |
|-------------------------------|-------------------------------------|------------|---------------------------------------------|
| SR5690/5670/<br>5650 All Revs | CPU_F0/F4 x E4 [15]                 | 0x1        | Enables processor Link3 Extended Addressing |
| 5050 All Revs                 |                                     |            |                                             |
|                               | CPU_F0/F4 x C4 [15]                 | 0x1        | Enables processor Link2 Extended Addressing |
|                               | CPU_F0/F4 x A4 [15]                 | 0x1        | Enables processor Link1 Extended Addressing |
|                               | CPU_F0/F4 x 84 [15]                 | 0x1        | Enables processor Link0 Extended Addressing |
|                               | NBCFG x C8 [15]                     | 0x1        | Enables NB Extended Addressing              |
| Note: These reg               | jisters require a warm reset to tal | ke effect. | ·                                           |

## 5.5.4 Isochronous Flow-Control Mode

The SR5690/5670/5650 supports the use of the Isochronous Flow-Control Mode (IFCM) function to provide reduced latency and avoid deadlocks for IOMMU table walker requests. In this mode, dedicated flow-control buffering must be reserved inside of the processor. Refer to the register settings in section 5.5.5 to reserve the isochronous flow-control buffers along with the appropriate processor BKDG. In addition to this, the isochronous mode must be enabled.

#### Table 5-9Register Settings for Enabling Isochronous Flow-Control Mode

| ASIC Rev      | Register                  | Setting                       | Function/Comments                              |
|---------------|---------------------------|-------------------------------|------------------------------------------------|
| SR5690/5670/  | NBCFG x C8 [12]           | 0x1                           | Enables IFCM in the chipset.                   |
| 5650 All Revs | CPU_F0 x E4/C4/A4/84 [12] | 0x1 if Link 1 is connected to | Enables IFCM on the link between processor and |
|               |                           | SR5690/5670/5650; 0x0         | chipset.                                       |
|               |                           | otherwise                     |                                                |

If isochronous flow-control mode is not enabled, the legacy display refresh mode should be enabled.

#### Table 5-10Register Settings for Enabling Display-Refresh in Normal Flow Control Mode

| ASIC Rev      | Register         | Setting | Function/Comments                                                                    |
|---------------|------------------|---------|--------------------------------------------------------------------------------------|
| SR5690/5670/  | CPU F0 x 68 [24] | 0x1     | Enables Display Refresh Mode in the processor. This setting applies to family 10h    |
| 5650 All Revs |                  |         | processors. This bit takes effect immediately. Please set it after the warm reset is |
|               |                  |         | used to make changes to HyperTransport and processor XBAR/XCS buffer                 |
|               |                  |         | allocations take effect.                                                             |

#### 5.5.5 Family 10h Processor Buffer Allocation Settings

This section only covers buffer allocation for Non-Coherent link. Please refer to Family 10h BKDG for Coherent link buffer allocation. The settings below are based on register definition for Family 10h Rev C processor.

Definitions:

Sublink – A group of 8 consecutive HT lanes, also called byte lane.

**Ganged** – When two sublinks work together and act as one 16-bit HT link. Most client systems or single NB platforms use Ganged HT link between processor and NB.

**Ungange**d – When sublink connects individually and act as two separate 8-bit HT link. In certain server configurations with multiple NB, the HT link between processor and NB might be Unganged.

Non-Coherent link – This refers to HT link between processor and NB.

Coherent link – This refers to HT link between processor and processor.

NFCM - Normal Flow Control Mode.

IFCM – Isochronous Flow Control Mode.

#### 5.5.5.1 HT Buffer Allocation for Ganged Links

#### Table 5-11HT Buffer Allocation for Ganged, Non-Coherent Links and Normal Flow-Control Mode

| ASIC Rev      | Register                     | Setting | Function/Comments                    |
|---------------|------------------------------|---------|--------------------------------------|
| SR5690/5670/  | CPU_F0 x F0/D0/B0/90 [27:25] | 0x1     | 2 Free Data                          |
| 5650 All Revs | CPU_F0 x F0/D0/B0/90 [24:20] | 0x8     | 16 Free Commands                     |
|               | CPU_F0 x F0/D0/B0/90 [19:18] | 0x1     | 2 Response Data                      |
|               | CPU_F0 x F0/D0/B0/90 [17:16] | 0x0     | 0 Non-posted Data                    |
|               | CPU_F0 x F0/D0/B0/90 [15:12] | 0x0     | 0 Probe Commands                     |
| -             | CPU_F0 x F0/D0/B0/90 [11:8]  | 0x1     | 2 Response Commands                  |
|               | CPU_F0 x F0/D0/B0/90 [7:5]   | 0x6     | 12 Posted Command and 12 Posted Data |
|               | CPU F0 x F0/D0/B0/90 [4:0]   | 0x11    | 34 Non-posted Commands               |

© 2012 Advanced Micro Devices, Inc.

| ASIC Rev    | Register                     | Setting | Function/Comments                     |
|-------------|------------------------------|---------|---------------------------------------|
| SR5690/5670 | CPU_F0 x F0/D0/B0/90 [27:25] | 0x1     | 2 Free Data                           |
| /5650 All   | CPU_F0 x F0/D0/B0/90 [24:20] | 0x8     | 16 Free Commands                      |
| Revs        | CPU_F0 x F0/D0/B0/90 [19:18] | 0x1     | 2 Response Data                       |
|             | CPU_F0 x F0/D0/B0/90 [17:16] | 0x0     | 0 Non-posted Data                     |
|             | CPU_F0 x F0/D0/B0/90 [15:12] | 0x0     | 0 Probe Commands                      |
|             | CPU_F0 x F0/D0/B0/90 [11:8]  | 0x1     | 2 Response Commands                   |
|             | CPU_F0 x F0/D0/B0/90 [7:5]   | 0x6     | 12 Posted Commands and 12 Posted Data |
|             | CPU_F0 x F0/D0/B0/90 [4:0]   | 0xF     | 30 Non-posted Commands                |
|             | CPU_F0 x F4/D4/B4/94 [18:16] | 0x2     | 4 Isochronous Non-posted Commands     |

#### Table 5-12HT Buffer Allocation for Ganged, Non-Coherent Links and Isochronous Flow-Control Mode

## 5.5.5.2 HT Buffer Allocation for Unganged Links

The settings below assume the other sublink is connected to another processor that uses Coherent HT with default buffer allocation (i.e., sublink 0 is connected to SR5690/5670/5650 and sublink 1 is connected to Family 10 processor, or vice-versa). If both sublinks are connected to SR5690/5670/5650, then refer to *Table 5.5.5.1*, *"HT Buffer Allocation for Ganged Links," on page 5-7.* If both sublinks are connected to Family 10 processor, then please refer to BKDG for more details.

The values below are applicable to Family 10h Rev C processor. For Family 10h Rev D processor, one needs to double the value in Free Data and Free Command fields, in order to achieve the same amount of buffer.

| ASIC Rev    | Register                     | Setting        | Function/Comments                  |
|-------------|------------------------------|----------------|------------------------------------|
| SR5690/5670 | CPU_F0 x F0/D0/B0/90 [27:25] | 0x1 for Rev C  | 2 Free Data                        |
| 5650        |                              | 0x for Rev D   |                                    |
| All Revs    | CPU_F0 x F0/D0/B0/90 [24:20] | 0x8 for Rev C  | 16 Free Commands                   |
|             |                              | 0x16 for Rev D |                                    |
|             | CPU_F0 x F0/D0/B0/90 [19:18] | 0x1            | 1 Response Data                    |
|             | CPU_F0 x F0/D0/B0/90 [17:16] | 0x0            | 0 Non-posted Data                  |
|             | CPU_F0 x F0/D0/B0/90 [15:12] | 0x0            | 0 Probe Commands                   |
|             | CPU_F0 x F0/D0/B0/90 [11:8]  | 0x1            | 1 Response Command                 |
|             | CPU_F0 x F0/D0/B0/90 [7:5]   | 0x6            | 6 Posted Command and 6 Posted Data |
|             | CPU_F0 x F0/D0/B0/90 [4:0]   | 0x11           | 17 Non-posted Commands             |

Table 5-13HT Buffer Allocation for Unganged, Sublink0, Non-Coherent Links and Normal Flow-Control Mode (NFCM)

Table 5-14HT Buffer Allocation for Unganged, Sublink0, Non-Coherent links and Isochronous Flow-Control Mode (IFCM)

| ASIC Rev      | Register                     | Setting        | Function/Comments                   |
|---------------|------------------------------|----------------|-------------------------------------|
| SR5690/5670/  | CPU_F0 x F0/D0/B0/90 [27:25] | 0x1 for Rev C  | 2 Free Data                         |
| 5650 All Revs |                              | 0x for Rev D   |                                     |
|               | CPU_F0 x F0/D0/B0/90 [24:20] | 0x8 for Rev C  | 16 Free Commands                    |
|               |                              | 0x16 for Rev D |                                     |
|               | CPU_F0 x F0/D0/B0/90 [19:18] | 0x1            | 1 Response Data                     |
|               | CPU_F0 x F0/D0/B0/90 [17:16] | 0x0            | 0 Non-posted Data                   |
|               | CPU_F0 x F0/D0/B0/90 [15:12] | 0x0            | 0 Probe Commands                    |
|               | CPU_F0 x F0/D0/B0/90 [11:8]  | 0x1            | 1 Response Command                  |
|               | CPU_F0 x F0/D0/B0/90 [7:5]   | 0x6            | 6 Posted Commands and 6 Posted Data |
|               | CPU_F0 x F0/D0/B0/90 [4:0]   | 0xF            | 15 Non-posted Command               |
|               | CPU_F0 x F4/D4/B4/94 [18:16] | 0x2            | 2 Isochronous Non-posted Commands   |

AMD SR5690/5670/5650 Register Programming Requirements 5-8

| Register                     | Setting                                                                                                                                                                                                                   | Function/Comments                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU_F4 x F0/D0/B0/90 [27:25] | 0x1 for Rev C                                                                                                                                                                                                             | 2 Free Data                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                              | 0x for Rev D                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CPU_F4 x F0/D0/B0/90 [24:20] | 0x8 for Rev C                                                                                                                                                                                                             | 16 Free Commands                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                              | 0x16 for Rev D                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CPU_F4 x F0/D0/B0/90 [19:18] | 0x1                                                                                                                                                                                                                       | 1 Response Data                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CPU_F4 x F0/D0/B0/90 [17:16] | 0x0                                                                                                                                                                                                                       | 0 Non-posted Data                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CPU_F4 x F0/D0/B0/90 [15:12] | 0x0                                                                                                                                                                                                                       | 0 Probe Commands                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| CPU_F4 x F0/D0/B0/90 [11:8]  | 0x1                                                                                                                                                                                                                       | 1 Response Command                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CPU_F4 x F0/D0/B0/90 [7:5]   | 0x6                                                                                                                                                                                                                       | 6 Posted Commands and 6 Posted Data                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CPU_F4 x F0/D0/B0/90 [4:0]   | 0x11                                                                                                                                                                                                                      | 17 Non-posted Commands                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                              | CPU_F4 x F0/D0/B0/90 [27:25]<br>CPU_F4 x F0/D0/B0/90 [24:20]<br>CPU_F4 x F0/D0/B0/90 [19:18]<br>CPU_F4 x F0/D0/B0/90 [17:16]<br>CPU_F4 x F0/D0/B0/90 [15:12]<br>CPU_F4 x F0/D0/B0/90 [11:8]<br>CPU_F4 x F0/D0/B0/90 [7:5] | CPU_F4 x F0/D0/B0/90 [27:25]         0x1 for Rev C           0x for Rev D         0x for Rev C           0x16 for Rev D         0x8 for Rev C           0x16 for Rev D         0x16 for Rev D           CPU_F4 x F0/D0/B0/90 [19:18]         0x1           CPU_F4 x F0/D0/B0/90 [17:16]         0x0           CPU_F4 x F0/D0/B0/90 [15:12]         0x0           CPU_F4 x F0/D0/B0/90 [11:8]         0x1           CPU_F4 x F0/D0/B0/90 [17:5]         0x6 |

Table 5-15HT Buffer Allocation for Unganged, Sublink1, Non-Coherent links and Non-isoc Flow-Control Mode (NFCM)

# Table 5-16HT Buffer Allocation for Unganged, Sublink1, Non-Coherent links and Isochronous Flow-Control Mode (IFCM)

| ASIC Rev        | Register                                     | Setting        | Function/Comments                   |
|-----------------|----------------------------------------------|----------------|-------------------------------------|
| SR5690/5670/    | CPU_F4 x F0/D0/B0/90 [27:25]                 | 0x1 for Rev C  | 2 Free Data                         |
| 5650 All Revs   |                                              | 0x for Rev D   |                                     |
|                 | CPU_F4 x F0/D0/B0/90 [24:20]                 | 0x8 for Rev C  | 16 Free Commands                    |
|                 |                                              | 0x16 for Rev D |                                     |
|                 | CPU_F4 x F0/D0/B0/90 [19:18]                 | 0x1            | 1 Response Data                     |
|                 | CPU_F4 x F0/D0/B0/90 [17:16]                 | 0x0            | 0 Non-posted Data                   |
|                 | CPU_F4 x F0/D0/B0/90 [15:12]                 | 0x0            | 0 Probe Commands                    |
|                 | CPU_F4 x F0/D0/B0/90 [11:8]                  | 0x1            | 1 Response Command                  |
|                 | CPU_F4 x F0/D0/B0/90 [7:5]                   | 0x6            | 6 Posted Commands and 6 Posted Data |
|                 | CPU_F4 x F0/D0/B0/90 [4:0]                   | 0xF            | 15 Non-posted Commands              |
|                 | CPU_F4 x F4/D4/B4/94 [18:16]                 | 0x2            | 2 Isochronous Non-posted Commands   |
| Note: These reg | gisters require a warm reset to take effect. |                | L                                   |

## 5.5.5.3 XBAR/XCS Buffer Allocation

All XBAR/XCS buffer allocation settings should follow the recommendations in the appropriate processor family BKDG. The multiple-link processor settings should be used.

# 5.5.6 HyperTransport<sup>™</sup> Protocol Checker

In any HyperTransport mode, the SR5690/5670/5650 can perform basic checks on the HyperTransport protocol in order to detect errors separately from the periodic CRC or per-packet CRC mechanism.

#### Table 5-17Register Settings for HT Protocol Checker

| ASIC Rev      | Register              | Setting     | Function/Comments                                           |
|---------------|-----------------------|-------------|-------------------------------------------------------------|
| SR5690/5670/  | HTIUNBIND x 1E [31:0] | 0x7FFF_FFFC | Enables the HyperTransport protocol checker in the chipset. |
| 5650 All Revs |                       |             |                                                             |

## 5.5.7 Transmitter De-emphasis

The following table contains guidelines on how to set the SR5690/5670/5650 HT transmitter de-emphasis level. These are a starting point and adjustments may be necessary to optimize for a specific platform implementation. The de-emphasis level is programmed through NBCFG x A4 [26:24].

| ASIC Rev                | Trace Length                                | De-Emphasis Level | De-Emphasis Code |
|-------------------------|---------------------------------------------|-------------------|------------------|
| SR5690/5670/5650        | 0 to 4.5"                                   | -1.32dB           | 0x1              |
| All Revs                | 4.5" to 8"                                  | -2.08dB           | 0x2              |
|                         | 8" to 11"                                   | -3.1dB            | 0x3              |
|                         | 11" to 14"                                  | -4.22dB           | 0x4              |
|                         | 14" to 18"                                  | -5.50dB           | 0x5              |
|                         | 18+"                                        | -7.05dB           | 0x6              |
|                         | 18+"                                        | -9.0dB            | 0x7 *            |
| * This setting may be u | useful for extremely long or lossy channels |                   |                  |

#### 5.5.8 Low-Power HyperTransport<sup>™</sup> Features

#### 5.5.8.1 HyperTransport 1

In HyperTransport 1 mode, the SR5690/5670/5650 can tristate parts of the link in order to reduce power consumption. By default, no lanes are tristated. The CAD and CTL lanes may be tristated together or CAD, CTL, and CLK may be tristated.

#### Table 5-19Register Settings for Tristating CAD and CTL

| ASIC Rev      | Register                     | Setting | Function/Comments                       |
|---------------|------------------------------|---------|-----------------------------------------|
| SR5690/5670/  | NBCFG x C8 [13]              | 0x1     | Enables HT Tristate in the chipset      |
| 5650 All Revs | NBCFG x AC [8]               | 0x0     | Disables HT CLK Tristate in the chipset |
|               | CPU_F0 x E4/C4/A4/84 [13]    | 0x1     | Enables HT Tristate in the CPU          |
|               | CPU_F0 x 17C/178/174/170 [8] | 0x0     | Disables HT CLK Tristate in the CPU     |

#### Table 5-20Register Settings for Tristating CAD, CTL and CLK

| ASIC Rev      | Register                     | Setting | Function/Comments                       |
|---------------|------------------------------|---------|-----------------------------------------|
| SR5690/5670/  | NBCFG x C8 [13]              | 0x1     | Enables HT Tristate in the chipset.     |
| 5650 All Revs | NBCFG x AC [8]               | 0x1     | Enables HT CLK Tristate in the chipset. |
|               | CPU_F0 x E4/C4/A4/84 [13]    | 0x1     | Enables HT Tristate in the CPU.         |
|               | CPU_F0 x 17C/178/174/170 [8] | 0x1     | Enables HT CLK Tristate in the CPU.     |
|               | CPU F3 x D8 [27:24]          | 0x3     | Reconnects the Delay Timer in the CPU.  |
|               |                              |         |                                         |

#### 5.5.8.2 HyperTransport 3

In HyperTransport 3 mode, the SR5690/5670/5650 supports the LS1 and the LS2 low-power states when LDTSTOP# is asserted, programmable through the LSSel register. The system must enable either the LS1 or the LS2 low power states. The LS1 features low reconnection latency but higher power consumption relative to the LS2.

#### Table 5-21Register Settings for LS1

| ASIC Rev      | Register                     | Setting | Function/Comments                  |
|---------------|------------------------------|---------|------------------------------------|
| SR5690/5670/5 | NBCFG x AC [8:7]             | 0x0     | Enables LS1 in the chipset.        |
| 650 All Revs  | CPU_F0 x 17C/178/174/170 [8] | 0x0     | Enables LS1 in the Family 10h CPU. |

#### Table 5-22Register Settings for LS2

| ASIC Rev      | Register                     | Setting | Function/Comments                              |
|---------------|------------------------------|---------|------------------------------------------------|
| SR5690/5670/5 | NBCFG x AC [8:7]             | 0x2     | Enables LS2 in the chipset.                    |
| 650 All Revs  | HTIUNBIND x 15 [27]          | 0x1     | Powers down the chipset DLLs in the LS2 state. |
|               | CPU_F0 x 17C/178/174/170 [8] | 0x1     | Enables LS2 in the Family 10h CPU.             |

#### 5.5.8.3 Inactive Lane State

When the HT link width is reduced below 16 bits in either direction, the electrical state of the inactive lanes will be controlled by the Inactive Lane State register. The chipset inactive lane state register setting is based on the values programmed in the processor as per the following table.

Table 5-23Register Settings for HT1 and HT3 Inactive Lane State

| ASIC Rev      | HT Mode and LS State   | Processor InLnSt<br>Setting<br>CPU_F0 x 16C [7:6] | Program chipset InLnSt<br>Register<br>NBCFG x A0 [7:6] | Function/Comments                          |
|---------------|------------------------|---------------------------------------------------|--------------------------------------------------------|--------------------------------------------|
| SR5690/5670/  | 8-bit HT link (HT1 or  | Any                                               | 0x1                                                    | Place the upper half of the HT PHY into    |
| 5650 All Revs | HT3)                   |                                                   |                                                        | the PHY_OFF state to maximize power        |
|               |                        |                                                   |                                                        | savings. Processor side of the link should |
|               |                        |                                                   |                                                        | be off via processor TransOff and          |
|               |                        |                                                   |                                                        | EndofChain register bits.                  |
|               | HT1 and 16-bit HT link | 0x0                                               | 0x0                                                    | Warm reset signalling                      |
|               |                        | 0x1                                               | 0x1                                                    | PHY_OFF state                              |
|               |                        | 0x2                                               | 0x2                                                    | Operational signaling                      |
|               |                        | 0x3                                               | 0x3                                                    | Tristate                                   |
|               | HT3 LS1 and 16-bit HT  | 0x0                                               | 0x0                                                    | Warm reset signalling                      |
|               | link                   | 0x1                                               | 0x0                                                    | Do not enable HT3 LS1 with InLnSt=0x1      |
|               |                        |                                                   |                                                        | (PHY_OFF) as per errata 9.                 |
|               |                        | 0x2                                               | 0x2                                                    | Operational signaling                      |
|               |                        | 0x3                                               | 0x3                                                    | LS1 disconnected state                     |
|               | HT3 LS2 and 16-bit HT  | 0x0                                               | 0x0                                                    | Warm reset signaling                       |
|               | link                   | 0x1                                               | 0x1                                                    | PHY_OFF state                              |
|               |                        | 0x2                                               | 0x2                                                    | Operational signaling                      |
|               |                        | 0x3                                               | 0x3                                                    | LS2 disconnected state                     |

## 5.5.8.4 Generalized Stutter Mode

Generalized Stutter Mode (GSM) must be enabled when enabling the C1e low power state in the processor. This feature allows the chipset to reconnect the HT link when the processor is in the C1e state in order to pass DMA requests to memory.

#### Table 5-24Register Settings for GSM

| SR5690/5670/  | NBMISCIND x C [13]     | 0x1   | Enables GSM Mode.                                  |
|---------------|------------------------|-------|----------------------------------------------------|
| 5650 All Revs | HTIUNBIND x 1C [31:17] | 0xFFF | Enables all traffic to be detected as GSM traffic. |

This chapter discusses the IOAPIC registers, initialization and feature programming. The IOAPIC can improve system performance significantly by delivering the interrupts to the system quickly and exposing more unique interrupt vectors. IOAPIC is only used for legacy interrupts and it is not used for MSI based interrupts.

Chapter 6

**IOAPIC** 

# 6.1 IOAPIC Register Spaces



Register Set #1 Configuration Space Registers

Register Set #2 Direct Memory Mapped Registers



Figure 6-1 IOAPIC Register Spaces

Four register spaces are involved in the IOAPIC block:

- Northbridge configuration space (NBCFG)
- IOAPIC configuration registers space indirect
- Direct memory mapped registers space

• Indirect memory mapped registers space.

# 6.1.1 IOAPIC Registers in the NBCFG Space

The Northbridge Configuration space has 2 registers - Index and Data. These allow the user to access the IOAPIC Configuration space.

| Register | Address in NBCFG Space | pace Description                                              |  |
|----------|------------------------|---------------------------------------------------------------|--|
| INDEX    | 0xF8                   | Address of the IOAPIC's indirect configuration space register |  |
| DATA     | 0xFC                   | Data to be written at the address                             |  |

# 6.1.2 IOAPIC Configuration Registers Space

This configuration space deals with the basic features and controls of the IOAPIC. This register space also allows the user to set the base address for the memory mapped registers. The Memory Mapped register space cannot be accessed until the Base Address Register (BAR) is defined. (Note: BAR is made up of two registers - IOAPIC\_Conf\_Lower and IOAPIC\_Conf\_Upper.)

Table 6-2 IOAPIC Configuration BAR Registers

| ASIC Rev      | Register          | Address in IOAPIC<br>Configuration Space | Bits | Field Name        | Description                                   |
|---------------|-------------------|------------------------------------------|------|-------------------|-----------------------------------------------|
| SR5690/5670/5 | IOAPIC_Conf_Lower | 0x01                                     | 2:0  | Reserved          | Reserved                                      |
| 650 All Revs  |                   |                                          | 3    | Mem_IO_Map        | Base Address Mapping                          |
|               |                   |                                          |      |                   | 1: Memory Map                                 |
|               |                   |                                          |      |                   | 0: IO Map                                     |
|               |                   |                                          |      |                   | (Set to 1 by default)                         |
|               |                   |                                          | 4    | Reserved          | Reserved                                      |
|               |                   |                                          | 31:5 | IOAPIC_Addr       | Base Address for IOAPIC (default to FEC000xx) |
|               | IOAPIC_Conf_Upper | 0x02                                     | 31:0 | IOAPIC_Addr_Upper | Base Address for IOAPIC (default to FEC000xx) |

Note: The XAPIC\_BASE\_REGISTER has a power-on default value of FEC0\_0000H.

# 6.1.3 IOAPIC Direct Memory Mapped Registers Space

Once the BAR register has been written in the IOAPIC Configuration space, these memory mapped registers become accessible. There are 4 direct registers in the memory mapped register space:

Table 6-3 1-3 IOAPIC Memory Mapped Registers

| Asic Rev                      | Register                       | Address in IOAPIC Direct<br>Memory Mapped Space | Bits | Field Name                  | Description                                                                      |
|-------------------------------|--------------------------------|-------------------------------------------------|------|-----------------------------|----------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs | IO_Register_Select_I<br>ndex   | BAR register + 0x00                             | 7:0  | Indirect_Address_<br>Offset | Indirect Address Offset                                                          |
|                               | ndox                           |                                                 | 31:8 | Reserved                    |                                                                                  |
|                               | IO_Window_Register             | BAR register + 0x10                             | 31:0 | Window                      | Data to be written to the register<br>selected by the indirect address<br>offset |
|                               | IRQ_PIN_ASSERTIO<br>N_REGISTER | BAR register + 0x20                             | 7:0  | Input_IRQ                   | Write Only. IRQ number for the<br>requested interrupt                            |
|                               |                                |                                                 | 31:8 | Reserved                    |                                                                                  |
|                               | EOI_REGISTER                   | BAR register + 0x20                             | 7:0  | Vector                      | Write Only. Interrupt vector                                                     |
|                               |                                |                                                 | 31:8 | Reserved                    |                                                                                  |

IO Register Select – Allows access to the indirect registers in the memory mapped space. Bits 7-0 indicate the
addresses of the indirect registers, the rest are reserved.

- IO Window Register Allows data to be written to the indirect registers. This is a 32 bit register. The Select and Window registers are used together to access the indirect registers.
- IRQ PIN Assertion Writing to this register causes the IOAPIC to generate an interrupt. Any number between 0 and 31/23 can be written to this register and the IOAPIC will generate that particular interrupt. Only bits 7-0 can be used while the reset are reserved.
- EOI Register For level sensitive interrupts, the CPU needs to indicate to the IOAPIC that the interrupt has been serviced. The IOAPIC will keep the corresponding remote IRR bit high until it receives such a message. The CPU can send this EOI message in 2 ways: It can either send an EOI broadcast message over HyperTransport<sup>™</sup>, or it can write to the EOI register. The CPU must **not** try to create a collision by clearing one level sensitive interrupt using a broadcast message and clearing a second level sensitive interrupt by writing to this register **at the same time**. The CPU must make sure that while it is sending a broadcast message it does not write to this register.

# 6.1.4 IOAPIC Indirect Memory Mapped Registers Space

The first 3 memory mapped indirect registers are: IOAPIC ID, IOXAPIC Version, and IOAPIC Arbitration.

| ASIC Rev    | Register           | Address in IOAPIC Indirect<br>Memory Mapped Space | Bits  | Field Name      | Description                              |
|-------------|--------------------|---------------------------------------------------|-------|-----------------|------------------------------------------|
| SR5690/5670 | IOAPIC_ID_REGISTER | 0x00                                              | 23:0  | Reserved        |                                          |
| /5650 All   |                    |                                                   | 27:24 | ID              | IOAPIC device ID for APIC serial bus     |
| Revs        |                    |                                                   |       |                 | delivery mode. Read Only.                |
|             |                    |                                                   | 31:28 | Extended ID     | Extended IOAPIC device ID for APIC       |
|             |                    |                                                   |       |                 | serial bus delivery mode, if the         |
|             |                    |                                                   |       |                 | loapic_id_ext_en is set to 1. Read Only  |
|             | IOAPIC_VERSION_RE  | 0x01                                              | 7:0   | Version         | PCI 2.2 compliant. This register has a   |
| /5650 All   | GISTER             |                                                   |       |                 | default value of hx21. Read Only         |
| Revs        |                    |                                                   | 14:8  | Reserved        |                                          |
|             |                    |                                                   | 15    | PRQ             | IRQ pin assertion supported. Default     |
|             |                    |                                                   |       |                 | value for this bit is 1. Read Only.      |
|             |                    |                                                   | 23:16 | Max Redirection | Defaults to 23 entries – This register   |
|             |                    |                                                   |       | Entries         | show the number of entries minus 1. If   |
|             |                    |                                                   |       |                 | the loapic_entrees bit in the            |
|             |                    |                                                   |       |                 | Features_Enable register is set to 1,    |
|             |                    |                                                   |       |                 | the value in this register will be 31.   |
|             |                    |                                                   |       |                 | Read Only                                |
|             |                    |                                                   | 31:24 | Reserved        |                                          |
|             | IOAPIC_ARBITRATION | 0x02                                              | 23:0  | Reserved        |                                          |
| /5650 All   | _REGISTER          |                                                   | 27:24 | Arbitration_ID  | Arbitration ID for APIC serial bus       |
| Revs        |                    |                                                   |       |                 | delivery mode. Not supported. The        |
|             |                    |                                                   |       |                 | Arbitration register is not supported as |
|             |                    |                                                   |       |                 | there is no longer a discrete APIC bus.  |
|             |                    |                                                   | 31:28 | Reserved        |                                          |

## Table 6-4 IOAPIC Indirect Memory Mapped Registers

# 6.2 **IOAPIC Operation**

The following steps are required to operate the IOAPIC:

1) Write the Base Address Register (BAR), see section 6.1: "*IOAPIC Configuration Registers Space*" on page 6-2. Note: BAR has a power-on default value of FEC0\_00xx.

2) Write to the IOAPIC Features Enable register (see *Table 6-5*), which performs the following:

- Switches on IOAPIC
- Sets the number of interrupts entries inside IOAPIC (32 or 24)
- Allows the IOAPIC to send "wake" signals to the IOC, upon interrupt generation.
- Switches on the southbridge feature, which allows masked interrupt entries to be routed to the southbridge.

| ASIC Rev    | Register        | Address in IOAPIC<br>Configuration Space | Bits | Field Name       | Description                                                                  |
|-------------|-----------------|------------------------------------------|------|------------------|------------------------------------------------------------------------------|
| SR5690/5670 | Features_enable | 0x00                                     | 0    | loapic_enable    | When set, this block will decode ioapic address                              |
| /5650 All   |                 |                                          | 1    | loapic_entries   | 1 = 32 entry IOAPIC                                                          |
| Revs        |                 |                                          |      |                  | 0 = 24 entry IOAPIC                                                          |
|             |                 |                                          | 2    | loapic_id_ext_en | Extend IOAPIC ID from 4-bit to 8-bit                                         |
|             |                 |                                          | 3    | loapic_c2wake_en | Generate C2Wake messages to the IOC                                          |
|             |                 |                                          | 4    | • – – –          | Allows masked interrupts to be re-routed back to the south bridge PIC/IOAPIC |

#### Table 6-5 IOAPIC Features Enable Register

3) Write to the remaining interrupt routing registers. Configure the interrupt routing which routes the 58 incoming interrupts to 32 or 24 interrupt depending on the mode (see *section 6.3*: *"Setting Interrupts" on page 6-5*). A recommended configuration is shown below:

| Device    | IOAPIC Mapped Group | Swizzling | Device's Bridge PIN Mapping |
|-----------|---------------------|-----------|-----------------------------|
| HT        |                     |           | 31                          |
| IOMMU     |                     |           | 31                          |
| Device 2  | 0                   | ABCD      | 28                          |
| Device 3  | 1                   | ABCD      | 28                          |
| Device 4  | 5                   | ABCD      | 28                          |
| Device 5  | 5                   | CDAB      | 28                          |
| Device 6  | 6                   | BCDA      | 29                          |
| Device 7  | 6                   | CDAB      | 29                          |
| Device 9  | 6                   | ABCD      | 29                          |
| Device 10 | 5                   | BCDA      | 30                          |
| Device 11 | 2                   | ABCD      | 30                          |
| Device 12 | 3                   | ABCD      | 30                          |
| Device 13 | 4                   | ABCD      | 30                          |

#### Table 6-6 Recommended Interrupt Routing Configuration

4) Write to the redirection table entrees in the memory mapped space Enable/disable interrupts using the mask bits, assign vectors, destination ID, trigger modes for each of the 32 or 24 interrupts (see section 6.5: *"Redirection Table Entry Registers" on page 6-15*).

# 6.3 Setting Interrupts

The IOAPIC has a total of 58 interrupt inputs. These 58 interrupts are mapped to either 32 or 24 interrupt entries depending on the mode selected in the Features Enable register. There are 11 groups of interrupts, each group having a 4 interrupt bus (INT A, B, C, D). This gives a total of 44 interrupts coming from groups. The remaining 14 interrupts are single bit interrupts (see section 6.3: "Individual Interrupt Routing" on page 6-8). The Group Interrupt Routing registers, shown below, deal with all 11 groups and the 14 individual interrupts. Each group is assigned a output group number and a swizzle number. Individual bits are assigned an output pin number.

# 6.3.1 Group Interrupt Routing Registers

| ASIC Rev                      | Register                          | Address in<br>IOAPIC<br>Configuration<br>Space | Field Name     | Bits  | Description                                                                                                                                                        |       |                                                                                                                                                                    |
|-------------------------------|-----------------------------------|------------------------------------------------|----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs | IOAPIC_Int_routing_register_<br>1 | 0x03                                           | D2ext_Intr_grp | 2:0   | Map D2 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                   |       |                                                                                                                                                                    |
|                               |                                   |                                                | D2ext_Intr_swz | 5:4   | Swizzle D2 external INT A/B/C/D based on the<br>value in this register before mapping them<br>onto the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC |       |                                                                                                                                                                    |
|                               |                                   |                                                | D3ext_Intr_grp | 10:8  | Map D3 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                   |       |                                                                                                                                                                    |
|                               |                                   |                                                |                |       | D3ext_Intr_swz                                                                                                                                                     | 13:12 | Swizzle D3 external INT A/B/C/D based on the<br>value in this register before mapping them<br>onto the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC |
|                               |                                   |                                                | D4ext_Intr_grp | 18:16 | Map D4 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                   |       |                                                                                                                                                                    |
|                               |                                   |                                                |                |       | D4ext_Intr_swz                                                                                                                                                     | 21:20 | Swizzle D4 external INT A/B/C/D based on the<br>value in this register before mapping them<br>onto the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC |
|                               |                                   |                                                | D5ext_Intr_grp | 26:24 | Map D5 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                   |       |                                                                                                                                                                    |
|                               |                                   |                                                | D5ext_Intr_swz | 29:28 | Swizzle D5 external INT A/B/C/D based on the<br>value in this register before mapping them<br>onto the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC |       |                                                                                                                                                                    |

| ASIC Rev                      | Register                          | Address in<br>IOAPIC<br>Configuration<br>Space | Field Name      | Bits  | Description                                                                                                                                                         |
|-------------------------------|-----------------------------------|------------------------------------------------|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs | IOAPIC_Int_routing_register_<br>2 | 0x04                                           | D6ext_Intr_grp  | 2:0   | Map D6 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                    |
|                               |                                   |                                                | D6ext_Intr_swz  | 5:4   | Swizzle D6 external INT A/B/C/D based on the<br>value in this register before mapping them onto<br>the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC  |
|                               |                                   |                                                | D7ext_Intr_grp  | 10:8  | Map D7 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                    |
|                               |                                   |                                                | D7ext_Intr_swz  | 13:12 | Swizzle D7 external INT A/B/C/D based on the<br>value in this register before mapping them onto<br>the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC  |
|                               |                                   |                                                | D9ext_Intr_grp  | 18:16 | Map D9 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                    |
|                               |                                   |                                                | D9ext_Intr_swz  | 21:20 | Swizzle D9 external INT A/B/C/D based on the<br>value in this register before mapping them onto<br>the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC  |
|                               |                                   |                                                | D10ext_Intr_grp | 26:24 | Map D10 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                   |
|                               |                                   |                                                | D10ext_Intr_swz | 29:28 | Swizzle D10 external INT A/B/C/D based on<br>the value in this register before mapping them<br>onto the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC |

## Table 6-8 IOAPIC Interrupt Routing Register 2

Table 6-9 IOAPIC Interrupt Routing Register 3

| ASIC Rev                      | Register                          | Address in<br>IOAPIC<br>Configuration<br>Space |                 | Bits  | Description                                                                                                                                                         |
|-------------------------------|-----------------------------------|------------------------------------------------|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs | IOAPIC_Int_routing_regi<br>ster 3 | 0x05                                           | D11ext_Intr_grp | 2:0   | Map D11 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                   |
|                               | _                                 |                                                | D11ext_Intr_swz | 5:4   | Swizzle D11 external INT A/B/C/D based on the<br>value in this register before mapping them onto<br>the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC |
|                               |                                   |                                                | D12ext_Intr_grp | 10:8  | Map D12 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                   |
|                               |                                   |                                                | D12ext_Intr_swz | 13:12 | Swizzle D12 external INT A/B/C/D based on the<br>value in this register before mapping them onto<br>the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC |
|                               |                                   |                                                | D13ext_Intr_grp | 18:16 | Map D13 external INTA/B/C/D to IOAPIC pins<br>[(grp*4):(grp-1)*4]                                                                                                   |
|                               |                                   |                                                | D13ext_Intr_swz | 21:20 | Swizzle D13 external INT A/B/C/D based on the<br>value in this register before mapping them onto<br>the IOAPIC pins<br>0 – ABCD<br>1 – BCDA<br>2 – CDAB<br>3 – DABC |

# 6.3.2 Individual Interrupt Routing

For the individual interrupts, the configuration space only has a pin mapping number. This pin mapping number decides which of the 32 or 24 interrupt pins the individual interrupts map to.



Figure 6-2 Individual Interrupt Routing

#### Table 6-10 IOAPIC Interrupt Routing Register 4

| ASIC Rev      | Register                      | Address in IOAPIC<br>Configuration Space | Field Name     | Bits  | Description                        |
|---------------|-------------------------------|------------------------------------------|----------------|-------|------------------------------------|
| SR5690/5670/  | IOAPIC_Int_routing_register_4 | 0x06                                     | D2int_Intr_map | 4:0   | Map D2 bridge interrupts to IOAPIC |
| 5650 All Revs |                               |                                          |                |       | pin D2_Intr_map                    |
|               |                               |                                          | D3int_Intr_map | 12:8  | Map D3 bridge interrupts to IOAPIC |
|               |                               |                                          |                |       | pin D3_Intr_map                    |
|               |                               |                                          | D4int_Intr_map | 20:16 | Map D4 bridge interrupts to IOAPIC |
|               |                               |                                          |                |       | pin D4_Intr_map                    |
|               |                               |                                          | D5int_Intr_map | 28:24 | Map D5 bridge interrupts to IOAPIC |
|               |                               |                                          |                |       | pin D5_Intr_map                    |

#### Table 6-11 IOAPIC Interrupt Routing Register 5

| ASIC Rev      | Register                      | Address in IOAPIC<br>Configuration Space | Field Name     | Bits  | Description                 |
|---------------|-------------------------------|------------------------------------------|----------------|-------|-----------------------------|
| SR5690/5670/  | IOAPIC_Int_routing_register_5 | 0x07                                     | D6int_Intr_map | 4:0   | Map D6 bridge interrupts to |
| 5650 All Revs |                               |                                          |                |       | IOAPIC pin D6_Intr_map      |
|               |                               |                                          | D7int_Intr_map | 12:8  | Map D7 bridge interrupts to |
|               |                               |                                          |                |       | IOAPIC pin D7_Intr_map      |
|               |                               |                                          | D8int_Intr_map | 20:16 | Map D8 bridge interrupts to |
|               |                               |                                          |                |       | IOAPIC pin D8_Intr_map      |
|               |                               |                                          | D9int_Intr_map | 28:24 | Map D9 bridge interrupts to |
|               |                               |                                          |                |       | IOAPIC pin D9_Intr_map      |

## Table 6-12 IOAPIC Interrupt Routing Register 6

| ASIC Rev      | Register                      | Address in IOAPIC<br>Configuration<br>Space | Field Name      | Bits  | Description                         |
|---------------|-------------------------------|---------------------------------------------|-----------------|-------|-------------------------------------|
| SR5690/5670/  | IOAPIC_Int_routing_register_6 | 0x08                                        | D10int_Intr_map | 4:0   | Map D10 bridge interrupts to IOAPIC |
| 5650 All Revs |                               |                                             |                 |       | pin D10_Intr_map                    |
|               |                               |                                             | D11int_Intr_map | 12:8  | Map D11 bridge interrupts to IOAPIC |
|               |                               |                                             |                 |       | pin D11_Intr_map                    |
|               |                               |                                             | D12int_Intr_map | 20:16 | Map D12 bridge interrupts to IOAPIC |
|               |                               |                                             |                 |       | pin D12_Intr_map                    |
|               |                               |                                             | D13int_Intr_map | 28:24 | Map D13 bridge interrupts to IOAPIC |
|               |                               |                                             |                 |       | pin D13_Intr_map                    |

## Table 6-13 IOAPIC Interrupt Routing Register 7

| ASIC Rev                      | Register                      | Address in IOAPIC<br>Configuration Space | Field Name     | Bits | Description                                                   |
|-------------------------------|-------------------------------|------------------------------------------|----------------|------|---------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs | IOAPIC_Int_routing_register_7 | 0x09                                     | HT_Intr_map    |      | Map HT internal interrupts to<br>IOAPIC pin HT_Intr_map       |
|                               |                               |                                          | IOMMU_Intr_map |      | Map IOMMU internal interrupts to<br>IOAPIC pin IOMMU_Intr_map |

# 6.3.3 Swizzling

Each of the 11 input group interrupts can be swizzled according to the swizzle number (4 in total).

The interrupts coming into the IOAPIC are always set as (A, B, C, D), with A being the LSB of the group and D being the MSB. The swizzle number decides how the interrupts will be mapped before being assigned to an output group.

- 00 ABCD
- 01 BCDA
- 10 CDAB
- 11 DABC

The figure below illustrates these 4 swizzling configurations.





# 6.3.4 Group Assignment

Once swizzling has been done, the 11 input groups are assigned to the output group using the group number. As mentioned earlier, there can be 32 or 24 interrupt entries depending on the mode set in the Features Enable register. This means that these 11 input groups of 4 interrupts can be assigned to either 8 or 6 output groups of 4 interrupts, depending on the mode set. Note it is possible to assign more than 1 input group to the same output group. The following figures show how this is done.



Figure 6-4 Group Assignment - 32 Interrupt Mode

Figure 6-4 above shows 11 groups (each having the new ABCD after swizzling) getting assigned to the 8 output groups (32 interrupt mode).



Figure 6-5 Group Assignment - 24 Interrupt Mode

Figure 6-5 above shows 11 groups (each having the new ABCD after swizzling) getting assigned to the 6 output groups (24 interrupt mode).

# 6.3.5 IOAPIC Interrupt Interrupt Status Register

| Table 6-14 | IOAPIC | Interrupt | interrupt | Status | Register |
|------------|--------|-----------|-----------|--------|----------|
|------------|--------|-----------|-----------|--------|----------|

| ASIC Rev      | Register                 | Address in<br>IOAPIC<br>configuratio<br>n space | Field Name       | Bits | Description                                    |
|---------------|--------------------------|-------------------------------------------------|------------------|------|------------------------------------------------|
| SR5690/5670/  | IOAPIC_serial_IRQ_Status | 0x0A                                            | Internal_irq_sts | 31:0 | Read Only. This is for debugging purpose only. |
| 5650 All Revs |                          |                                                 |                  |      | This register shows each of the 32 interrupt   |
|               |                          |                                                 |                  |      | status going into the IOAPIC. Note that the    |
|               |                          |                                                 |                  |      | polarity of certain bits are reversed.         |

# 6.4 Southbridge Re-Routing Feature

Once the 58 interrupts are mapped to either 32 or 24 interrupts, the IOAPIC decides which of the 32 or 24 interrupts are supposed to be active. The CPU indicates this by setting the MASK bit of the corresponding interrupt in the interrupt table entry. (This will be explained later, once the Memory mapped space is explained. For now it is correct to assume that each of the 32/24 interrupts has a corresponding MASK bit assigned, which decides whether the interrupt is active or disabled.) The southbridge feature allows the routing of the masked interrupt lines to the southbridge (see bit 4 in *Table 6-5*).



Figure 6-6 Routing of the Masked Interrupt Lines to the Southbridge

The mapping of the 32/24 masked interrupts to the 8-bit vector (A, B, C, D, E, F, G, H) is as follows:

If Mode is set to 1 (32 interrupts):

- A = Int0 OR Int8 OR Int16 OR Int24
- B = Int1 OR Int9 OR Int17 OR Int25
- C = Int2 OR Int10 OR Int18 OR Int26
- D = Int3 OR Int11 OR Int19 OR Int27
- E = Int4 OR Int12 OR Int20 OR Int28
- F = Int5 OR Int13 OR Int21 OR Int29
- G = Int6 OR Int14 OR Int22 OR Int30
- H = Int7 OR Int15 OR Int23 OR Int31

#### If Mode is set to 0 (24 Interrupts):

- A = Int0 OR Int8 OR Int16
- B = Int1 OR Int9 OR Int17
- C = Int2 OR Int10 OR Int18
- D = Int3 OR Int11 OR Int19
- E = Int4 OR Int12 OR Int20
- F = Int5 OR Int13 OR Int21

G = Int6 OR Int14 OR Int22

H = Int7 OR Int15 OR Int23

In general the IOAPIC does not send any interrupt message if the interrupt is masked. If the southbridge feature is set, then the masked interrupt will be routed to the southbridge. If the southbridge feature is not set, no interrupts will be sent to the southbridge and the masked interrupt will be treated as masked.

## 6.4.1 Recommended Usage

The IOAPIC should be enabled by the system BIOS and the southbridge routing feature should be switched on. This will allow the interrupts to be forwarded to the PIC in the southbridge. This way, if the system boots in DOS, interrupts will still work. Once the system boots an ACPI OS (where IOAPIC is assumed to be supported), the system BIOS will disable the southbridge routing feature so that the masked interrupts are masked out.

## 6.4.2 Interrupt Swizzling by the Processor in a Multi-NB Environment

In a multi-NB environment, the processor complex will swizzle the secondary NB's interrupts as follows:

INTA->INTB INTB->INTC INTC->INTD INTD->INTA INTE->INTE INTF->INTF INTG->INTG INTH->INTH

The primary NB's interrupts are unaffected.

# 6.5 Redirection Table Entry Registers

These are 64-bit registers. Each of the mapped interrupt has a redirection table entry assigned to it. A redirection table entry defines the features of the interrupt. In particular it defines:

- Interrupt Vector The vector associated with that interrupt pin. The CPU uses this vector to find out who sent the interrupt. Also for the EOI, the CPU writes/broadcasts this vector number to clear the interrupt
- Delivery Mode The priority of the interrupt.
- Destination Mode Whether the interrupt is going to a logical address or a physical address.
- Delivery Status Whether the IOAPIC has sent the interrupt message corresponding to this pin or it is still pending.
- Interrupt Pin Polarity Active high or active low. Note that the IOAPIC does not support active low interrupts, therefore this bit should always be set to 0.
- Remote IRR This bit talks about the level sensitive interrupt and tells the CPU whether it has cleared this interrupt by sending an EOI or not. This bit will go high once the interrupt message corresponding to that pin has been sent.
- Trigger Mode Whether the interrupt is level sensitive or edge sensitive.
- Mask Whether the interrupt pin has been disabled or not. All interrupts are masked by default (bit set to 1). The CPU needs to write a 0 to unmask.
- Destination Address Destination address of the interrupt message.

| ASIC Rev | Register    | Address in IOAPIC Direct                       | Bits           | Field Name    | Description                                           |
|----------|-------------|------------------------------------------------|----------------|---------------|-------------------------------------------------------|
|          | REDIRECTION | Memory Mapped Space                            | 7:0            | Vector        | Interrupt vector cooperated with                      |
|          | —           | 0x10 For mapped int 0<br>0x12 For mapped int 1 | 7.0            |               | Interrupt vector associated with this interrupt input |
|          | —           | 0x12 For mapped int 2                          | 10:8           |               |                                                       |
|          |             | 0x14 For mapped int 3                          | 10:8           | Delivery Mode |                                                       |
|          |             | 0x18 For mapped int 4                          |                |               | 001: Lowest Priority                                  |
|          |             | 0x18 For mapped int 5                          |                |               | 010: SMI/PMI                                          |
|          |             |                                                |                |               | 011: Reserved                                         |
|          |             | 0x1C For mapped int 6                          |                |               | 100: NMI                                              |
|          |             | 0x1E For mapped int 7                          |                |               | 101: INIT                                             |
|          |             | 0x20 For mapped int 8                          |                |               | 110: Reserved                                         |
|          |             | 0x22 For mapped int 9                          |                |               | 111: ExtINT                                           |
|          |             | 0x24 For mapped int 10                         | 11             |               | 0: Physical                                           |
|          |             | 0x26 For mapped int 11                         |                | Mode          | 1: Logical                                            |
|          |             | 0x28 For mapped int 12                         | 12             | ,             | Read Only                                             |
|          |             | 0x2A For mapped int 13                         |                | Status        | 0: Idle                                               |
|          |             | 0x2C For mapped int 14                         |                |               | 1: Send Pending                                       |
|          |             | 0x2E For mapped int 15                         | 13             | Interrupt Pin | 0: High                                               |
|          |             | 0x30 For mapped int 16                         |                | Polarity      | 1: Low                                                |
|          |             | 0x32 For mapped int 17                         | 14             | Remote IRR    | Used for level triggered interrupts                   |
|          |             | 0x34 For mapped int 18                         |                |               | only.                                                 |
|          |             | 0x36 For mapped int 19                         |                |               | Set when interrupt message                            |
|          |             | 0x38 For mapped int 20                         |                |               | delivered.                                            |
|          |             | 0x3A For mapped int 21                         |                |               | Cleared by EOI special cycle                          |
|          |             | 0x3C For mapped int 22                         |                |               | transaction or write to EOI register                  |
|          |             | 0x3E For mapped int 23                         | 15 Trigger Mod |               | 0: Edge                                               |
|          |             | 0x40 For mapped int 24                         |                |               | 1: Level                                              |
|          |             | 0x42 For mapped int 25                         | 16             | Mask          | Masks the interrupt injection at the                  |
|          |             | 0x44 For mapped int 26                         |                |               | input of this device.                                 |
|          |             | 0x46 For mapped int 27                         |                |               | Write 0 to unmask                                     |
|          |             | 0x48 For mapped int 28                         |                |               |                                                       |
|          |             | 0x4A For mapped int 29                         |                |               |                                                       |
|          |             | 0x4C For mapped int 30                         |                |               |                                                       |
|          |             | 0x4E For mapped int 31                         |                |               |                                                       |
|          |             |                                                | 31:17          | Reserved      |                                                       |

## Table 6-15 IOAPIC Redirection Table Entrée LOW Register

|              |                    | Address in IOAPIC      |       |                |                                          |
|--------------|--------------------|------------------------|-------|----------------|------------------------------------------|
| ASIC Rev     | Register           | Direct Memory Mapped   | Bits  | Field Name     | Description                              |
| ASIC Rev     | Register           | Space                  | Dits  | Field Name     | Description                              |
| SR5690/5670/ | REDIRECTION_TABLE_ | 0x11 For mapped int 0  | 55:32 | Reserved       |                                          |
|              | ENTREE_HIGH        | 0x13 For mapped int 1  | 63:56 | Destination ID | Bits [19:12] of the address field of the |
|              | -                  | 0x15 For mapped int 2  |       |                | interrupt message                        |
|              |                    | 0x17 For mapped int 3  |       |                |                                          |
|              |                    | 0x19 For mapped int 4  |       |                |                                          |
|              |                    | 0x1B For mapped int 5  |       |                |                                          |
|              |                    | 0x1D For mapped int 6  |       |                |                                          |
|              |                    | 0x1F For mapped int 7  |       |                |                                          |
|              |                    | 0x21 For mapped int 8  |       |                |                                          |
|              |                    | 0x23 For mapped int 9  |       |                |                                          |
|              |                    | 0x25 For mapped int 10 |       |                |                                          |
|              |                    | 0x26 For mapped int 11 |       |                |                                          |
|              |                    | 0x27 For mapped int 12 |       |                |                                          |
|              |                    | 0x2B For mapped int 13 |       |                |                                          |
|              |                    | 0x2D For mapped int 14 |       |                |                                          |
|              |                    | 0x2F For mapped int 15 |       |                |                                          |
|              |                    | 0x31 For mapped int 16 |       |                |                                          |
|              |                    | 0x33 For mapped int 17 |       |                |                                          |
|              |                    | 0x35 For mapped int 18 |       |                |                                          |
|              |                    | 0x37 For mapped int 19 |       |                |                                          |
|              |                    | 0x39 For mapped int 20 |       |                |                                          |
|              |                    | 0x3B For mapped int 21 |       |                |                                          |
|              |                    | 0x3D For mapped int 22 |       |                |                                          |
|              |                    | 0x3F For mapped int 23 |       |                |                                          |
|              |                    | 0x41 For mapped int 24 |       |                |                                          |
|              |                    | 0x43 For mapped int 25 |       |                |                                          |
|              |                    | 0x45 For mapped int 26 |       |                |                                          |
|              |                    | 0x47 For mapped int 27 |       |                |                                          |
|              |                    | 0x49 For mapped int 28 |       |                |                                          |
|              |                    | 0x4B For mapped int 29 |       |                |                                          |
|              |                    | 0x4D For mapped int 30 |       |                |                                          |
|              |                    | 0x4F For mapped int 31 |       |                |                                          |

# Table 6-16 IOAPIC Redirection Table Entrée HIGH Register

# 7.1 Overview

The section describes the programming sequences needed to enable and configure various RAS related features in the SR5690/5670/5650. The chipset supports several different methods of reporting and handling errors within the system and it is up to the platform designer to choose the method that is appropriate for them. Specifically, the chipset supports error detection for the following general classes of errors:

- HyperTransport<sup>™</sup> Errors
- Internal Parity Errors
- PCIe<sup>®</sup> Errors

The following modes of error handling are supported:

- Error handling through Operating System/Hypervisor and appropriate chipset drivers (when required/available).
- Error handling though System BIOS.
- System halt on error via HyperTransport syncflood and PCIe link disable.

It is possible to configure a system to use different error handling methods for different classes of errors but there are minor restrictions in the supported combinations.

For an overview of the SR5690/5670/5650 RAS capabilities, please refer to the chipset databook.

# 7.2 Platform Configuration

The SR5690/5670/5650 contains several sideband signals that can be used to facilitate error reporting and error handling. Specifically, the SERR\_FATAL# and NON\_FATAL\_CORR# pins may be used to report errors while the SYNCFLOODIN# and NMI# input pins may be used to generate particular error responses. It is suggested that all of these pins be connected to a BMC. It is also suggested that a BMC connect to at least one southbridge pin capable of generating an SMI interrupt. In this manner, the BMC can be configured in different modes to support the different error handling modes. Please see the logical connection diagram in the chipset databook for more details.

Please note that the SR5690/5670/5650 sideband error reporting pins and error response pins have integrated pull-up resistors to 1.8V. These pins are not 3.3V tolerant. The output pins are open-drain. Also note that the input error response pins (SYNCFLOODIN# and NMI#) are pin straps during power-up and may not be driven until after POWERGOOD has been asserted for 2us.

# 7.3 RAS Feature Configuration

# 7.3.1 Sideband Pin Configuration

The following sub-sections document how error status logged inside the chipset can be propagated out to the SERR\_FATAL# and NON\_FATAL\_CORR# pins. In general, these may be set when internal status registers within the chipset are set. Additional registers need to be configured to allow the chipset to log certain types of errors in its status registers. In particular, within the PCI Express<sup>®</sup> controllers, various proprietary registers need to be configured in addition to a number of standard PCI Express capability registers in order to properly detect and log errors on the PCI Express interfaces. Furthermore, additional registers need to be set to allow logged errors to propagate out of the sideband error reporting pins.

Additional details can be found in the sections related to Hypertransport error reporting (see *section 7.3.3*), internal parity error reporting (see *section 7.3.4*), and PCI Express error reporting (see *section 7.3.5*).

# 7.3.1.1 SERR\_FATAL# Pin

The SERR\_FATAL# pin is controlled through NBMISCIND 0x77 (SERR\_PIN\_CONTROL) and NBMISCIND 0x78 (FATAL\_PIN\_CONTROL). Errors classified and logged as SERR or fatal can be configured to drive this pin. The

SERR\_FATAL# pin will be asserted as long as the triggering status bits remain set. The pin will be deasserted on warm reset as all of the control (but not status) bits will be cleared.

| ASIC Rev      | Register Setting          | Description                                                                         |
|---------------|---------------------------|-------------------------------------------------------------------------------------|
| SR5690/5670/  | NBMISCIND x 77 [31] = 0x1 | When set to 1, this register allows SERR events to trigger the SERR_FATAL# pin. The |
| 5650 All Revs |                           | event sources must also be enabled.                                                 |







| Table 7-2 Register Settings to Enable SERR_F | FATAL# Pin Fatal Functionality |
|----------------------------------------------|--------------------------------|
|----------------------------------------------|--------------------------------|

|   | ASIC Rev      | Register Setting          | Description                                                                                |
|---|---------------|---------------------------|--------------------------------------------------------------------------------------------|
| S | SR5690/5670/  | NBMISCIND x 78 [31] = 0x1 | When set to 1, this register allows fatal events to trigger the SERR_FATAL# pin. The event |
| Ę | 5650 All Revs |                           | sources must also be enabled.                                                              |



\* Refer to Table 7-12, "Registers to Probe for HT Error Conditions," on page 7-8 for error status and Table 7-13, "Hypertranport Error Classification," on page 7-9 for error severity settings.

## Figure 7-2 Fatal Error Conditions Used to Drive SERR\_FATAL#

## 7.3.1.2 NON\_FATAL\_CORR# Pin

The NON\_FATAL\_CORR# pin is controlled through NBMISCIND 0x79 (NON\_FATAL\_PIN\_CONTROL) and NBMISCIND 0x7A (CORR\_PIN\_CONTROL). Errors classified and logged as non-fatal or correctable can be configured to drive this pin. The NON\_FATAL\_CORR# pin will be asserted as long as the triggering status bits remain set. The pin will be deasserted on warm reset as all of the control (but not status) bits will be cleared.

| ASIC Rev      | Register Setting          | Description                                                         |
|---------------|---------------------------|---------------------------------------------------------------------|
| SR5690/5670   | NBMISCIND x 79 [31] = 0x1 | When set to 1, this register allows non-fatal events to trigger the |
| 5650 All Revs |                           | NON_FATAL_CORR# pin. The event sources must also be enabled.        |



\* Refer to Table 7-12, "Registers to Probe for HT Error Conditions," on page 7-8 for error status and Table 7-13, "Hypertranport Error Classification," on page 7-9 for error severity settings.

Figure 7-3 Non-fatal Error Conditions Used to Drive NON\_FATAL\_CORR#







#### 7.3.1.3 SERR\_FATAL# and NON\_FATAL\_CORR# Status Readback

The value of the SERR\_FATAL# and NON\_FATAL\_CORR# output pins can be read back via the following registers. In multiple-northbridge environments, the SERR\_FATAL# and NON\_FATAL\_CORR# signals must be buffered before being wire-ORed together to drive system logic for this function to operate properly in the context of identifying the specific northbridge that is signaling an error.

#### Table 7-4 Registers to Read Back SERR\_FATAL# and NON\_FATAL\_CORR# State

| ASIC Rev         | Register            | Description                                       |
|------------------|---------------------|---------------------------------------------------|
|                  | HTIUNBIND x A7 [6]  | Reads back the state of DBG_GPIO0/SERR_FATAL#     |
| 5650<br>All Revs | HTIUNBIND x A7 [30] | Reads back the state of DBG_GPIO3/NON_FATAL_CORR# |

#### 7.3.1.4 SYNCFLOODIN# Pin

The SYNCFLOODIN# pin functionality can be enable by setting HTIUNBIND 0x7E (HT\_ERROR\_INJECTION\_CNTL) bit 6 to 1. When enabled, a falling edge on this pin will cause the SR5690/5670/5650's HyperTransport controller to go into the syncflood state. Whenever this pin is triggered, the associated status bit located in HTIUNBIND 0x7E bit 7 will be set. The status bit is preserved across a warm reset and may be cleared by writing it to 1.

| Table 7-5 Register Settings to | Enable SYNCFLOODIN# Pin |
|--------------------------------|-------------------------|
|--------------------------------|-------------------------|

| ASIC Rev         | Register           | Setting | Description                                                                |
|------------------|--------------------|---------|----------------------------------------------------------------------------|
|                  | HTIUNBIND x 7E [6] | 0x1     | Enable SYNCFLOODIN# to generate HT syncflood when the pin is asserted low. |
| 5650<br>All Revs | HTIUNBIND x 7E [7] | N/A     | Status bit set by hardware when SYNCFLOODIN# is asserted.                  |

# 7.3.1.5 NMI# Pin

The NMI# pin functionality can be enable by setting NBMISCIND 0x75 (IOC\_FEATURE\_CNTL) bit 1 to 1. When enabled, a falling edge on this pin will cause the SR5690/5670/5650 to generate an upstream NMI interrupt to the processor complex. Whenever this pin is triggered, the associated status bit located in NBMISCIND 0x75 bit 28 will be set. The status bit is preserved across a warm reset and may be cleared by writing it to 1. The interrupt handler may use this status bit to differentiate an NMI generated through the NMI# pin versus an NMI generated through other means (like southbridge PERR# or FERR#) or from a different SR5690/5670/5650.

The NMI# pin may be used to generate a broadcast NMI that is seen by all processor cores. Alternatively, it may be desirable to generate an NMI targeted at a single processor core. The A21 silicon revision adds a directed NMI capability. This may be used to support WHEA in the firmware first mode when system BIOS (handling SMI) signals the OS via NMI to pick up error log information. If NMI is seen by all cores, only one core's NMI handler will pick up the error log information and the rest will detect a missing error log.

Alternatively, the local APIC inter-processor interrupt facility may be used to send an NMI to a single core. This may be done via the following software sequence:

- 3. Save the state of APIC310
- 4. Write APIC310 = 0x0
- 5. Write APIC300 = 0x40 (this will trigger NMI# which will be handled after the SMI finishes)
- 6. Restore APIC310

#### Table 7-6 Register Settings to Enable NMI# Pin

| ASIC Rev      | Register               | Setting | Description                                                                    |
|---------------|------------------------|---------|--------------------------------------------------------------------------------|
| SR5690/5670/  | NBMISCIND x 75 [1]     | 0x1     | Enable NMI# to generate an upstream NMI interrupt request when the pin is      |
| 5650 All Revs |                        |         | asserted low.                                                                  |
|               | NBMISCIND x 75 [28]    | N/A     | Status bit set by hardware when NMI# is asserted.                              |
| SR5690/5670/  | NBMISCIND x 12 [23]    |         | Enable NMI# pin to direct an NMI to a specific processor core instead of       |
| 5650 Rev A21  |                        |         | broadcasting it to all cores                                                   |
|               | NBMISCIND x 12 [31:24] |         | Selects the target of the directed NMI. The processor core with matching local |
|               |                        |         | APIC ID is targeted. This register should be set to the APIC ID of core 0.     |

## 7.3.2 HyperTransport RAS Feature Configuration

#### 7.3.2.1 HyperTransport Syncflood on Errors

The SR5690/5670/5650 HyperTransport controller can be configured to trigger a HyperTransport syncflood on various error conditions. The SR5690/5670/5650 contains the standard HyperTransport error mapping registers which can trigger a syncflood when the associated error type is detected. In those cases, NBCONFIG 0x4 [8] (SERR\_EN) register bit must also be set. SERR events associated with the NBCONFIG space, such as those from internal parity errors, will result in a Hypertransport syncflood. Unless explicitly disabled, the SR5690/5670/5650 will propagate a syncflood from its receiver to its transmitter.

Additionally, the SR5690/5670/5650 can be programmed to trigger a syncflood on internal parity errors as well as on PCIe<sup>®</sup> fatal or non-fatal errors. Finally, the SYNCFLOODIN# pin described in *section 7.3.1.3 "SERR\_FATAL# and NON\_FATAL\_CORR# Status Readback" on page 7-5* may be used to trigger a HyperTransport syncflood.

Note that a received syncflood event is not logged inside the SR5690/5670/5650. The device that triggered the syncflood should log the error in its own status registers.

#### Table 7-7 Registers to Configure HyperTransport Syncflood

| ASIC Rev      | Register         | Description                                                                                      |
|---------------|------------------|--------------------------------------------------------------------------------------------------|
| SR5690/5670/  | NBCONFIG x 4 [8] | This is the SERR_EN register bit located in the HyperTransport controller. It must be set before |
| 5650 All Revs |                  | the controller can initiate a syncflood due to any error source.                                 |

| ASIC Rev      | Register           | Description                                                                                        |
|---------------|--------------------|----------------------------------------------------------------------------------------------------|
| SR5690/5670/  | NBCONFIG x C8 [1]  | When set to 1, a received periodic CRC error will trigger a syncflood. This register has no effect |
| 5650 All Revs |                    | when running in HyperTransport 3 mode.                                                             |
|               | NBCONFIG x D8 [16] | When set to 1, a received protocol error will trigger a syncflood.                                 |
|               | NBCONFIG x D8 [17] | When set to 1, a received flow-control buffer overflow error will trigger a syncflood.             |

## Table 7-8 Registers to Configure HyperTransport Syncflood on HyperTransport Errors

## Table 7-9 Registers to Configure HyperTransport Syncflood On Internal Parity Errors

| ASIC Rev | Register           | Description                                                                                 |
|----------|--------------------|---------------------------------------------------------------------------------------------|
|          | NBCONFIG x 68 [19] | When set to 1, an internal parity error classified as correctable will trigger a syncflood. |
| All Revs | NBCONFIG x 68 [20] | When set to 1, an internal parity error classified as non-fatal will trigger a syncflood.   |
|          | NBCONFIG x 68 [21] | When set to 1, an internal parity error classified as fatal will trigger a syncflood.       |

## Table 7-10 Registers to Configure HyperTransport Syncflood on PCIe® Fatal Errors

| ASIC Rev         | Register            | Description                                                                               |
|------------------|---------------------|-------------------------------------------------------------------------------------------|
| SR5690/5670/5650 | HTIUNBIND x 3A [2]  | When set to 1, a fatal error detected in PCIE-GPP1 Port 0 will trigger a syncflood.       |
| All Revs         | HTIUNBIND x 3A [3]  | When set to 1, a fatal error detected in PCIE-GPP1 Port 1 will trigger a syncflood.       |
|                  | HTIUNBIND x 3A [4]  | When set to 1, a fatal error detected in PCIE-GPP3a Port 0 will trigger a syncflood.      |
|                  | HTIUNBIND x 3A [5]  | When set to 1, a fatal error detected in PCIE-GPP3a Port 1 will trigger a syncflood.      |
|                  | HTIUNBIND x 3A [6]  | When set to 1, a fatal error detected in PCIE-GPP3a Port 2 will trigger a syncflood.      |
|                  | HTIUNBIND x 3A [7]  | When set to 1, a fatal error detected in PCIE-GPP3a Port 3 will trigger a syncflood.      |
|                  | HTIUNBIND x 3A [9]  | When set to 1, a fatal error detected in PCIE-GPP3a Port 4 will trigger a syncflood.      |
|                  | HTIUNBIND x 3A [10] | When set to 1, a fatal error detected in PCIE-GPP3a Port 5 will trigger a syncflood.      |
| SR5690/5670 All  | HTIUNBIND x 3A [11] | When set to 1, a fatal error detected in PCIE-GPP2 Port 0 will trigger a syncflood. (Not  |
| Revs             |                     | available on SR5650)                                                                      |
| SR5690 All Revs  | HTIUNBIND x 3A [12] | When set to 1, a fatal error detected in PCIE-GPP2 Port 1 will trigger a syncflood. (Not  |
|                  |                     | available on SR5670 and SR5650)                                                           |
| SR5690 All Revs  | HTIUNBIND x 3A [13] | When set to 1, a fatal error detected in PCIE-GPP3b Port 0 will trigger a syncflood. (Not |
|                  |                     | available on SR5670 and SR5650)                                                           |

#### Table 7-11 Registers to Configure HyperTransport Syncflood on PCIe® Non-Fatal Errors

| ASIC Rev                | Register            | Description                                                                                                       |
|-------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/5650        | HTIUNBIND x 3B [2]  | When set to 1, a non-fatal error detected in PCIE-GPP1 Port 0 will trigger a syncflood.                           |
| All Revs                | HTIUNBIND x 3B [3]  | When set to 1, a non-fatal error detected in PCIE-GPP1 Port 1 will trigger a syncflood.                           |
|                         | HTIUNBIND x 3B [4]  | When set to 1, a non-fatal error detected in PCIE-GPP3a Port 0 will trigger a syncflood.                          |
|                         | HTIUNBIND x 3B [5]  | When set to 1, a non-fatal error detected in PCIE-GPP3a Port 1 will trigger a syncflood.                          |
|                         | HTIUNBIND x 3B [6]  | When set to 1, a non-fatal error detected in PCIE-GPP3a Port 2 will trigger a syncflood.                          |
|                         | HTIUNBIND x 3B [7]  | When set to 1, a non-fatal error detected in PCIE-GPP3a Port 3 will trigger a syncflood.                          |
|                         | HTIUNBIND x 3B [9]  | When set to 1, a non-fatal error detected in PCIE-GPP3a Port 4 will trigger a syncflood.                          |
|                         | HTIUNBIND x 3B [10] | When set to 1, a non-fatal error detected in PCIE-GPP3a Port 5 will trigger a syncflood.                          |
| SR5690/5670 All<br>Revs |                     | When set to 1, a non-fatal error detected in PCIE-GPP2 Port 0 will trigger a syncflood. (Not available on SR5650) |
|                         |                     | When set to 1, a non-fatal error detected in PCIE-GPP2 Port 1 will trigger a syncflood. (Not                      |
|                         |                     | available on SR5670 and SR5650)                                                                                   |
| SR5690 All Revs         |                     | When set to 1, a non-fatal error detected in PCIE-GPP3b Port 0 will trigger a syncflood.                          |
|                         |                     | (Not available on SR5670 and SR5650)                                                                              |

# 7.3.3 Error Status for HyperTransport<sup>™</sup> Errors

Software may quickly determine whether the HyperTransport<sup>™</sup> interface has detected an error by reading back NBCONFIG 0x68 (HT\_PARITY\_ERR\_CONTROL\_STATUS) bits 0 (NON\_FATAL\_HT\_ERR) and 1 (FATAL\_HT\_ERR). If one of those bits is set, the controller has detected an error classified as either non-fatal or fatal respectively. If an error has been detected, specific error status bits may be probed to determine the specific error.

Error status bits are cleared by writing them to 1 unless otherwise indicated.

| ASIC Rev | Error Type                      | Status Register     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|---------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Non-Fatal                       | NBCONFIG x 68 [0]   | When set to 1 by hardware, this indicates the HyperTransport <sup>™</sup> controller has detected a HyperTransport error that has been classified as non-fatal. This is a read-only register bit that is the OR of all non-fatal classified HT error status bits. Note that since HT error classification registers are cleared on a warm reset, this register will read back as 0 after a warm reset even if specific error status bits have preserved non-zero state. |
|          | Fatal                           | NBCONFIG x 68 [1]   | When set to 1 by hardware, this indicates the HyperTransport controller has detected a HyperTransport error that has been classified as fatal. This is a read-only register bit that is the OR of all fatal classified HT error status bits. Note that since HT error classification registers are cleared on a warm reset, this register will read back as 0 after a warm reset even if specific error status bits have preserved non-zero state.                      |
|          | Periodic CRC<br>Error           | NBCONFIG x C8 [9:8] | When set to 1 by hardware, this indicates the HyperTransport controller has detected a periodic CRC error if the system is in HyperTransport 1 mode. In HyperTransport 3 mode, bit 8 is set when the link enters the syncflood state.                                                                                                                                                                                                                                   |
|          | Protocol                        | NBCONFIG x D0 [12]  | When set to 1 by hardware, this indicates the HyperTransport controller has detected a protocol error                                                                                                                                                                                                                                                                                                                                                                   |
|          | Flow-control<br>buffer overflow | NBCONFIG x D0 [13]  | When set to 1 by hardware, this indicates the HyperTransport controller has detected a flow-control buffer overflow error                                                                                                                                                                                                                                                                                                                                               |
|          | Response Error                  | NBCONFIG x D8[25]   | When set to 1 by hardware, this indicates the HyperTransport controller has detected a response error                                                                                                                                                                                                                                                                                                                                                                   |
|          | Per-Packet<br>CRC Error         | NBCONFIG x 44 [8]   | When set to 1 by hardware, this indicates the HyperTransport controller has detected a retry error. This only applies to HyperTransport 3 mode operation.                                                                                                                                                                                                                                                                                                               |
|          | Retry Counter<br>Rollover       | NBCONFIG x 44 [9]   | When set to 1 by hardware, this indicates the HyperTransport controller has detected a retry counter overflow. This only applies to HyperTransport 3 mode operation.                                                                                                                                                                                                                                                                                                    |

Table 7-12 Registers to Probe for HT Error Conditions

## 7.3.3.1 Error Classification for HyperTransport Errors

The SR5690/5670/5650 HyperTransport controller can classify HT errors as either system error/syncflood, fatal, non-fatal or unclassified/masked using a standard set of HT registers. Certain types of errors have restrictions on their possible classification. While it is possible to classify an error in multiple ways, this is not recommended. For details on setting the system error/syncflood classification, please see *section 7.3.2.1 "HyperTransport Syncflood on Errors" on page 7-6.* 

| ASIC Rev      | Error Type                   | Register                 | Classification |
|---------------|------------------------------|--------------------------|----------------|
| SR5690/5670/5 | Protocol                     | NBCONFIG x D8 [18] = 0x1 | Fatal          |
| 650 All Revs  |                              | NBCONFIG x D8 [26] = 0x0 |                |
|               |                              | NBCONFIG x D8 [18] = 0x0 | Non-fatal      |
|               |                              | NBCONFIG x D8 [26] = 0x1 |                |
|               |                              | NBCONFIG x D8 [18] = 0x0 | Masked         |
|               |                              | NBCONFIG x D8 [26] = 0x0 |                |
|               | Flow-control buffer overflow | NBCONFIG x D8 [19] = 0x1 | Fatal          |
|               |                              | NBCONFIG x D8 [27] = 0x0 |                |
|               |                              | NBCONFIG x D8 [19] = 0x0 | Non-fatal      |
|               |                              | NBCONFIG x D8 [27] = 0x1 |                |
|               |                              | NBCONFIG x D8 [19] = 0x0 | Masked         |
|               |                              | NBCONFIG x D8 [27] = 0x0 |                |
|               | Response Error               | NBCONFIG x D8 [21] = 0x1 | Fatal          |
|               |                              | NBCONFIG x D8 [29] = 0x0 |                |
|               |                              | NBCONFIG x D8 [21] = 0x0 | Non-fatal      |
|               |                              | NBCONFIG x D8 [29] = 0x1 |                |
|               |                              | NBCONFIG x D8 [21] = 0x0 | Masked         |
|               |                              | NBCONFIG x D8 [29] = 0x0 |                |
|               | Periodic CRC Error           | NBCONFIG x D8 [22] = 0x1 | Fatal          |
|               |                              | NBCONFIG x D8 [30] = 0x0 |                |
|               |                              | NBCONFIG x D8 [22] = 0x0 | Non-fatal      |
|               |                              | NBCONFIG x D8 [30] = 0x1 |                |
|               |                              | NBCONFIG x D8 [22] = 0x0 | Masked         |
|               |                              | NBCONFIG x D8 [30] = 0x0 |                |
|               | Per-Packet CRC Error         | NBCONFIG x 44 [5] = 0x1  | Fatal          |
|               |                              | NBCONFIG x 44 [4] = 0x0  |                |
|               |                              | NBCONFIG x 44 [5] = 0x0  | Non-fatal      |
|               |                              | NBCONFIG x 44 [4] = 0x1  |                |
|               |                              | NBCONFIG x 44 [5] = 0x0  | Masked         |
|               |                              | NBCONFIG x 44 [4] = 0x0  |                |
|               | Retry Counter Rollover       | NBCONFIG x 44 [2] = 0x1  | Non-fatal      |
|               |                              | NBCONFIG x 44 [2] = 0x0  | Masked         |

# Table 7-13 Hypertranport Error Classification

# **Recommended HyperTransport Error Classification**

It is recommended that HyperTransport error classification be configured as per the following table

| ASIC Rev    | Error Type                   | Classification |
|-------------|------------------------------|----------------|
| RS5690/5670 | Protocol                     | Fatal          |
| All Revs    | Flow-control buffer overflow | Fatal          |
|             | Response Error               | Fatal          |
|             | Periodic CRC Error           | Fatal          |
|             | Per-Packet CRC Error         | Masked         |
|             | Retry Counter Rollover       | Masked         |

# 7.3.3.2 Interrupt-Based Error Reporting for HyperTransport Errors

The SR5690/5670/5650 HyperTransport controller can be configured to generate upstream interrupts when certain classes of HyperTransport errors or internal parity errors are detected. HyperTransport errors are configured as either fatal or non-fatal as per the HyperTransport specification. Internal parity errors are classified as fatal, non-fatal or correctable. HyperTransport error interrupts are enabled by the classifying the error types as fatal or non-fatal (same registers). The following options are available for the types of interrupts generated.

| ASIC Rev   | Register Settings                                    | Mode                | Number of Interrupts        | Interrupt Path to CPI  |
|------------|------------------------------------------------------|---------------------|-----------------------------|------------------------|
| SR5690/567 | NBCONFIG x68 [14:12] = 0x0                           | HyperTransport      | No interrupts (the          | Expect to route errors |
| 0/5650 All | NBCONFIG x4 [10] = 0x1                               | Controller and      | Interrupt pin in the PCI    | out of the error       |
| Revs       | NBMISC x0 [0] = 0x1                                  | Parity Error        | config space header         | reporting pins and     |
|            |                                                      | interrupts disabled | reads back as 0x0. MSI      | trigger SMI# or        |
|            |                                                      |                     | capability on dev 0 fn 0 is | generated syncflood    |
|            |                                                      |                     | hidden)                     | с ,                    |
|            | NBCONFIG x68 [14:12] = 0x1 for INTA, 0x2 for         | Legacy mode         | 1 shared interrupt          | Southbridge IOAPIC     |
|            | INTB, 0x3 for INTC, 0x4 for INTD.                    |                     | (configurable as one of     | via SB IRQ16/17/18/1   |
|            | NB IOAPIC disabled                                   |                     | INTA/B/C/D)                 |                        |
|            | NBCONFIG x68 [14:12] = 0x1 to declare a legacy       | Legacy mode         | 1 shared interrupt (can     | SR5690/5670/5650       |
|            | interrupt.                                           |                     | map onto any IOAPIC         | IOAPIC                 |
|            | NB IOAPIC disabled                                   |                     | table entry)                |                        |
|            | For instructions on how to enable the IOAPIC and     |                     |                             |                        |
|            | map the HTIU interrupt, please see Chapter 6         |                     |                             |                        |
|            | IOAPIC.                                              |                     |                             |                        |
|            |                                                      | MSI mode            | 1 shared interrupt          | Sent directly to the   |
|            | interrupt                                            | Mormode             | i shared interrupt          | processor              |
|            | OS must enable MSI mode for device 0 function 0 by   |                     |                             | processor              |
|            |                                                      |                     |                             |                        |
|            | setting:                                             |                     |                             |                        |
|            | NBCONFIG x70 [16] = 0x1                              |                     |                             |                        |
|            | NBCONFIG x70 [22:20] = 0x0 to set 1 interrupt        |                     |                             |                        |
|            | NBCONFIG x74 [31:0] = MSI address –                  |                     |                             |                        |
|            | (0xFEEx_xxxx)                                        |                     |                             |                        |
|            | NBCONFIG x78 [15:0] = MSI data                       |                     |                             |                        |
|            | NBCONFIG x68 [14:12] = 0x1 to declare a legacy       | MSI mode            | 2 shared interrupts         | Sent directly to the   |
|            | interrupt.                                           |                     | (message 0 is used for all  | processor              |
|            | OS must enable MSI mode for device 0 function 0 by   |                     | HT interrupts; message 1    |                        |
|            | setting:                                             |                     | is for all parity errors)   |                        |
|            | NBCONFIG x70 [16] = 0x1                              |                     |                             |                        |
|            | NBCONFIG x70 [22:20] = 0x1 to set 2 interrupts.      |                     |                             |                        |
|            | NBCONFIG x74 [31:0] = MSI address –                  |                     |                             |                        |
|            | (0xFEEx_xxxx)                                        |                     |                             |                        |
|            | NBCONFIG x78 [15:0] = MSI data                       |                     |                             |                        |
|            |                                                      | MSI mode            | 4 interrupts (message 0     | Sent directly to the   |
|            | interrupt                                            | Morniouc            | is used for all non-fatal   | processor              |
|            | OS must enable MSI mode for device 0 function 0 by   |                     | HT errors; message 1 is     | processor              |
|            | -                                                    |                     | used for all fatal HT       |                        |
|            | setting:                                             |                     |                             |                        |
|            | NBCONFIG x70 [16] = $0x1$                            |                     | errors; message 2 is        |                        |
|            | NBCONFIG x70 [22:20] = 0x2 to set 4 interrupts       |                     | used for all non-fatal and  |                        |
|            | NBCONFIG x74 [31:0] = MSI address –                  |                     | correctable parity errors;  |                        |
|            | (0xFEEx_xxxx)                                        |                     | message 3 is used for       |                        |
|            | NBCONFIG x78 [15:0] = MSI data                       |                     | fatal parity errors.)       |                        |
|            |                                                      | Remapped MSI        | 1 shared interrupt          | Interrupt is remapped  |
|            | interrupt                                            | mode                |                             | using IOMMU before     |
|            | NBCONFIG x68 [15] = 0x1 to enable remapping MSI      |                     |                             | being sent to the      |
|            | interrupts                                           |                     |                             | processor              |
|            | OS must enable MSI mode for device 0 function 0 by   |                     |                             |                        |
|            | setting:                                             |                     |                             |                        |
|            | NBCONFIG x70 [16] = 0x1                              |                     |                             |                        |
|            | NBCONFIG x70 [22:20] = 0x0 to set 1 interrupt        |                     |                             |                        |
|            |                                                      |                     | 1                           | 1                      |
|            | NBCONFIG x74 [31:0] = MSI address –                  |                     |                             |                        |
|            | NBCONFIG x74 [31:0] = MSI address –<br>(0xFEEx_xxxx) |                     |                             |                        |

# Table 7-15 HyperTransport Error Interrupt Types

| ASIC Rev | Register Settings                                  | Mode         | Number of Interrupts       | Interrupt Path to CPU |
|----------|----------------------------------------------------|--------------|----------------------------|-----------------------|
|          | NBCONFIG x68 [14:12] = 0x1 to declare a legacy     | Remapped MSI | 2 shared interrupts        | Interrupt is remapped |
|          | interrupt                                          | mode         | (Message 0 is used for all | using IOMMU before    |
|          | NBCONFIG x68 [15] = 0x1 to enable remapping MSI    |              | HT interrupts. Message 1   | being sent to the     |
|          | interrupts                                         |              | is for all parity errors)  | processor             |
|          | OS must enable MSI mode for device 0 function 0 by |              |                            |                       |
|          | setting:                                           |              |                            |                       |
|          | NBCONFIG x70 [16] = 0x1                            |              |                            |                       |
|          | NBCONFIG x70 [22:20] = 0x1 to set 2 interrupt      |              |                            |                       |
|          | NBCONFIG x74 [31:0] = MSI address –                |              |                            |                       |
|          | (0xFEEx_xxxx)                                      |              |                            |                       |
|          | NBCONFIG x78 [15:0] = MSI data                     |              |                            |                       |
|          | NBCONFIG x68 [14:12] = 0x1 to declare a legacy     | Remapped MSI | 4 interrupts (Message 0    | Interrupt is remapped |
|          | interrupt                                          | mode         | is used for all non-fatal  | using IOMMU before    |
|          | NBCONFIG x68 [15] = 0x1 to enable remapping MSI    |              | HT errors. Message 1 is    | being sent to the     |
|          | interrupts                                         |              | used for all fatal HT      | processor             |
|          | OS must enable MSI mode for device 0 function 0 by |              | errors. Message 2 is       |                       |
|          | setting:                                           |              | used for all non-fatal and |                       |
|          | NBCONFIG x70 [16] = 0x1                            |              | correctable parity errors. |                       |
|          | NBCONFIG x70 [22:20] = 0x2 to set 4 interrupt      |              | Message 3 is used for      |                       |
|          | NBCONFIG x74 [31:0] = MSI address –                |              | fatal parity errors.)      |                       |
|          | (0xFEEx_xxxx)                                      |              |                            |                       |
|          | NBCONFIG x78 [15:0] = MSI data                     |              |                            |                       |

# Table 7-15 HyperTransport Error Interrupt Types (Continued)

# 7.3.3.3 Sideband Pin Error Reporting for HyperTransport Errors

HyperTransport errors may be reported via sideband error pins. Please see the Sideband Pin Configuration section regarding how to configure SERR\_FATAL# and NON\_FATAL\_CORR#.

In order to avoid generating interrupts at the same time as reporting errors over sideband pins, interrupts should be disabled as per *Table 7-15*. The HyperTransport error classification registers that group errors as either fatal or non-fatal are instead used to route errors to either the SERR\_FATAL# or NON\_FATAL\_CORR# pins.

It is possible to report HyperTransport errors through both sideband pins and interrupts but the two methods are inherently unordered relative to each other.

#### Table 7-16 Registers to Control HyperTransport Sideband Error Reporting

| ASIC Rev             | Register                 | Description                                                                                                                                                                    |
|----------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/565<br>0 |                          | When set to 1, this enables reporting of SERR events from HyperTransport or internal<br>parity error sources via SERR_FATAL#.                                                  |
| All Revs             |                          | When set to 1, this enables reporting of HyperTransport syncflood events via<br>SERR_FATAL#. This event is treated as an SERR condition with respect to NBMISCIND<br>x 77[31]. |
|                      | NBMISCIND x 78 [1] = 0x1 | When set to 1, this enables reporting of fatal HyperTransport events via SERR_FATAL#.                                                                                          |
|                      |                          | When set to 1, this enables reporting of non-fatal HyperTransport events via NON_FATAL_CORR#.                                                                                  |

# 7.3.3.4 Software Error Injection Facilities for HyperTransport Errors

Software may artificially inject HT errors into the system in order to test error handling capabilities (interrupt handler, SMI handler, etc). The SR5690/5670/5650 can transmit bad periodic or per-packet CRCs to the processor using the standard HyperTransport registers. For all other types of errors including received CRC errors, real errors are not created, only the status registers are forced to be set.

| ASIC Rev     | Register           | Description                                                                                                      |
|--------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/ | HTIUNBIND x 7E [0] | When set to 1, this forces the HT protocol error status bit in NBCONFIG x D0 [12] to be set.                     |
|              | HTIUNBIND x 7E [1] | When set to 1, this forces the HT response error status bit in NBCONFIG x D8 [25] to be set.                     |
| All Revs     | HTIUNBIND x 7E [2] | When set to 1, this forces the HT flow-control buffer overflow error status bit in NBCONFIG x D0 [13] to be set. |
|              | HTIUNBIND x 7E [3] | When set to 1, this forces the HT CRC error status bit in NBCONFIG x C8 [8] to be set.                           |
|              | HTIUNBIND x 7E [4] | When set to 1, this forces the HT retry error status bit in NBCONFIG x 44 [8] to be set.                         |
|              | HTIUNBIND x 7E [5] | When set to 1, this forces the HT retry counter rollover error status bit in NBCONFIG x 44 [9] to be set.        |

#### Table 7-17 Registers for HyperTransport Error Status Injection

#### Table 7-18 Registers for HyperTransport Transmitter Error Injection

| ASIC Rev                      | Register | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs |          | When set to 1, this forces the HT transmitter to generate a single corrupted CRC to be sent to the processor.                                                                                                                                                                                                                                                                                                                                 |
|                               |          | When set, this register forces the HT transmitter to generate packets with corrupted CRCs on a periodic basis to be sent to the processor.<br>00 = Disabled<br>01 = 250us<br>10 = 500us<br>11 = 1ms                                                                                                                                                                                                                                           |
|                               |          | When set to 1 in HyperTransport 1 mode, this register forces the HT transmitter to send<br>corrupted periodic CRCs upstream to the processor. This will lead to a syncflood condition if the<br>opposite side of the link has the CRC Flood Enable bit set.<br>When set to 1 in HyperTransport 3 mode, this register forces the HT transmitter to send<br>corrupted per-packet CRCs in every packet. This will lead to a syncflood condition. |

# 7.3.4 Internal Parity Error Configuration

# 7.3.4.1 HyperTransport Syncflood on Internal Parity Errors

Please see *section 7.3.2.1 "HyperTransport Syncflood on Errors" on page 7-6* for a description of how to trigger a HyperTransport syncflood when an internal parity error is detected.

# 7.3.4.2 Error Status for Internal Parity Errors

Software may quickly determine whether an internal parity error has occurred by reading back NBCONFIG 0x68 (HT\_PARITY\_ERR\_CONTROL\_STATUS) bits 8, 9 and 10 (CORRPARITY\_ERR, NON\_FATAL\_PARITY\_ERR and FATAL\_PARITY\_ERR). If one of those bits is set, the SR5690/5670/5650 has detected a parity error classified as either correctable, non-fatal or fatal respectively. If an error has been detected, specific error status bits need to be probed to determine the specific error location and to clear the error status. The summary error status bits cannot be cleared directly. Error status bits are cleared by writing them to 1 unless otherwise indicated.

| ASIC Rev                      | Error Type               | Status Register | Description                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------|--------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs | Correctable Parity Error |                 | When set to 1 by hardware, this indicates an internal parity<br>error classified as correctable has been detected. This is a<br>read-only register bit that is the OR of all correctable classified<br>parity error status bits.<br>Note that since internal parity error classification registers are<br>cleared on a warm reset, any logged parity errors will show up<br>as correctable in NBCONFIG x68 [10:8]. |

#### Table 7-19 Registers to Probe for HT Error Conditions

| ASIC Rev                      | Error Type                    | Status Register       | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------|-------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs | Non-Fatal Parity Error        | NBCONFIG x 68 [9]     | When set to 1 by hardware, this indicates an internal parity<br>error classified as non-fatal has been detected. This is a<br>read-only register bit that is the OR of all correctable classified<br>parity error status bits.<br>Note that since internal parity error classification registers are<br>cleared on a warm reset, any logged parity errors will show up<br>as correctable in NBCONFIG x68 [10:8].        |
|                               | Fatal Parity Error            | NBCONFIG x 68 [10]    | <ul> <li>When set to 1 by hardware, this indicates an internal parity error classified as fatal has been detected. This is a read-only register bit that is the OR of all correctable classified parity error status bits.</li> <li>Note that since internal parity error classification registers are cleared on a warm reset, any logged parity errors will show up as correctable in NBCONFIG x68 [10:8].</li> </ul> |
|                               | HyperTransport Parity         | HTIUNBIND x 81 [7:0]  | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                                                                                                                                                                                                                                                                     |
|                               | MCU Parity                    | HTIUNBIND x 83 [1:0]  | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                                                                                                                                                                                                                                                                     |
|                               | PCIE-GPP1 Parity              | HTIUNBIND x 84 [21:0] | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                                                                                                                                                                                                                                                                     |
| SR5690/5670<br>All Revs       | PCIE-GPP2 Parity              | HTIUNBIND x 85 [21:0] | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block. (Not available on SR5650)                                                                                                                                                                                                                                                           |
| SR5690/5670/<br>5650 All Revs | PCIE-GPP3a Parity             | HTIUNBIND x 86 [15:0] | Each bit in this register may be set when a parity error is<br>detected in a corresponding memory located within the<br>associated block.                                                                                                                                                                                                                                                                               |
| SR5690 All Revs               | PCIE-GPP3b Parity             | HTIUNBIND x 87 [17:0] | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block. (Not available on SR5670 and SR5650)                                                                                                                                                                                                                                                |
| SR5690/5670/<br>5650 All Revs | PCIE-SB Parity                | HTIUNBIND x 88 [17:0] | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                                                                                                                                                                                                                                                                     |
| SR5690/5670/<br>5650 All Revs | IOMMU L1 GPP1 Parity          |                       | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                                                                                                                                                                                                                                                                     |
| SR5690/5670<br>All Revs       | IOMMU L1 GPP2 Parity          | HTIUNBIND x 8A [1:0]  | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block. (Not available on SR5650)                                                                                                                                                                                                                                                           |
| SR5690/5670/<br>5650 All Revs | IOMMU L1 GPP3a<br>Parity      | HTIUNBIND x 8B [1:0]  | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                                                                                                                                                                                                                                                                     |
| SR5690 All Revs               | IOMMU L1 GPP3b<br>Parity      | HTIUNBIND x 8C [1:0]  | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block. (Not available on SR5670 and SR5650)                                                                                                                                                                                                                                                |
| SR5690/5670/<br>5650 All Revs | IOMMU L1 SB Parity            | HTIUNBIND x 8D [1:0]  | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                                                                                                                                                                                                                                                                     |
| SR5690/5670/<br>5650 All Revs | IOMMU L1 GPP1 Cache<br>Parity | HTIUNBIND x 90 [1:0]  | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                                                                                                                                                                                                                                                                     |
| SR5690/5670<br>All Revs       | IOMMU L1 GPP2 Cache<br>Parity | HTIUNBIND x 91 [1:0]  | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block. (Not available on SR5650)                                                                                                                                                                                                                                                           |

# Table 7-19 Registers to Probe for HT Error Conditions (Continued)

| ASIC Rev        | Error Type                     | Status Register       | Description                                                                                                                                                              |
|-----------------|--------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/    | IOMMU L1 GPP3a                 | HTIUNBIND x 92 [1:0]  | Each bit in this register may be set when a parity error is                                                                                                              |
| 5650 All Revs   | Cache Parity                   |                       | detected in a corresponding memory located within the associated block.                                                                                                  |
| SR5690 All Revs | IOMMU L1 GPP3b<br>Cache Parity | HTIUNBIND x 93 [0]    | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block. (Not available on SR5670 and SR5650) |
| SR5690/5670/    | IOMMU L1 SB Cache              | HTIUNBIND x 94 [0]    | Each bit in this register may be set when a parity error is                                                                                                              |
| 5650 All Revs   | Parity                         |                       | detected in a corresponding memory located within the<br>associated block.                                                                                               |
|                 | IOMMU L2 Cache Parity          | HTIUNBIND x 96 [15:0] | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                      |
|                 | IOMMU L2 Cache Parity          | HTIUNBIND x 97 [31:0] | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                      |
|                 | IOMMU L2 Cache Parity          | HTIUNBIND x 98 [23:0] | Each bit in this register may be set when a parity error is detected in a corresponding memory located within the associated block.                                      |

## Table 7-19 Registers to Probe for HT Error Conditions (Continued)

# 7.3.4.3 Error Classification for Internal Parity Errors

The SR5690/5670/5650 treats internal parity errors as 2 groups: cache and non-cache. Cache errors can then be classified as either fatal, non-fatal or correctable (fundamentally they are correctable at the hardware level). Non-cache errors can be classified as non-fatal or fatal (there is no recovery from these).

| ASIC Rev      | Error Type             | Register                    | Classification |
|---------------|------------------------|-----------------------------|----------------|
| SR5690/5670/  | Cache Parity Error     | NBCONFIG x 68 [29:28] = 0x2 | Fatal          |
| 5650 All Revs |                        | NBCONFIG x 68 [29:28] = 0x1 | Non-fatal      |
|               |                        | NBCONFIG x 68 [29:28] = 0x0 | Correctable    |
|               | Non-Cache Parity Error | NBCONFIG x 68 [31:30] = 0x2 | Fatal          |
|               |                        | NBCONFIG x 68 [31:30] = 0x1 | Non-fatal      |

## **Recommended HyperTransport Error Classification**

It is recommended that HyperTransport error classification be configured as per the following table

#### Table 7-21 Recommended Internal Parity Error Classification

| ASIC Rev         | Error Type             | Classification |
|------------------|------------------------|----------------|
| SR5690/5670/5650 | Cache Parity Error     | Correctable    |
| All Revs         | Non-Cache Parity Error | Fatal          |

#### 7.3.4.4 Interrupt-Based Error Reporting for Internal Parity Errors

See *section 7.3.3.2 "Interrupt-Based Error Reporting for HyperTransport Errors" on page 7-9* for additional details. HT and internal parity errors share a common interrupt-based error reporting mechanism.

Unlike HyperTransport controller errors, internal parity error interrupts are enabled after classification. If an error type is not enabled for interrupt generation, only the status bits are set and no interrupt is generated. This may also trigger sideband error reporting.

#### Table 7-22 Internal Parity Error Interrupt Types

| ASIC Rev | Error Type               | Register Setting                                                              | Description                                                                       |
|----------|--------------------------|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
|          |                          | When set to 1, fatal parity errors trigger<br>interrupt-based error reporting |                                                                                   |
|          | Non-Fatal Parity Error   | NBCONFIG x 68 [17] = 0x1                                                      | When set to 1, non-fatal parity errors trigger<br>interrupt-based error reporting |
|          | Correctable Parity Error |                                                                               | When set to 1, correctable parity errors trigger interrupt-based error reporting  |

# 7.3.4.5 Sideband Pin Error Reporting for Internal Parity Errors

Internal parity errors may be reporting via sideband error pins. Please see the Sideband Pin Configuration section regarding how to configure SERR\_FATAL# and NON\_FATAL\_CORR# for parity errors.

Errors classified as SERR, fatal, non-fatal or correctable can be routed to the sideband pins. Interrupt generation for internal parity errors is independent of classification so it is possible to report certain parity errors through interrupts and others through sideband pins.

In order to avoid generating interrupts at the same time as reporting errors over sideband pins, interrupts should be disabled. Note that if interrupt generation for HyperTransport errors is disabled, this will also disable interrupt generation for internal parity errors.

| ASIC Rev                     | Register Setting | Description                                                                                                                   |
|------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/5650<br>All Revs | • •              | When set to 1, this enables reporting of SERR events from HyperTransport or<br>internal parity error sources via SERR_FATAL#. |
|                              | • •              | When set to 1, this enables reporting of fatal internal parity error events via<br>SERR_FATAL#                                |
|                              |                  | When set to 1, this enables reporting of non-fatal internal parity error events via NON_FATAL_CORR#                           |
|                              |                  | When set to 1, this enables reporting of correctable internal parity error events via NON_FATAL_CORR#.                        |

#### 7.3.4.6 Software Error Injection Facilities for Internal Parity Errors

Software may artificially inject internal parity errors into the system in order to test error handling capabilities (interrupt handlers, etc). The SR5690/5670/5650 can inject parity errors into either the read or write side of every internal array memory. Write-side injection may not result in a detected error if the memory location is never read or is overwritten before being read, which may occur in structures such as caches and replay buffers. Only parity bits are corrupted to avoid real data corruption. The following procedure should be used:

- 1. Clear both PerrGenInjectWrErr (HTIUNBIND 0x80 [30]) and PerrGenInjectRdErr (HTIUNBIND 0x80 [31])
- 2. Select the target block by programming PerrGenBlockSel (HTIUNBIND 0x80 [7:0])
- 3. Select the target macro by programming PerrGenMacroSel (HTIUNBIND 0x80 [23:16])
- 4. Set PerrGenInjectWrErr (HTIUNBIND 0x80 [30]) to 1 for write-side error injection or PerrGenInjectRdErr (HTIUNBIND 0x80 [31]) to 1 for read-side error injection. This must be a separate write operation from step 3. Steps 2 and 3 can be combined into a single write transaction if desired.

Error status is logged in the associated error status register bit and can be cleared by writing the status to 1.

| Block        | Parity Error Generation<br>Block Number<br>(PerrGenBlockSel) | Parity Error Generation<br>Macro Number<br>(PerrGenMacroSel) | Parity Error Status<br>Register | Status<br>Bits | Memory<br>Group |
|--------------|--------------------------------------------------------------|--------------------------------------------------------------|---------------------------------|----------------|-----------------|
| HTIU         | 0                                                            | 0x2->0x0                                                     | HTIUNBIND x 81                  | 2:0            | A               |
|              | 0                                                            | 0x3                                                          |                                 | 3              | В               |
|              | 0                                                            | 0x7->0x4                                                     |                                 | 7:4            | С               |
| NCU          | 2                                                            | 0x0                                                          | HTIUNBIND x 83                  | 0              | A               |
|              | 2                                                            | 0x1                                                          | -                               | 1              | В               |
| PCIE-GPP1    | 3                                                            | 0x1 -> 0x0                                                   | HTIUNBIND x 84                  | 1:0            | A               |
|              | 3                                                            | 0x2                                                          |                                 | 2              | В               |
|              | 3                                                            | 0x4 -> 0x3                                                   | -                               | 4:3            | С               |
|              | 3                                                            | 0x6 -> 0x5                                                   | -                               | 6:5            | D               |
|              | 3                                                            | 0x8 -> 0x7                                                   | -                               | 8:7            | E               |
|              | 3                                                            | 0xC -> 0x9                                                   |                                 | 12:9           | F               |
|              | 3                                                            | 0xD                                                          |                                 | 13             | G               |
|              | 3                                                            | 0x15 -> 0xE                                                  | -                               | 21:14          | Н               |
| PCIE-GPP2    | 4                                                            | 0x1 -> 0x0                                                   | HTIUNBIND x 85                  | 1:0            | A               |
|              | 4                                                            | 0x2                                                          | -                               | 2              | В               |
|              | 4                                                            | 0x4 -> 0x3                                                   | 1                               | 4:3            | С               |
|              | 4                                                            | 0x6 -> 0x5                                                   | -                               | 6:5            | D               |
|              | 4                                                            | 0x8 -> 0x7                                                   | -                               | 8:7            | E               |
|              | 4                                                            | 0xC -> 0x9                                                   | -                               | 12:9           | F               |
|              | 4                                                            | 0xD                                                          | -                               | 13             | G               |
|              | 4                                                            | 0x15 -> 0xE                                                  | -                               | 21:14          | H               |
| CIE-GPP3a    | 5                                                            | 0x1 -> 0x0                                                   | HTIUNBIND x 86                  | 1:0            | A               |
| 0.2 0.1 00   | 5                                                            | 0x2                                                          |                                 | 2              | В               |
|              | 5                                                            | 0x4 -> 0x3                                                   | -                               | -<br>4:3       | C               |
|              | 5                                                            | 0x6 -> 0x5                                                   | -                               | 6:5            | D               |
|              | 5                                                            | 0x8 -> 0x7                                                   | -                               | 8:7            | E               |
|              | 5                                                            | 0xC -> 0x9                                                   | -                               | 12:9           | F               |
|              | 5                                                            | 0xD                                                          | _                               | 12.0           | G               |
|              | 5                                                            | 0xF -> 0xE                                                   | -                               | 15:14          | H               |
| PCIE-GPP3b   | 6                                                            | 0x1 -> 0x0                                                   | HTIUNBIND x 87                  | 1:0            | A               |
|              | 6                                                            | 0x2                                                          |                                 | 2              | В               |
|              | 6                                                            | 0x4 -> 0x3                                                   | -                               | 4:3            | C               |
|              | 6                                                            | 0x8 -> 0x5                                                   | -                               | 8:5            | D               |
|              | 6                                                            | 0x9                                                          | -                               | 9              | E               |
|              | 6                                                            | 0x8                                                          | -                               | 5<br>10        | F               |
|              | 6                                                            | 0xE -> 0xB                                                   | _                               | 14:11          | G               |
|              | 6                                                            | 0xF                                                          | -                               | 15             | Н               |
|              | 6                                                            | 0x11 -> 0x10                                                 | _                               | 17:16          | 1               |
| CIE-SB       | 7                                                            | 0x1 -> 0x0                                                   | HTIUNBIND x 88                  | 1:0            | A               |
| CIL-3D       | 7                                                            | 0x1 -> 0x0                                                   |                                 | 2              | В               |
|              | 7                                                            | 0x2 -> 0x3                                                   | -                               | 2<br>4:3       | C               |
|              | 7                                                            | 0x4 -> 0x5                                                   | _                               | 4.5<br>8:5     | D               |
|              |                                                              |                                                              | _                               |                | E               |
|              | 7                                                            | 0x9                                                          | 4                               | 9              | F               |
|              | 7                                                            |                                                              | 4                               | 10             |                 |
|              | 7                                                            | 0xE -> 0xB                                                   | 4                               | 14:11          | G               |
|              | 7                                                            | 0xF                                                          | 4                               | 15             | H               |
|              | 7                                                            | 0x11 -> 0x10                                                 |                                 | 17:16          |                 |
| IOMMU L1 GPP |                                                              | 0x0                                                          | HTIUNBIND x 89                  | 0              | A               |
|              |                                                              |                                                              |                                 |                |                 |
| OMMU L1 GPP2 | 8                                                            | 0x1<br>0x0                                                   | HTIUNBIND x 8A                  | 1<br>0         | B<br>A          |

# Table 7-24 Mapping of Parity Error Injection Controls and Status to Memories

| Block           | Parity Error Generation<br>Block Number<br>(PerrGenBlockSel) | Parity Error Generation<br>Macro Number<br>(PerrGenMacroSel) | Parity Error Status<br>Register | Status<br>Bits | Memory<br>Group |
|-----------------|--------------------------------------------------------------|--------------------------------------------------------------|---------------------------------|----------------|-----------------|
| IOMMU L1        | 0xA                                                          | 0x0                                                          | HTIUNBIND x 8B                  | 0              | A               |
| GPP3a           | 0xA                                                          | 0x1                                                          |                                 | 1              | В               |
| IOMMU L1        | 0xB                                                          | 0x0                                                          | HTIUNBIND x 8C                  | 0              | А               |
| GPP3b           | 0xB                                                          | 0x1                                                          |                                 | 1              | В               |
| IOMMU L1 SB     | 0xC                                                          | 0x0                                                          | HTIUNBIND x 8D                  | 0              | A               |
|                 | 0xC                                                          | 0x1                                                          |                                 | 1              | В               |
| IOMMU L1 GPP1   | 0xF                                                          | 0x0                                                          | HTIUNBIND x 90                  | 0              | A               |
| Cache           | 0xF                                                          | 0x1                                                          | _                               | 1              | В               |
| IOMMU L1 GPP2   | 0x10                                                         | 0x0                                                          | HTIUNBIND x 91                  | 0              | A               |
| Cache (L1 GFX2) | 0x10                                                         | 0x1                                                          |                                 | 1              | В               |
| IOMMU L1        | 0x11                                                         | 0x0                                                          | HTIUNBIND x 92                  | 0              | A               |
| GPP3a Cache     | 0x11                                                         | 0x1                                                          |                                 | 1              | В               |
| IOMMU L1        | 0x12                                                         | 0x0                                                          | HTIUNBIND x 93                  | 0              | A               |
| GPP3b Cache     | 0x12                                                         | 0x1                                                          | _                               | 1              | В               |
| IOMMU L1 SB     | 0x13                                                         | 0x0                                                          | HTIUNBIND x 94                  | 0              | A               |
| Cache           | 0x13                                                         | 0x1                                                          |                                 | 1              | В               |
| IOMMU L2B       | 0x15                                                         | 0xF -> 0x0                                                   | HTIUNBIND x 96                  | 15:0           | A               |
| IOMMU L2A       | 0x16                                                         | 0x7 -> 0x0                                                   | HTIUNBIND x 97                  | 7:0            | A               |
|                 | 0x16                                                         | 0xF -> 0x8                                                   |                                 | 15:8           | В               |
|                 | 0x16                                                         | 0x17 -> 0x10                                                 | 1                               | 23:16          | С               |
|                 | 0x16                                                         | 0x1F -> 0x18                                                 | 1                               | 31:24          | D               |
|                 | 0x16                                                         | 0x27 -> 0x20                                                 | HTIUNBIND x 98                  | 7:0            | E               |
|                 | 0x16                                                         | 0x37 -> 0x28                                                 |                                 | 23:8           | F               |

Table 7-24 Mapping of Parity Error Injection Controls and Status to Memories (Continued)

# 7.3.5 PCIe<sup>®</sup> RAS Feature Configuration

Note that the following section references registers that must be set in all PCIe cores or ports. Only registers in active cores/ports should be accessed. Registers should not be accessed in non-existant core/port, or one that is unused and possibly clock-gated. Additionally, link level error reporting is not supported on the SB core. This link is normally hidden to operating system software which may prevent errors from being reported and handled properly. Per-core and per-port registers referenced in the following sections should not be set for the SB core/port. Parity checking logic described in the previous section is supported within the SB core.

# 7.3.5.1 PCIe® Advanced Error Reporting (AER) Capabilities

The advanced error reporting capabilities of PCIe<sup>®</sup> allow for the detection of a wide range of defined error types as well as programmable severity classification and selective reporting capabilities. System BIOS should enable AER before handing off control to the OS. Operating systems with native PCIe support may further modify the AER controls. Additionally, these registers also control the ability of the chipset to detect and log errors both in the AER capability as well as in the standard (non-AER) PCIe capability register set. Additional standard PCI/PCIe registers may also need to be set in order to propagate.

# **Exposing PCIe Advanced Error Reporting Capabilities:**

By default, the SR5690/5670/5650 does not expose its AER capability in PCI configuration space. The following registers should be programmed to expose the AER capability and enable the chipset to detect and log errors on the PCIe interfaces.

| ASIC Rev                      | Register                                | Description                                                                                                                                                                                                                                        |
|-------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs | PCIEIND x C0 [8] = 0x1                  | This register must be programmed for every enabled PCIe core except the SB core. It exposes AER capabilities in all PCIe bridges.                                                                                                                  |
|                               | NBMISCIND x 2D [29] = 0x0               | This register enables error reporting logic in the GPP3b PCIe core                                                                                                                                                                                 |
|                               | NBMISCIND x 24 [27:25] =<br>0x0         | This register enables error reporting logic in the GPP1, GPP2, and GPP3a PCIe cores                                                                                                                                                                |
| SR5690/5670/<br>5650 All Revs | PCIEIND_P x 6A [0] = 0x0                | This register enables error reporting logic in a PCIe port. This register must be explicitly written to 0 for each enabled PCIe port except the SB port, even though the hardware default value for this register is already 0.                    |
|                               | NBMISCIND x 19 [4:0] =<br>0x1F          | Enable completer abort logic in all PCIe cores.                                                                                                                                                                                                    |
|                               | NBMISCIND x 75 [27:13] =<br>0x4924      | Enable AER interface between IOC and IOMMU.                                                                                                                                                                                                        |
|                               | PCIEIND x 10 [22:21] = 0x0              | This register must be programmed for every enabled PCIe core except the SB core. It allows the PCIe core to check for improper attribute and function number fields in received completions.                                                       |
|                               | PCIEIND_P x 21 [15:0] =<br>Bridge ReqID | This register must be programmed for every enabled PCIe port except the SB port. It must be set to the requestor ID (bus, device, function) of the associated bridge to enable errors to be reported in the AER error source id register properly. |

# Table 7-25 Registers for Exposing PCIe® AER Capabilities

#### **Enabling PCIe® Advanced Error Reporting:**

In native PCIe mode, the operating system is responsible for enabling AER. For firmware based implementations, SBIOS software must perform this task.

The SR5690/5670/5650 implements a standard PCIe AER capability at offset 0x150 within each enabled PCIe bridge.

Please refer to the PCIe 2.0 Base Specification section 7.10 for more details.

The following algorithm may be used to determine when and where to enable AER. System BIOS should enable AER before handing off control to the OS.

For each PCIe root port

Configure root port AER uncorrectable error mask (root port offset 0x158. See the recommended AER error severity and mask settings table below)

Configure root port AER uncorrectable error severity (root port offset 0x15C. See the recommended AER error severity and mask settings table below)

Configure root port AER correctable error mask (root port offset 0x164. See the recommended AER error severity and mask settings table below)

Configure root port PCIe capability Device Control register to enable Fatal/Non-Fatal/Correctable Error Reporting for errors detected within the root port itself (set root port offset 0x60 bits 2:0 as appropriate)

Configure root port to propagate received ERR\_\* messages from the secondary side of the bridge to the primary side (root port offset 0x3E bit1)

If propagation of errors as System Error is desired, configure the root port to signal System Error on one or more error severities (Fatal/Non-Fatal/Correctable) (set root port offset 0x74 bits 2:0 as appropriate)

Check all PCIe devices behind the root port

Configure device PCIe capability Device Control register to enable Fatal/Non-Fatal/Correctable Error Reporting (offset 0x08 bits [2:0] inside the device's PCIe capability)

For switch devices, configure the bridges in the switch to propagate received ERR\_\* messages from the secondary side of the bridge to the primary side (set offset 0x3e bit 1)

For switch devices, if error propagation of errors as System Error is desired, configure the bridges in the switch to forward all fatal and non-fatal error messages upstream (set offset 0x4 bit 8)

If any device (switch upstream or downstream port, bridge or endpoint) contains an AER capability in its extended capability list

Configure device AER uncorrectable error mask (offset 0x8 inside the device's AER capability. See the recommended AER error severity and mask settings table below)

Configure device AER uncorrectable error severity (offset 0x8 inside the device's AER capability. See the recommended AER error severity and mask settings table below)

Configure device AER correctable error mask (offset 0x8 inside the device's AER capability. See the recommended AER

error severity and mask settings table below)

#### **Recommended AER Severity Settings:**

It is recommended that AER be configured as per the following table.

#### Table 7-26 Recommended AER Severity and Mask Settings for Root Complex and Switch Downstream Ports

| AER Feature                 | Severity                                                                                                                                                                 | Mask |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Data Link Protocol Error    | Fatal                                                                                                                                                                    | 0    |
| Poisoned TLP                | Fatal if poisoned data is not supported at the platform level (Family 10h processors).<br>Advisory non-fatal if poisoned data is supported at the platform level (Family | 0    |
|                             | 15h processors)                                                                                                                                                          |      |
| Flow control Protocol Error | Fatal                                                                                                                                                                    | 0    |
| Completion Timeout Error    | Fatal                                                                                                                                                                    | 0    |
| Completer Abort             | Advisory non-fatal                                                                                                                                                       | 0    |
| Unexpected Completion Error | Fatal                                                                                                                                                                    | 0    |
| Malformed TLP               | Fatal                                                                                                                                                                    | 0    |
| ECRC Error                  | Fatal. The SR5690/5670/5650 cannot convert an ECRC error into poisoned data.                                                                                             | 0    |
| Unsupported Request Error   | Advisory non-fatal                                                                                                                                                       | 0    |
| ACS Violation               | Fatal                                                                                                                                                                    | 0    |
| Bad TLP                     | Correctable                                                                                                                                                              | 0    |
| Bad DLLP                    | Correctable                                                                                                                                                              | 0    |
| REPLAY_NUM Rollover         | Correctable                                                                                                                                                              | 0    |
| Replay Timer Timeout        | Correctable                                                                                                                                                              | 0    |

#### Table 7-27 Recommended AER Severity and Mask Settings for Endpoint Devices and Switch Upstream Ports

| AER Feature                 | Severity                                                                                                                                                                                              | Mask |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Data Link Protocol Error    | Fatal                                                                                                                                                                                                 | 0    |
| Poisoned TLP                | Poisoned TLP Fatal if poisoned data is not supported at the platform level (Family 10h processors).<br>Advisory non-fatal if poisoned data is supported at the platform level (Family 15h processors) |      |
| Flow control Protocol Error | Fatal                                                                                                                                                                                                 | 0    |
| Completion Timeout Error    | Fatal                                                                                                                                                                                                 | 0    |
| Completer Abort             | Advisory non-fatal                                                                                                                                                                                    | 0    |
| Unexpected Completion Error | Fatal                                                                                                                                                                                                 | 0    |
| Malformed TLP               | Fatal                                                                                                                                                                                                 | 0    |
| ECRC Error                  | Fatal if poisoned data is not supported. Advisory non-fatal otherwise.                                                                                                                                | 0    |
| Unsupported Request Error   | Advisory non-fatal                                                                                                                                                                                    | 1    |
| ACS Violation               | Fatal                                                                                                                                                                                                 | 0    |
| Bad TLP                     | Correctable                                                                                                                                                                                           | 0    |
| Bad DLLP                    | Correctable                                                                                                                                                                                           | 0    |
| REPLAY_NUM Rollover         | Correctable                                                                                                                                                                                           | 0    |
| Replay Timer Timeout        | Correctable                                                                                                                                                                                           | 0    |

# 7.3.5.2 PCIe<sup>®</sup> End-to-End CRC (ECRC)

The chipset supports the PCIe ECRC feature. The AER capability must be exposed before ECRC can be configured. ECRC capabilities are exposed at the PCIe core level of granularity. ECRC generation capabilities should only be exposed on a PCIe core if one or more root ports associated with the core connects to a switch, and below the switch, an endpoint device supports the ECRC checking function. ECRC checking capabilities should only be exposed on a PCIe core if one or more root ports associated with the core connects to a switch, an endpoint device supports the ECRC generation function. Additionally, for root ports connected to switches using x8 or x16 widths, all endpoint devices attached below the switches must support the ECRC generation function, and none of the slots below the switch (including populated ones) may be hot-pluggable before ECRC checking may be exposed in the associated PCIe core.

Please see Errata #75 for more details. This can be determined after device enumeration by searching for devices which contain AER capabilities and advertise ECRC support (generation and/or checking) as part of that capability.

Note that it is legal for the chipset to send requests with ECRC to endpoints that do not support ECRC. This may occur if a root port connects to a switch with multiple downstream ports where some ports connect to endpoint devices supporting ECRC and others connect to endpoints that do not support ECRC. Endpoints that do not support ECRC should ignore the ECRC information.

The following registers are used to expose the ECRC checking and generation capabilities within the chipset. The programming requirements described above must be followed before exposing ECRC capabilities.

| ASIC Rev      | Register                  | Description                                                                                       |
|---------------|---------------------------|---------------------------------------------------------------------------------------------------|
| SR5690/5670/  | NBMISCIND x 2E [25] = 0x1 | Expose ECRC checking capabilities for all PCIe <sup>®</sup> bridges associated with the PCIE-GPP1 |
| 5650 All Revs |                           | core                                                                                              |
|               | NBMISCIND x 2E [26] = 0x1 | Expose ECRC checking capabilities for all PCIe bridges associated with the PCIE-GPP2              |
|               |                           | core                                                                                              |
|               | NBMISCIND x 2E [27] = 0x1 | Expose ECRC checking capabilities for all PCIe bridges associated with the PCIE-GPP3a             |
|               |                           | core                                                                                              |
|               | NBMISCIND x 2E [29] = 0x1 | Expose ECRC checking capabilities for all PCIe bridges associated with the PCIE-GPP3b             |
|               |                           | core                                                                                              |
|               | NBMISCIND x 2E [20] = 0x1 | Expose ECRC generation capabilities for all PCIe bridges associated with the PCIE-GPP1            |
|               |                           | core                                                                                              |
|               | NBMISCIND x 2E [21] = 0x1 | Expose ECRC generation capabilities for all PCIe bridges associated with the PCIE-GPP2            |
|               |                           | core                                                                                              |
|               | NBMISCIND x 2E [22] = 0x1 | Expose ECRC generation capabilities for all PCIe bridges associated with the PCIE-GPP3a           |
|               |                           | core                                                                                              |
|               | NBMISCIND x 2E [24] = 0x1 | Expose ECRC generation capabilities for all PCIe bridges associated with the PCIE-GPP3b           |
|               |                           | core                                                                                              |

 Table 7-28 Registers for Exposing PCIe<sup>®</sup> ECRC Capabilities

The SR5690/5670/5650 implements a standard PCIe ECRC control as part of AER located at offset 0x168 within each PCIe bridge.

Please refer to the PCIe 2.0 Base Specification section 7.10.7 for more details on the registers used to control ECRC.

The following algorithm may be used to determine when and where to enable ECRC. SBIOS should enable ECRC before handin off control to the OS.

For each PCIe root port check the device immediately behind the bridge

If this is an endpoint device, do not enable ECRC on the root port and go to the next root port

Else if this is a PCIe bridge and there are additional PCIe bridges located on the bus behind it, the root port is connected to a PCIe switch (as opposed to a different type of bridge such as a PCIe to PCI-X bridge).

Search all PCIe endpoint devices below the switch (which may be below additional switches).

If any endpoint device contains an AER capability in the extended capability list (type 0x1) and sets the ECRC Check Capable bit in Advanced Error Capabilities and Control Register (offset 0x18 bit 8 inside the device's AER capability) and the root port has ECRC\_GEN\_CAP=0x1

Set ECRC Check Enable in the endpoint device (offset 0x18 bit 7 inside the device's AER capability)

Set ECRC Generation Enable in the root port (root port offset 0x168 bit 6)

If any endpoint device contains an AER capability in the extended capability list (type 0x1) and sets the ECRC Generation Capable bit in Advanced Error Capabilities and Control Register (offset 0x18 bit 5 inside the AER cap) and the root port has ECRC\_GEN\_CAP=0x1

Set ECRC Check Enable in the root port (root port offset 0x168 bit 8)

Set ECRC Generation Enable in the endpoint device (offset 0x18 bit 6 inside the device's AER capability)

#### 7.3.5.3 PCIe<sup>®</sup> Access Control Services (ACS)

#### **Exposing PCIe Access Control Services Capabilities:**

By default, the SR5690/5670/5650 exposes its ACS capability in PCI configuration space. The following register controls whether the ACS capability is exposed or hidden.

#### Table 7-29 Registers for Exposing PCIe AER Capabilities

| ASIC Rev    | Register                 | Description                                  |
|-------------|--------------------------|----------------------------------------------|
| SR5690/5670 | NBMISCIND x 6A [2] = 0x1 | Expose ACS capabilities for all PCIe bridges |
| /5650 All   |                          |                                              |
| Revs        |                          |                                              |

#### **Enabling PCIe Access Control Services:**

In native PCIe mode, the operating system is responsible for enabling ACS. For firmware based implementations, system BIOS software must perform this task.

The SR5690/5670/5650 implements a standard PCIe ACS capability at offset 0x190 within each PCIe bridge.

Please refer to the PCIe 2.0 Base specification section 7.16 for more details.

#### **Recommended ACS Settings:**

It is recommended that the following ACS features be enabled by system BIOS before potentially handing off control of ACS to the operating system. ACS features should be enabled in the chipset's PCIe root ports, any switch downstream ports that support ACS, and in multi-function devices that support ACS.

#### **Table 7-30 Recommended ACS Settings**

| ASIC Rev         | Feature                     | Register                        | Recommended Setting                                                                                                                                                       |
|------------------|-----------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/5650 | ACS Source Validation       | ACS Capability Offset 0x6 bit 0 | Enable                                                                                                                                                                    |
| All Revs         | ACS P2P Request Redirect    | ACS Capability Offset 0x6 bit 2 | Enable                                                                                                                                                                    |
|                  | ACS P2P Completion Redirect | ACS Capability Offset 0x6 bit 3 | Enable                                                                                                                                                                    |
|                  | ACS Upstream Forwarding     | ACS Capability Offset 0x6 bit 4 | Enable                                                                                                                                                                    |
|                  | ACS Direct Translated P2P   | ACS Capability Offset 0x6 bit 6 | Enable                                                                                                                                                                    |
|                  | ACS Translation Blocking    |                                 | Enable if IOMMU is not supported or if IOMMU<br>is supported but ATS is not supported at the<br>platform level. Feature may also be enabled as<br>per the algorithm below |

The following algorithm may be used to determine when and where to enable ACS.

For each PCIe root port

Configure root port ACS control register (root port offset 0x196) to enable ACS source validation, ACS P2P redirect, ACS P2P completion redirect, ACS upstream forwarding and ACS direct translated P2P.

If ATS is not supported on this platform, enable ACS translation blocking in the root port ACS control register.

Check all PCIe devices behind the root port

If a PCIe switch downstream port or a multi-function endpoint device is found that supports ACS

Enable ACS source validation, ACS P2P redirect, ACS P2P completion redirect, ACS upstream forwarding and ACS direct translated P2P (offset 0x6 within the endpoint device or switch downstream port's ACS capability).

If no endpoint device below the root port supports ATS, enable ACS translation blocking in the root port ACS control register.

#### 7.3.5.4 PCIe<sup>®</sup> Link Disable on Errors

All PCIe links may be disabled when a HyperTransport syncflood is detected. In addition to this, a specific PCIe link may be disabled when a fatal or non-fatal error is detected on that link. This provides maximum error containment but makes error diagnosis more difficult.

| Table 7-31 Register | s for Disabling | PCIe <sup>®</sup> Links | on Errors |
|---------------------|-----------------|-------------------------|-----------|
|---------------------|-----------------|-------------------------|-----------|

| ASIC Rev    | Register                  | Description                                                                            |
|-------------|---------------------------|----------------------------------------------------------------------------------------|
| SR5690/5670 | PCIEIND_P x A1 [19] = 0x1 | Enable hardware to disable the corresponding PCIe link on error conditions. This       |
| /5650 All   |                           | register exists for each PCIe port. This register must be set in each enabled port, in |
| Revs        |                           | addition to the specific error response registers listed below.                        |

| ASIC Rev                      | Register                  | Description                                                                                                                               |
|-------------------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/                  | NBMISCIND x D [11] = 0x1  | Disables the PCIe link controlled by GPP1 port 0 when a HyperTransport Syncflood                                                          |
| 5650 All Revs                 |                           | event is detected                                                                                                                         |
|                               | NBMISCIND x D [15] = 0x1  | Disables the PCIe link controlled by GPP1 port 1 when a HyperTransport Syncflood<br>event is detected                                     |
| SR5690/5670                   | NBMISCIND x D [19] = 0x1  | Disables the PCIe link controlled by GPP2 port 0 when a HyperTransport Syncflood                                                          |
| All Revs                      |                           | event is detected. (Not available on SR5650)                                                                                              |
| SR5690                        | NBMISCIND x D [23] = 0x1  | Disables the PCIe link controlled by GPP2 port 1 when a HyperTransport Syncflood                                                          |
| All Revs                      |                           | event is detected. (Not available on SR5670 and SR5650)                                                                                   |
|                               | NBMISCIND x D [27] = 0x1  | Disables the PCIe link controlled by GPP3a port 0 when a HyperTransport Syncflood<br>event is detected                                    |
| SR5690/5670/<br>5650 All Revs | NBMISCIND x D [31] = 0x1  | Disables the PCIe link controlled by GPP3a port 1 when a HyperTransport Syncflood<br>event is detected                                    |
|                               | NBMISCIND x 4F [3] = 0x1  | Disables the PCIe link controlled by GPP3a port 2 when a HyperTransport Syncflood<br>event is detected                                    |
|                               | NBMISCIND x 4F [7] = 0x1  | Disables the PCIe link controlled by GPP3a port 3 when a HyperTransport Syncflood<br>event is detected                                    |
|                               | NBMISCIND x 4F [11] = 0x1 | Disables the PCIe link controlled by GPP3a port 4 when a HyperTransport Syncflood<br>event is detected                                    |
|                               | NBMISCIND x 4F [15] = 0x1 | Disables the PCIe link controlled by GPP3a port 5 when a HyperTransport Syncflood<br>event is detected                                    |
| SR5690 All<br>Revs            | NBMISCIND x D [7] = 0x1   | Disables the PCIe link controlled by GPP3b port 0 when a HyperTransport Syncflood event is detected. (Not available on SR5670 and SR5650) |

## Table 7-32 Registers for Disabling PCIe Links on HyperTransport Syncflood

# Table 7-33 Registers for Disabling PCIe® Links on Fatal Errors

| ASIC Rev                      | Register                  | Description                                                                                                                         |
|-------------------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650 All Revs | NBMISCIND x D [8] = 0x1   | Disables the PCIe link controlled by GPP1 port 0 when a Fatal error is detected on that port                                        |
|                               | NBMISCIND x D [12] = 0x1  | Disables the PCIe link controlled by GPP1 port 1 when a Fatal error is<br>detected on that port                                     |
| SR5690/5670<br>All Revs       | NBMISCIND x D [16] = 0x1  | Disables the PCIe link controlled by GPP2 port 0 when a Fatal error is detected on that port. (Not available on SR5650)             |
| SR5690<br>All Revs            | NBMISCIND x D [20] = 0x1  | Disables the PCIe link controlled by GPP2 port 1 when a Fatal error is detected on that port.(Not available on SR5670 and SR5650)   |
| SR5690/5670/<br>5650 All Revs | NBMISCIND x D [24] = 0x1  | Disables the PCIe link controlled by GPP3a port 0 when a Fatal error is<br>detected on that port                                    |
|                               | NBMISCIND x D [28] = 0x1  | Disables the PCIe link controlled by GPP3a port 1 when a Fatal error is<br>detected on that port                                    |
|                               | NBMISCIND x 4F [0] = 0x1  | Disables the PCIe link controlled by GPP3a port 2 when a Fatal error is detected on that port                                       |
|                               | NBMISCIND x 4F [4] = 0x1  | Disables the PCIe link controlled by GPP3a port 3 when a Fatal error is detected on that port                                       |
|                               | NBMISCIND x 4F [8] = 0x1  | Disables the PCIe link controlled by GPP3a port 4 when a Fatal error is detected on that port                                       |
|                               | NBMISCIND x 4F [12] = 0x1 | Disables the PCIe link controlled by GPP3a port 5 when a Fatal error is detected on that port                                       |
| SR5690<br>All Revs            | NBMISCIND x D [4] = 0x1   | Disables the PCIe link controlled by GPP3b port 0 when a Fatal error is detected on that port. (Not available on SR5670 and SR5650) |

| ASIC Rev      | Register                  | Description                                                                |
|---------------|---------------------------|----------------------------------------------------------------------------|
| SR5690/5670/  | NBMISCIND x D [9] = 0x1   | Disables the PCIe link controlled by GPP1 port 0 when a Non-Fatal error is |
| 5650 All Revs |                           | detected on that port                                                      |
|               | NBMISCIND x D [13] = 0x1  | Disables the PCIe link controlled by GPP1 port 1 when a Non-Fatal error is |
|               |                           | detected on that port                                                      |
| SR5690/5670   | NBMISCIND x D [17] = 0x1  | Disables the PCIe link controlled by GPP2 port 0 when a Non-Fatal error is |
| All Revs      |                           | detected on that port. (Not available on SR5650)                           |
| SR5690        | NBMISCIND x D [21] = 0x1  | Disables the PCIe link controlled by GPP2 port 1 when a Non-Fatal error is |
| All Revs      |                           | detected on that port. (Not available on SR5670 and SR5650)                |
| SR5690/5670/  | NBMISCIND x D [25] = 0x1  | Disables the PCIe link controlled by GPP3a port 0 when a Non-Fatal error   |
| 5650 All Revs |                           | is detected on that port                                                   |
|               | NBMISCIND x D [29] = 0x1  | Disables the PCIe link controlled by GPP3a port 1 when a Non-Fatal error   |
|               |                           | is detected on that port                                                   |
|               | NBMISCIND x 4F [1] = 0x1  | Disables the PCIe link controlled by GPP3a port 2 when a Non-Fatal error   |
|               |                           | is detected on that port                                                   |
|               | NBMISCIND x 4F [5] = 0x1  | Disables the PCIe link controlled by GPP3a port 3 when a Non-Fatal error   |
|               |                           | is detected on that port                                                   |
|               | NBMISCIND x 4F [9] = 0x1  | Disables the PCIe link controlled by GPP3a port 4 when a Non-Fatal error   |
|               |                           | is detected on that port                                                   |
|               | NBMISCIND x 4F [13] = 0x1 | Disables the PCIe link controlled by GPP3a port 5 when a Non-Fatal error   |
|               |                           | is detected on that port                                                   |
| SR5690        | NBMISCIND x D [5] = 0x1   | Disables the PCIe link controlled by GPP3b port 0 when a Non-Fatal error   |
| All Revs      |                           | is detected on that port. (Not available on SR5670 and SR5650)             |

Table 7-34 Registers for Disabling PCIe Links on Non-Fatal Errors

# 7.3.5.5 Error Status for PCIe<sup>®</sup> Errors

Error status for detected uncorrectable and correctable errors are stored in Uncorrectable Error Status and Correctable Error Status registers. The SR5690/5670/5650 implements these registers at offset 0x154 and 0x160 respectively within each PCIe bridge. The associated mask registers do not affect the setting of the status bits, only the associated interrupt generation.

Error status for received error messages is stored in the Root Error Status register. The SR5690/5670/5650 implements this register at offset 0x180 within each PCIe bridge.

Additional error information is stored in the Header Log and Error Source Identification registers. The SR5690/5670/5650 implements these register at offsets 0x16C->0x178 and offset 0x184 respectively within each PCIe bridge.

Please refer to the PCIe<sup>®</sup> 2.0 Base Specification section 7.10 for more details.

#### 7.3.5.6 Error Classification for PCIe Errors

Uncorrectable errors can be classified as either fatal or non-fatal or advisory non-fatal as per the Uncorrectable Error Severity register. The SR5690/5670/5650 implements this register at offset 0x15C within each PCIe bridge.

Please refer to the PCIe 2.0 Base specification section 7.10 for more details.

#### 7.3.5.7 Interrupt-Based Error Reporting for PCIe Errors

Interrupt-based error reporting is enabled for each error class by setting the associated error reporting enable registers in the Root Error Command Register. The SR5690/5670/5650 implements this register at offset 0x17C within each PCIe bridge.

Please refer to the PCIe 2.0 Base specification section 7.10 for more details.

#### 7.3.5.8 Sideband Pin Error Reporting for PCIe Errors

PCIe errors may be reported via sideband error reporting pins. In order to avoid generating interrupts at the same time as reporting errors over sideband pins, interrupts for the associated error class should be disabled. The classification of fatal versus non-fatal for uncorrectable errors is taken from the error severity programming in the AER capability space.

Fatal and non-fatal sideband reporting of detected errors must be enabled on a per-bridge basis. Sideband reporting of received ERR\_FATAL and ERR\_NONFATAL messages from endpoint devices also can be enabled on a per-bridge basis. In both cases, the bridge must additionally be enabled to report error conditions via sideband error reporting pins.

| ASIC Rev      | Register                  | Description                                                                                           |
|---------------|---------------------------|-------------------------------------------------------------------------------------------------------|
| SR5690/5670/  | NBMISCIND x 1B [5] = 0x0  | Enable detected fatal error sideband reporting for GPP1 port 0                                        |
| 5650 All Revs | NBMISCIND x 1B [11] = 0x0 | Enable detected fatal error sideband reporting for GPP1 port 1                                        |
|               | NBMISCIND x 19 [21] = 0x0 | Enable detected fatal error sideband reporting for GPP2 port 0. (Not available on SR5650)             |
|               | NBMISCIND x 19 [27] = 0x0 | Enable detected fatal error sideband reporting for GPP2 port 1. (Not available on SR5670 and SR5650)  |
|               | NBMISCIND x 1A [1] = 0x0  | Enable detected fatal error sideband reporting for GPP3a port 0                                       |
|               | NBMISCIND x 1A [7] = 0x0  | Enable detected fatal error sideband reporting for GPP3a port 1                                       |
|               | NBMISCIND x 1A [13] = 0x0 | Enable detected fatal error sideband reporting for GPP3a port 2                                       |
|               | NBMISCIND x 1A [19] = 0x0 | Enable detected fatal error sideband reporting for GPP3a port 3                                       |
|               | NBMISCIND x 1A [25] = 0x0 | Enable detected fatal error sideband reporting for GPP3a port 4                                       |
|               | NBMISCIND x 1A [31] = 0x0 | Enable detected fatal error sideband reporting for GPP3a port 5                                       |
|               | NBMISCIND x 19 [15] = 0x0 | Enable detected fatal error sideband reporting for GPP3b port 0. (Not available on SR5670 and SR5650) |

#### Table 7-36 Registers for Enabling Non-Fatal Sideband Error Reporting For Detected Non-Fatal Errors

| ASIC Rev      | Register                  | Description                                                                                               |
|---------------|---------------------------|-----------------------------------------------------------------------------------------------------------|
| SR5690/5670/  | NBMISCIND x 1B [1] = 0x0  | Enable detected non-fatal error sideband reporting for GPP1 port 0                                        |
| 5650 All Revs | NBMISCIND x 1B [7] = 0x0  | Enable detected non-fatal error sideband reporting for GPP1 port 1                                        |
|               | NBMISCIND x 19 [17] = 0x0 | Enable detected non-fatal error sideband reporting for GPP2 port 0. (Not available on SR5650)             |
|               | NBMISCIND x 19 [23] = 0x0 | Enable detected non-fatal error sideband reporting for GPP2 port 1. (Not available on SR5670 and SR5650)  |
|               | NBMISCIND x 19 [29] = 0x0 | Enable detected non-fatal error sideband reporting for GPP3a port 0                                       |
|               | NBMISCIND x 1A [3] = 0x0  | Enable detected non-fatal error sideband reporting for GPP3a port 1                                       |
|               | NBMISCIND x 1A [9] = 0x0  | Enable detected non-fatal error sideband reporting for GPP3a port 2                                       |
|               | NBMISCIND x 1A [15] = 0x0 | Enable detected non-fatal error sideband reporting for GPP3a port 3                                       |
|               | NBMISCIND x 1A [21] = 0x0 | Enable detected non-fatal error sideband reporting for GPP3a port 4                                       |
|               | NBMISCIND x 1A [27] = 0x0 | Enable detected non-fatal error sideband reporting for GPP3a port 5                                       |
|               | NBMISCIND x 19 [11] = 0x0 | Enable detected non-fatal error sideband reporting for GPP3b port 0. (Not available on SR5670 and SR5650) |

#### Table 7-37 Registers for Enabling Correctable Sideband Error Reporting For Detected Correctable Errors

| ASIC Rev Register | Description |
|-------------------|-------------|
|-------------------|-------------|

| SR5690/5670/  | NBMISCIND x 1B [3] = 0x0  | Enable detected correctable error sideband reporting for GPP1 port 0                                        |
|---------------|---------------------------|-------------------------------------------------------------------------------------------------------------|
| 5650 All Revs | NBMISCIND x 1B [9] = 0x0  | Enable detected correctable error sideband reporting for GPP1 port 1                                        |
|               | NBMISCIND x 19 [19] = 0x0 | Enable detected correctable error sideband reporting for GPP2 port 0. (Not available on SR5650)             |
|               | NBMISCIND x 19 [25] = 0x0 | Enable detected correctable error sideband reporting for GPP2 port 1. (Not available on SR5670 and SR5650)  |
|               | NBMISCIND x 19 [31] = 0x0 | Enable detected correctable error sideband reporting for GPP3a port 0                                       |
|               | NBMISCIND x 1A [5] = 0x0  | Enable detected correctable error sideband reporting for GPP3a port 1                                       |
|               | NBMISCIND x 1A [11] = 0x0 | Enable detected correctable error sideband reporting for GPP3a port 2                                       |
|               | NBMISCIND x 1A [17] = 0x0 | Enable detected correctable error sideband reporting for GPP3a port 3                                       |
|               | NBMISCIND x 1A [23] = 0x0 | Enable detected correctable error sideband reporting for GPP3a port 4                                       |
|               | NBMISCIND x 1A [29] = 0x0 | Enable detected correctable error sideband reporting for GPP3a port 5                                       |
|               | NBMISCIND x 19 [13] = 0x0 | Enable detected correctable error sideband reporting for GPP3b port 0. (Not available on SR5670 and SR5650) |

# Table 7-37 Registers for Enabling Correctable Sideband Error Reporting For Detected Correctable Errors

### Table 7-38 Registers for Enabling Fatal Sideband Error Reporting for Received ERR\_FATAL Messages

| ASIC Rev      | Register                  | Description                                                                                         |
|---------------|---------------------------|-----------------------------------------------------------------------------------------------------|
| SR5690/5670/  | NBMISCIND x 1B [6] = 0x0  | Enable received ERR_FATAL sideband reporting for GPP1 port 0                                        |
| 5650 All Revs | NBMISCIND x 1B [12] = 0x0 | Enable received ERR_FATAL sideband reporting for GPP1 port 1                                        |
|               | NBMISCIND x 19 [22] = 0x0 | Enable received ERR_FATAL sideband reporting for GPP2 port 0. (Not available on SR5650)             |
|               | NBMISCIND x 19 [28] = 0x0 | Enable received ERR_FATAL sideband reporting for GPP2 port 1. (Not available on SR5670 and SR5650)  |
|               | NBMISCIND x 1A [2] = 0x0  | Enable received ERR_FATAL sideband reporting for GPP3a port 0                                       |
|               | NBMISCIND x 1A [8] = 0x0  | Enable received ERR_FATAL sideband reporting for GPP3a port 1                                       |
|               | NBMISCIND x 1A [14] = 0x0 | Enable received ERR_FATAL sideband reporting for GPP3a port 2                                       |
|               | NBMISCIND x 1A [20] = 0x0 | Enable received ERR_FATAL sideband reporting for GPP3a port 3                                       |
|               | NBMISCIND x 1A [26] = 0x0 | Enable received ERR_FATAL sideband reporting for GPP3a port 4                                       |
|               | NBMISCIND x 1B [0] = 0x0  | Enable received ERR_FATAL sideband reporting for GPP3a port 5                                       |
|               | NBMISCIND x 19 [16] = 0x0 | Enable received ERR_FATAL sideband reporting for GPP3b port 0. (Not available on SR5670 and SR5650) |

# Table 7-39 Registers for Enabling Non-Fatal Sideband Error Reporting for Received ERR\_NONFATAL Messages

| ASIC Rev      | Register                  | Description                                                                                              |
|---------------|---------------------------|----------------------------------------------------------------------------------------------------------|
| SR5690/5670/  | NBMISCIND x 1B [2] = 0x0  | Enable received ERR_NONFATAL sideband reporting for GPP1 port 0                                          |
| 5650 All Revs | NBMISCIND x 1B [8] = 0x0  | Enable received ERR_NONFATAL sideband reporting for GPP1 port 1                                          |
|               | NBMISCIND x 19 [18] = 0x0 | Enable received ERR_NONFATAL sideband reporting for GPP2 port 0. (Not available on SR5650)               |
|               | NBMISCIND x 19 [24] = 0x0 | Enable received ERR_NONFATAL sideband reporting for GPP2 port 1.<br>(Not available on SR5670 and SR5650) |
|               | NBMISCIND x 19 [30] = 0x0 | Enable received ERR_NONFATAL sideband reporting for GPP3a port 0                                         |
|               | NBMISCIND x 1A [4] = 0x0  | Enable received ERR_NONFATAL sideband reporting for GPP3a port 1                                         |
|               | NBMISCIND x 1A [10] = 0x0 | Enable received ERR_NONFATAL sideband reporting for GPP3a port 2                                         |
|               | NBMISCIND x 1A [16] = 0x0 | Enable received ERR_NONFATAL sideband reporting for GPP3a port 3                                         |
|               | NBMISCIND x 1A [22] = 0x0 | Enable received ERR_NONFATAL sideband reporting for GPP3a port 4                                         |
|               | NBMISCIND x 1A [28] = 0x0 | Enable received ERR_NONFATAL sideband reporting for GPP3a port 5                                         |
|               | NBMISCIND x 19 [12] = 0x0 | Enable received ERR_NONFATAL sideband reporting for GPP3b port 0. (Not available on SR5670 and SR5650)   |

# 7.3.5.9 Software Error Injection Facilities for PCIe<sup>®</sup> Errors

The chipset is capable of injecting LCRC and ECRC errors in the transmit and receive directions of each PCIe port. In order to stimulate additional error types, a PCIe exerciser is required.

| ASIC Rev        | Register           | Description                                                                |
|-----------------|--------------------|----------------------------------------------------------------------------|
| SR5690/5670/565 | PCIEIND_P 0x6A [4] | Writing this register to 1 causes an outbound TLP to have an LCRC error on |
| 0 All Revs      |                    | the corresponding PCIe link                                                |
|                 | PCIEIND_P 0x6A [5] | Writing this register to 1 causes an inbound TLP to have an LCRC error on  |
|                 |                    | the corresponding PCIe link                                                |
|                 | PCIEIND_P 0x6A [6] | Writing this register to 1 causes an outbound TLP to have an ECRC error on |
|                 |                    | the corresponding PCIe link                                                |
|                 | PCIEIND_P 0x6A [7] | Writing this register to 1 causes an inbound TLP to have an ECRC error on  |
|                 |                    | the corresponding PCIe link                                                |

| Table 7-40 | Registers | for PCle | Error In | iection |
|------------|-----------|----------|----------|---------|
| 14010 1 10 |           |          |          | Jeenen  |

# 7.3.5.10 Data Poisoning

The chipset supports passing the data poisoning attribute from data packets on the Hypertransport<sup>™</sup> interface to the PCIe interfaces and vice-versa. Support for data poisoning within the processor, PCIe endpoint devices, associated device drivers as well as the OS are also required to support the feature at the system level.

When data packets are transmitted or received on the PCIe interfaces with the data poisoning attribute, the PCI Data Parity Error and Master Data Parity Error status bits may be set (depending on transaction type and direction) within the affected PCIe bridge. DPE/MDPE are never set in the host bridge (nbconfig) register space.

# 7.3.5.11 RAS Programming Workarounds

#### Table 7-41 Registers for RAS Programming Workarounds

| ASIC Rev     | Register                             | Description                                                                                                                                                        |
|--------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/ | HTIUNBIND x 0 [7] = <mark>0x1</mark> | Setting this register prevents PCIe <sup>®</sup> AER error status registers from being                                                                             |
| 5650 Rev A21 |                                      | cleared on warm reset.                                                                                                                                             |
|              | NBMISCIND x 35 [10] = 0x0            | Clearing this register fixes an error containment issue when PCIe links are<br>disabled.                                                                           |
|              | PCIEIND x 2 [1] = 0x1                | Fix replay number rollover behaviour. This needs to be set in every enabled PCIe core.                                                                             |
|              | PCIEIND x 2 [2] = 0x1                | Fix poisoned data error logging in the AER error status registers so that it can be logged as advisory non-fatal. This needs to be set in every PCIe enabled core. |
|              | HTIUNBIND x 5 [15] = 0x1             | Fix parity collector acknowledge logic for IOMMU L2 cache parity errors                                                                                            |
|              | PCIEIND_P x 70 [12] = 0x0            | Clearing this register enables the detection of certain malformed ATS requests.<br>This register needs to be cleared in every enabled PCIe port.                   |

#### 7.3.5.12 Masked Memory Initialization (for A21)

For the A21 silicon revision, the following sequence should be performed to initialize masked memories and avoid the potential for the detection of false parity errors. This sequence should be performed only after a cold reset, after system BIOS has been shadowed to system memory and is no longer executing out of ROM.

#### Table 7-42 Registers for Masked Memory Initialization

| ASIC Rev | Step | Register | Description |
|----------|------|----------|-------------|
|----------|------|----------|-------------|

| SR5690/5670/ | 1 | NBMISCIND x 1B [29:21] = 0x0 | Clear memory initialization controls.                                      |
|--------------|---|------------------------------|----------------------------------------------------------------------------|
| 5650 Rev A21 | 2 | NBMISCIND x 1B [15] = 0x1    | Start memory initialization.                                               |
|              | 3 | NBMISCIND x 1B [29:22] = X   | The register write in step 3 must be a separate request from steps 2 or 5. |
|              |   |                              | Repeat steps 3 to 5 for X = 0x0 to 0xFF                                    |
|              | 4 | NBMISCIND x 1B [21] = 0x1    | The register write in step 4 must be a separate request from step 3.       |
|              | 5 | NBMISCIND x 1B [21] = 0x0    | The register write in step 5 must be a separate request from step 4.       |
|              |   |                              | After step 5, go back to step 3 until X = 0xFF                             |
|              | 6 | NBMISCIND x 1B [15] = 0x0    | End memory initialization.                                                 |
|              | 7 | =                            | Clear out any potential false parity errors from PCIE-GPP3b and PCIE-SB    |
|              |   | HTIUNBIND x 88 = 0xFFFF_FFF  | memory after cold boot.                                                    |

# Table 7-42 Registers for Masked Memory Initialization

# 7.4 Platform Level Error Handling

SR5690/5670/5650 platforms may be configured into different error detection and handling modes depending on the desired error handling policy of the OEM. In general, errors may be handled by the operating system or hypervisor (OS-first), system BIOS (firmware-first), or trigger a system halt with a HyperTransport<sup>™</sup> syncflood and the disabling of PCIe links. The following table describes the supported error handling mode for each error type and severity.

| Table 7-43 Supported Error Handling | g Modes By Error Type |
|-------------------------------------|-----------------------|
|-------------------------------------|-----------------------|

| Error Source/Soucrity                                                                                                                                                                                        | Error Handling Mode |          |             |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------|-------------|--|
| Error Source/Severity                                                                                                                                                                                        | OS-First            | FW-First | System Halt |  |
| HyperTransport Fatal                                                                                                                                                                                         | No *                | Yes      | Yes         |  |
| HyperTransport Non-Fatal                                                                                                                                                                                     | No *                | Yes      | Yes         |  |
| Internal Parity Fatal                                                                                                                                                                                        | No *                | Yes      | Yes         |  |
| Internal Parity Correctable                                                                                                                                                                                  | No *                | Yes      | Yes         |  |
| PCIe Fatal                                                                                                                                                                                                   | Yes                 | Yes      | Yes         |  |
| PCIe Non-Fatal                                                                                                                                                                                               | Yes                 | Yes      | Yes         |  |
| PCIe Correctable                                                                                                                                                                                             | Yes                 | Yes      | Yes         |  |
| * While the SR5690/5670 hardware supports OS-first error handling for HyperTransport and internal parity errors, software support is not expected to be delivered for most operating systems or hypervisors. |                     |          |             |  |

If OS-first error handling support is desired for some or all PCIe error severities, it is recommended that the associated error type be configured for either firmware-first or system halt error handling by the system BIOS before initializing the OS/hypervisor. OS-first support can then be enabled for the desired error severities (and the default error handling method disabled) if an OS/hypervisor requests error handling control via the \_OSC method. If no request is made by the OS/hypervisor, errors can still be handled by the default method.

The system BIOS is expected to configure the chipsets for the desired error handling methods as per *section 7.3 "RAS Feature Configuration" on page 7-1*.

Utilizing a mix of OS-first and FW-first error handling for different PCIe error severities is not recommended as it introduces complications related to the reporting of errors via both methods simultaneously.

# 7.4.1 OS-First Error Handling

Operating system or hypervisor level software may be used to receive PCIe error reports directly from the SR5690/5670/5650 and handle them in an appropriate manner. The SR5690/5670/5650 should be configured by the OS/hypervisor to generate appropriately classified interrupts upon the detection of errors. Error status will be logged inside the hardware. Either native operating system code or an appropriate error handling device driver is required to handle the error, extract the status and log this information back to the OS.

# 7.4.1.1 WHEA OS-First Support

Windows Sever<sup>®</sup> 2008 has built-in support for PCIe Advanced Error Reporting through Windows Hardware Error Architecture (WHEA). Windows is capable of configuring AER, handling AER related interrupts and logging errors into a system event log. System BIOS must configure PCIe to operate in "native" mode for this support to function properly. System BIOS may override the Windows default configuration of the AER control registers via the ACPI Hardware Error

Source Table (HEST) table in order to set error severity. The HEST must contain entries to describe PCIe root ports, switches and endpoint devices that support AER. See the WHEA Platform Design Guide for more details.

For HyperTransport and internal parity error functions, the SR5690/5670/5650 can be configured to generate interrupts when errors are detected. These would be described as generic hardware error sources in the HEST. Errors need to be handled by a PSHED plug-in which would manage the reporting of the error into WHEA as well as clearing the error and supporting error injection for test purposes etc. There is currently no plan to develop a PSHED plug-in for HyperTransport or internal parity errors.

# 7.4.1.2 Linux OS-First Support

Current versions of Linux are capable of supporting PCIe AER. System BIOS must configure PCIe to operate in the "native" mode.

# 7.4.2 Firmware-First Error Handling

In FW-first error handling, System BIOS is responsible for handling errors. Errors are reported through the sideband error reporting pins SERR\_FATAL# and NON\_FATAL\_CORR#, and then routed to an SMI generating pin on the southbridge which will trigger entry into the BIOS. It is recommended that SERR\_FATAL# and NON\_FATAL\_CORR# be isolated between different SR5690/5670/5650s to make it easier to identify the specific chipset reporting the error. The signals can be connected together in a wired-OR manner after the isolation buffers. The specific pin used to trigger SMI# is platform dependent as are any GPIO pins needed to enable the routing between SERR\_FATAL# and NON\_FATAL\_CORR# and the SMI# pin.

It is suggested that only SERR, Fatal and Non-Fatal errors be routed to the error reporting pins. Correctable errors can be handled by periodically polling the associated correctable error status registers in the SR5690/5670/5650.

See *section 7.3.1, section 7.3.3.3, section 7.3.4.5*, and *section 7.3.5.8* for details on reporting errors via sideband error reporting pins.

See section 7.4.2.2 for more details on the steps that need to be performed in an SMI error handling routine.

# 7.4.2.1 WHEA Firmware-First Support

Under WHEA in Windows Server 2008, specific error sources may be declared to the operating system in the HEST as operating in firmware-first mode. For error sources configured as firmware-first, the system BIOS is responsible for enabling, handling and clearing the error condition. It must then copy error information into an error status block and signal the OS through NMI#. It is possible to have some error sources configured to run as OS-first while others are configured as firmware-first.

The following table indicates the type of HEST entry to use when configuring the associated error source for FW-First mode. HEST entries need to be constructed for all component error sources and not just the chipset error sources. This document does not attempt to indicate the processor requirements for WHEA, but processors also need to be described in the HEST. For PCIe error sources, two HEST entries need to be constructed - a generic hardware error source and an associated PCIe component that indicates the firmware first mode of operation.

| Error Source                               | HEST Entry Type               | Associated HEST Entry Type                               | Hardware Error Notification<br>Structure Type |
|--------------------------------------------|-------------------------------|----------------------------------------------------------|-----------------------------------------------|
| HyperTransport                             | Generic Hardware Error Source | None                                                     | NMI#                                          |
| Internal Parity Error                      | Generic Hardware Error Source | None                                                     | NMI#                                          |
| PCIe Root Port                             |                               | PCIe Root Port AER Structure marked<br>as FIRMWARE_FIRST | NMI#                                          |
| PCIe Endpoint Device                       |                               | PCIe Device AER Structure marked as<br>FIRMWARE_FIRST    | NMI#                                          |
| PCIe Switch Upstream or<br>Downstream Port |                               | PCIe Device AER Structure marked as<br>FIRMWARE_FIRST    | NMI#                                          |
| PCIe to PCI-X Bridge                       |                               | PCle Bridge AER Structure marked as<br>FIRMWARE_FIRST    | NMI#                                          |

#### Table 7-44 Error Source HEST Entry Types

When system BIOS reports errors to WHEA via the firmware-first method, error information is entered into the generic error data structures. These are formatted according to the tables defined in appendix N of the UEFI specification. HyperTransport and internal parity errors should be reported using the PCI/PCI-X Component Error Section with error status taken from the following table depending on the specific error. No error register information needs to be entered.

|        | Error Type                | Section Type                 | Error Status/Error Type | Error<br>Status/Add<br>ress | Error<br>Status/<br>Control | Error<br>Status/<br>Data | Error<br>Status/<br>Responder |
|--------|---------------------------|------------------------------|-------------------------|-----------------------------|-----------------------------|--------------------------|-------------------------------|
| НТ     | Protocol                  | PCI/PCI-X<br>Component Error | 23 - ERR_PROTOCOL       | 0                           | 0                           | 0                        | 0                             |
|        | Overflow                  | PCI/PCI-X<br>Component Error | 9 - ERR_FLOW            | 0                           | 0                           | 0                        | 0                             |
|        | Response                  | PCI/PCI-X<br>Component Error | 21 - ERR_RESPONSE       | 0                           | 0                           | 0                        | 0                             |
|        | Periodic CRC Error        | PCI/PCI-X<br>Component Error | 22 - ERR_PARITY         | 0                           | 0                           | 0                        | 1                             |
|        | Per-Packet CRC<br>Error   | PCI/PCI-X<br>Component Error | 22 - ERR_PARITY         | 0                           | 0                           | 0                        | 1                             |
|        | Retry Counter<br>Rollover | PCI/PCI-X<br>Component Error | 16 - Bus (generic)      | 0                           | 0                           | 0                        | 1                             |
| Parity | Cache Parity Error        | PCI/PCI-X<br>Component Error | 6 - ERR_CACHE           | 0                           | 0                           | 0                        | 0                             |
|        | Non-Cache Parity<br>Error | PCI/PCI-X<br>Component Error | 4 - ERR_MEM             | 0                           | 0                           | 0                        | 0                             |

 Table 7-45 Error Types and Error Status for HyperTransport and Internal Parity Errors

PCIe errors may be reported through the generic error data using the PCIe Error Section.

Raw data for HT and internal parity errors may also be stored to provide increased information.

|        | Error Type             | Raw Data Length in Bytes | Raw Data |
|--------|------------------------|--------------------------|----------|
| HT     | Protocol               | 4                        | 0x0      |
|        | Overflow               | 4                        | 0x1      |
|        | Response               | 4                        | 0x2      |
|        | Periodic CRC Error     | 4                        | 0x3      |
|        | Per-Packet CRC Error   | 4                        | 0x4      |
|        | Retry Counter Rollover | 4                        | 0x5      |
| Parity | Cache Parity Error     | 4                        | 0x10     |
|        | Non-Cache Parity Error | 4                        | 0x11     |

#### Table 7-46 Raw Data for Error Type

#### 7.4.2.2 Sample System BIOS Service Routine

System BIOS may use the following skeleton routine as part of the SMI handler for chipset errors.

1. Identify the error source.

System BIOS may detect which of SERR\_FATAL# or NON\_FATAL\_CORR# pins are asserted on a particular SR5690/5670/5650 by reading back the state of the pins. See *section 7.3.1.3 "SERR\_FATAL# and NON\_FATAL\_CORR# Status Readback" on page 7-5.* 

System BIOS must then probe the status bits associated with all of the possible error sources for the associated error class (SERR+fatal or non-fatal+correctable) to identify the source of the error. Only error sources that have been configured to generate errors through SERR\_FATAL# or NON\_FATAL\_CORR# need to be checked.

2. Execute any OEM specific error handling/reporting code for the associated error.

3. Clear the error status. This is generally done by overwriting the specific error status bit with a "1".

4. If running a WHEA-enabled operating system, report the error to WHEA by filling in the generic error data structure with the error information followed by the generation of an NMI#. This NMI must be directed to a specific processor core and not be a broadcast NMI. See *section 7.3.1.5 "NMI# Pin" on page 7-6* for more details on NMI generation.

# 7.4.3 System Halt on Error

The SR5690/5670/5650 can be configured to initiate a HyperTransport<sup>™</sup> syncflood and to disable all PCIe<sup>®</sup> lanes upon the detection of an error. This feature may be used to prevent the escape of corrupted data to disk or network. Refer to the following table for information on how to configure the system halt behavior for a particular error source/severity combination.

| Error Source | Error Severity | System Halt Configuration                                             |
|--------------|----------------|-----------------------------------------------------------------------|
| HT           | Fatal          | Configure individual HT error types to trigger syncflood              |
|              |                | Configure PCIe $^{\mathbb{R}}$ Links to be disabled on HT syncflood   |
|              | Non-Fatal      | Configure individual HT error types to trigger syncflood              |
|              |                | Configure PCIe Links to be disabled on HT syncflood                   |
| Parity       | Fatal          | Configure HT to syncflood on fatal internal parity errors             |
|              |                | Configure PCIe Links to be disabled on HT syncflood                   |
|              | Correctable    | Configure HT to syncflood on correctable fatal internal parity errors |
|              |                | Configure PCIe Links to be disabled on HT syncflood                   |
| PCle         | Fatal          | Configure HT to syncflood on PCIe fatal errors                        |
|              |                | Configure PCIe Links to be disabled on HT syncflood                   |
|              |                | Configure PCIe Links detecting fatal errors to be disabled            |
|              | Non-Fatal      | Configure HT to syncflood on PCIe non-fatal errors                    |
|              |                | Configure PCIe Links to be disabled on HT syncflood                   |
|              |                | Configure PCIe Links detecting non-fatal errors to be disabled        |

# Table 7-47 System Halt Configuration

Additionally, error information may be routed out of the SERR\_FATAL# pin. The BMC may monitor SERR\_FATAL# so that it can facilitate a warm-reset after error detection to re-initialize the system and initiate error status recovery. If both FW-first error SMI generation and system halt status are sharing SERR\_FATAL#, a watchdog timer function can be used by the BMC to differentiate between a FW-first error and a system halt. The timer can be disabled by system BIOS executing the error handling SMI routine.



Figure 7-5 Disabling of PCIe Lanes caused by Error Detection

#### 7.4.3.1 Recovery of Error Status After Warm Boot

A warm-reset should be performed after a system halt to bring the system back online for error status recovery. After the warm-reset, system BIOS software may read back all error status registers within the system (processors, chipsets, endpoint devices) to determine the source of the error. Error status registers in the chipset are preserved across a warm-reset but not a cold-reset.

# 7.4.3.2 BOOT Error Source Support

Error status that is recovered after a warm-reset can be propagated to the operating system through the ACPI BOOT Error Record Table (BERT). Windows Server 2008 supports BERT through WHEA.

For more details on Windows Server 2008 through WHEA using the BOOT error source reporting mechanism, please refer to the WHEA platform design guide.

# **Chapter 8** IOMMU Initialization

This chapter describes initialization and feature programming of the SR5690/5670/5650 IOMMU subsystem.

# 8.1 IOMMU Configuration Space

The IOMMU configuration space consists of the following four groups:

- PCI Configuration space
- IOMMU Memory Mapped Register space
- IOMMU L1 Indexed space
- IOMMU L2 Indexed space

# 8.1.1 PCI Configuration Space

The PCI Configuration space consists of an IOMMU function (System Base Peripheral class and IOMMU sub-class) combined with an IOMMU capability. There are also MSI and MSI-Mapping capabilities in the capability chain. Multiple IOMMU functions may be located within a single system at Bus n, Device 0, Function 2, where n is the primary bus number of the corresponding northbridge.

# 8.1.2 IOMMU Memory Mapped Register Space

The IOMMU Memory Mapped registers are mapped using the IOMMU Base Address Low register (Capability Offset 0x04) and IOMMU Base Address High register (Capability Offset 0x08) from IOMMU Capability Header, which starts at 0x40, specified in the PCI Configuration space.

# 8.1.3 IOMMU L1 Indexed Space

The IOMMU L1 Indexed space contains control and status registers that are generic to all L1s present in the IOMMU.

This register space is accessed through an index/data register pair located in the PCI Configuration space:

## nbconfigfunc2:0xF8/0xFC (PCI Configuration Space, Bus n, Device 0, Function 2)

The IOMMU L1 Indexed Space is subdivided into six parts as IOMMU has six L1s. Hardware has been implemented to provide a mechanism to access these registers independently, through the programming of bits [19:16] of the index register 0xF8. The encoding is as follows:

|              | Bus n, Device 0, Function 2 : (IOMMU_L1, IOMMU_L2) :<br>L1CFG_INDEX · nbconfigfunc2:0xf8 | Function/Comment             |
|--------------|------------------------------------------------------------------------------------------|------------------------------|
| SR5690/5670/ | NBCONFIGFUNC2:L1CFG_INDEX[15:0] = Register Offset · nbconfigfunc2:0xf8                   | Register Offset              |
| 5650         | L1CFG_INDEX                                                                              |                              |
| All Revs     | NBCONFIGFUNC2:L1CFG_INDEX[19:16] = L1 Offset · nbconfigfunc2:0xf8                        | Use the following encoding:  |
|              | L1CFG_SEL                                                                                | 0x0 for GPP1                 |
|              |                                                                                          | 0x1 for GPP2                 |
|              |                                                                                          | 0x2 for SB                   |
|              |                                                                                          | 0x3 for GPP3a                |
|              |                                                                                          | 0x4 for GPP3b                |
|              |                                                                                          | 0x5 for VC1                  |
|              | NBCONFIGFUNC2:L1CFG_INDEX[31]=1'b1 · nbconfigfunc2:0xf8<br>L1CFG_EN                      | Enable writing to L1CFG_DATA |

## Table 8-2 IOMMU L1 Data Register

| ASIC Rev     | Bus n, Device 0, Function2 : (IOMMU_L1, IOMMU_L2):L1CFG_DATA·<br>nbconfigfunc2:0xfc | Function/Comment |
|--------------|-------------------------------------------------------------------------------------|------------------|
| SR5690/5670/ | NBCONFIGFUNC2:L1CFG_DATA[31:0] = Register Offset · nbconfigfunc2:0xf8               | Data Value       |
| 5650         | L1CFG_DATA                                                                          |                  |
| All Revs     |                                                                                     |                  |

# 8.1.4 IOMMU L2 Indexed Space

The IOMMU L2 Indexed Space contains control and status registers for IOMMU L2.

This register space is accessed through an index/data register pair located in the PCI Configuration Space. Please note the following for the index/data register pair:

# nbconfigfunc2:0xF0/0xF4 (PCI Configuration Space, Bus n, Device 0, Function 2)

#### Table 8-3 IOMMU L2 Indexed Register

| ASIC Rev     | Bus n, Device 0, Function2:(IOMMU_L1, IOMMU_L2):L2CFG_INDEX ・<br>nbconfigfunc2:0xf0 | Function/Comment             |
|--------------|-------------------------------------------------------------------------------------|------------------------------|
| SR5690/5670/ | NBCONFIGFUNC2:L2CFG_INDEX[15:0]=Register Offset · nbconfigfunc2:0xf0                | Register Offset              |
| 5650         | L2CFG_INDEX                                                                         |                              |
| All Revs     | NBCONFIGFUNC2:L2CFG_INDEX[8]=0x1 · nbconfigfunc2:0xf0                               | Enable writing to L1CFG_DATA |
|              | L2CFG_EN                                                                            |                              |

#### Table 8-4 IOMMU L2 Data Register

| ASIC Rev     | Bus n, Device 0, Function2 : (IOMMU_L1, IOMMU_L2):L2CFG_DATA·<br>nbconfigfunc2:0xf4 | Function/Comment |
|--------------|-------------------------------------------------------------------------------------|------------------|
| SR5690/5670/ | NBCONFIGFUNC2:L2CFG_DATA[31:0]=Register Offset · nbconfigfunc2:0xF4                 | Data Value       |
| 5650         | L2CFG_DATA                                                                          |                  |
| All Revs     |                                                                                     |                  |

# 8.2 **IOMMU Initialization**

NOTE: Steps described in this section need to be done for each IOMMU present in the system. Each IOMMU should use a different MMIO region for memory-mapped registers.

#### Table 8-5 IOMMU Initialization

| ASIC Rev     | Step | Register Settings                             | Function/Comment                                 |
|--------------|------|-----------------------------------------------|--------------------------------------------------|
| SR5690/5670/ | 1    | NBCFG:IOC_FEATURE_CNTL[0]=0x1· NBMISCIND:0x75 | Enable Access to Device 0, Function 2.           |
| 5650         |      | IOC_FEATURE_CNTL_10_0                         |                                                  |
| All Revs     |      | Set bit [0] to 0x1.                           |                                                  |
| -            | 2    | IOMMU_L2:IOMMU_CAP_BASE_LO[31:14] ·           | SBIOS must allocate a 16K region of MMIO         |
|              |      | nbconfigfunc2:0x44                            | space (16K aligned) for IOMMU memory-mapped      |
|              |      | IOMMU_BASE_ADDR_LO                            | registers. This base address of this region must |
|              |      | IOMMU_L2:IOMMU_CAP_BASE_HI[31:0] ·            | be programmed into the IOMMU base address        |
|              |      | nbconfigfunc2:0x48                            | register.                                        |
|              |      | IOMMU_BASE_ADDR_HI                            |                                                  |
| SR5690/5670/ | 3    | IOMMU_L2: IOMMU_CONTROL_W[8] =0x0             | For A11 only. Disable ATS support due to byte    |
| 5650         |      | nbconfigfunc2:0x6C                            | reverse ordering issue.                          |
| Rev A11 only |      | IO_TLBSUP_W                                   |                                                  |
|              |      | Clear bit [8] to 0x0                          |                                                  |

| ASIC Rev     | Step | Register Settings                          | Function/Comment                              |
|--------------|------|--------------------------------------------|-----------------------------------------------|
| SR5690/5670/ | 4    | IOMMU_L2:IOMMU_CAP_MISC[22]=0x0 ·          | SBIOS should ensure the Address Translation   |
| 5650         |      | nbconfigfunc2:0x50                         | address range can be translated by the IOMMU. |
| All Revs     |      | IOMMU_HT_ATS_RESV                          |                                               |
|              |      | Clear bit [22] to 0x0                      |                                               |
|              | 5    | IOMMU_L2:IOMMU_CAP_BASE_LO[0]=0x1·         | All IOMMU RW capability registers in PCI      |
|              |      | nbconfigfunc2:0x44                         | Configuration space are locked until the next |
|              |      | IOMMU_ENABLE                               | system reset.                                 |
|              |      | Set bit [0] to 0x1.                        |                                               |
|              | 6    | IOMMU_L2MMIO: IOMMU_MMIO_CMD_BASE_0 = 0x0  | Reset iommu mmio registers on warm reset,     |
|              |      | Clear to 0x0                               | since they are only reset by a cold reset in  |
|              |      |                                            | hardware.                                     |
|              |      | IOMMU_L2MMIO:IOMMU_MMIO_CMD_BASE_1 =       |                                               |
|              |      | 0x0800_0000                                |                                               |
|              |      | Set to 0x0800_0000                         |                                               |
|              |      | IOMMU L2MMIO:IOMMU MMIO EVENT BASE 0 = 0x0 |                                               |
|              |      | Clear to 0x0                               |                                               |
|              |      |                                            |                                               |
|              |      | IOMMU L2MMIO:IOMMU MMIO EVENT BASE 1 = 0x0 |                                               |
|              |      | Clear to 0x0                               |                                               |
|              |      |                                            |                                               |
|              |      | IOMMU_L2MMIO:IOMMU_MMIO_CMD_BUF_TAILPTR_0  |                                               |
|              |      | = 0x0                                      |                                               |
|              |      | Clear to 0x0                               |                                               |
|              |      |                                            |                                               |
|              |      | IOMMU_L2MMIO:IOMMU_MMIO_EVENT_BUF_HDPTR_0  |                                               |
|              |      | = 0x0                                      |                                               |
|              |      | Clear to 0x0                               |                                               |

# Table 8-5 IOMMU Initialization (Continued)

# 8.2.1 IOMMU L1 Initialization

## Table 8-6 IOMMU L1 Initialization

| ASIC Rev    | Step | Register Settings                              | Function/Comment                               |
|-------------|------|------------------------------------------------|------------------------------------------------|
| SR5690/5670 | 1    | IOMMU_L1:L1_CNTRL_0[30:28] = 0x7· L1CFGIND:0xC | For each L1 increase virtual queues to maximum |
| /5650       |      | L1VirtOrderQueues                              | number for Virtual Queue hashing.              |
| All Revs    |      | Set bits [30:28]=0x7                           |                                                |
|             | 2    | IOMMU_L1:L1_DEBUG_1[5]=0x1·L1CFGIND:0x7        | Enable ECO to prevent waiting for read         |
|             |      |                                                | completions on invalidations, this is a        |
|             |      | Set bit [5]=0x1.                               | performance feature                            |

# 8.2.1.1 Enabling Phantom Function Support

To enable Phantom Function support, SBIOS is required to apply the algorithm described in Table 8-7 below.

# Table 8-7 Enabling Phantom Function Support

| ASIC Rev     | Step | Field Settings                                                    | Function/Comment                                |
|--------------|------|-------------------------------------------------------------------|-------------------------------------------------|
| SR5690/5670/ | 1    | In the PCIe® Configuration space of each PCIe device present      | SBIOS will look into PCIe Configuration space   |
| 5650         |      | in the system, read back bits [4:3] of:                           | of each PCIe device present in the system after |
| All Revs     |      | PCIE_DEVICE_CAP[4:3] · (Offset 0x04 from PCI Express <sup>®</sup> | the enumeration and read back whether any       |
|              |      | Capability ID)                                                    | device residing on all ports of each multi-port |
|              |      | PHANTOM_FUNC                                                      | PCIe core advertises support for Phantom        |
|              |      |                                                                   | Function.                                       |

| SR5690/5670/         | 2 | IOMMU_L1:L1_DEBUG_1[0]=0x1 · L1CFGIND:0x7              | For A11 only                                       |
|----------------------|---|--------------------------------------------------------|----------------------------------------------------|
| 5650                 |   | L1DEBUG_0                                              |                                                    |
| A11                  |   |                                                        | If SBIOS finds that at least one PCIe device       |
|                      |   | Set bit [0] to 0x1                                     | among all of the ones residing on all ports of a   |
|                      |   |                                                        | single multi-port PCIe core advertises support     |
|                      |   |                                                        | for Phantom Function, then L1 Phantom              |
|                      |   |                                                        | Function support will be enabled from              |
|                      |   |                                                        | respective L1.                                     |
|                      |   |                                                        | Exception is made for L1s behind PCIe cores        |
|                      |   |                                                        | with HotPlug capable PCIe slots present in the     |
|                      |   |                                                        | system, as respective L1 Phantom Function          |
|                      |   |                                                        | support should be enabled at all time.             |
| SR5690/5670/<br>5650 | 3 | IOMMU_L1:L1_DEBUG_1[0]=0x0 · L1CFGIND:0x7<br>L1DEBUG_0 | For A21 only                                       |
| A21                  |   |                                                        | If all PCIe device residing on all ports of single |
|                      |   |                                                        | multi-port PCIe core do not advertise support for  |
|                      |   |                                                        | Phantom Function, then L1 Phantom Function         |
|                      |   |                                                        | support will be disabled from respective L1.       |

# Table 8-7 Enabling Phantom Function Support

# 8.2.1.2 Enabling PCIe<sup>®</sup> to PCI-X Bridge Support

To enable PCIe to PCI-X bridge support, SBIOS is required to apply the programming sequence described below.

# Table 8-8 Enabling PCIe to PCI-X Bridge Support

| ASIC Rev     | Step | Register Settings                           | Function/Comment                                         |
|--------------|------|---------------------------------------------|----------------------------------------------------------|
| SR5690/5670/ | 1    | IOMMU_L1:L1_CNTRL_1[2:0]=0x7 · L1CFGIND:0xD | If SBIOS finds that at least one PCIe to PCI-x bridge    |
| 5650         |      | L1_CNTRL_1                                  | exists on a PCIe port or a HotPlug capable PCIe slots    |
| All Revs     |      |                                             | is present on a PCIe port, then this register should be  |
|              |      | Set bit [2:0] to 0x7                        | set for the L1 corresponding to the particular PCIe core |

# 8.2.2 IOMMU L2 Initialization

## 8.2.2.1 IOMMU L2 Common Initialization

#### Table 8-9 IOMMU L2 Initialization

| ASIC Rev     | Step | Register Settings                                         | Function/Comment                                   |
|--------------|------|-----------------------------------------------------------|----------------------------------------------------|
| SR5690/5670/ | 1    | IOMMU_L2AINDX:L2_CONTROL_0[29]=0x1 · L2CFGIND:0xC         | Set attribute to VC1 L1 client to be arbitrated as |
| 5650         |      | IFifoClientPriority                                       | high priority.                                     |
| All Revs     |      | Set bit [29] to 0x1                                       |                                                    |
|              | 2    | IOMMU_L2AINDX:L2_DTC_CONTROL[9:8]=0x2 ·L2CFGIND:0         | Select DTC cache Invalidation Algorithm to be      |
|              |      | x10                                                       | sequential precise invalidation.                   |
|              |      | DTCInvalidationSel                                        |                                                    |
|              |      | Set bits [9:8] to 0x2                                     |                                                    |
|              | 3    | IOMMU_L2AINDX:L2_ITC_CONTROL[9:8]                         | Select ITC cache Invalidation Algorithm to be      |
|              |      | =0x2 · L2CFGIND:0x14                                      | sequential precise invalidation.                   |
|              |      | ITCInvalidationSel                                        |                                                    |
|              |      | Set bits [9:8] to 0x2                                     |                                                    |
|              | 4    | IOMMU_L2AINDX:L2_PTC_A_CONTROL[9:8]                       | Select PTC Cache A Invalidation Algorithm to       |
|              |      | =0x2 ·L2CFGIND:0x18                                       | be sequential precise invalidation.                |
|              |      | PTCAInvalidationSel                                       |                                                    |
|              |      | Set bits [9:8] to 0x2                                     |                                                    |
|              | 5    | IOMMU_L2AINDX:L2_PTC_B_CONTROL[9:8]                       | Select PTC Cache B Invalidation Algorithm to       |
|              |      | =0x2 ·L2CFGIND:0x1C                                       | be sequential precise invalidation.                |
|              |      | PTCBInvalidationSel                                       |                                                    |
|              |      | Set bits [9:8] to 0x2                                     |                                                    |
|              | 6    | IOMMU_L2INDX:L2_PDC_CONTROL [9:8]=0x2 ·                   | Select PDC Cache Invalidation Algorithm to be      |
|              |      | L2CFGIND:0x50                                             | sequential precise invalidation.                   |
|              |      | PDCInvalidationSel                                        |                                                    |
|              |      | Set bits [9:8] to 0x2                                     |                                                    |
| R5690/5670/  | 7    | IOMMU_L2AINDX:L2_DTC_CONTROL[4]=0x1·L2CFGIND:0x1          | Enable parity protection of DTC Cache.             |
| 5650         |      | 0                                                         |                                                    |
| All Revs     |      | DTCParityEn                                               |                                                    |
|              |      | Set bit [4] to 0x1.                                       |                                                    |
|              | 8    | IOMMU_L2AINDX:L2_ITC_CONTROL[4]=0x1 ·                     | Enable parity protection of ITC Cache.             |
|              |      | L2CFGIND:0x14                                             |                                                    |
|              |      | ITCParityEn                                               |                                                    |
|              |      | Set bit [4] to 0x1.                                       |                                                    |
|              | 9    | IOMMU_L2AINDX:L2_PTC_A_CONTROL[4]=0x1 ·                   | Enable parity protection of PTC Cache A.           |
|              |      | L2CFGIND:0x18                                             |                                                    |
|              |      | PTCAParityEn                                              |                                                    |
|              |      | Set bit [4] to 0x1.                                       |                                                    |
|              | 10   | IOMMU_L2AINDX:L2_PTC_B_CONTROL[4]=0x1 ·L2CFGIND:          | Enable parity protection of PTC Cache B.           |
|              |      | 0x1C                                                      |                                                    |
|              |      | PTCBParityEn                                              |                                                    |
|              |      | Set bit [4] to 0x1.                                       |                                                    |
|              | 11   | IOMMU_L2INDX:L2_PDC_CONTROL[4]=0x1·                       | Enable parity protection of PDC Cache.             |
|              |      | L2CFGIND:0x50                                             |                                                    |
|              |      | PDCParityEn                                               |                                                    |
|              |      | Set bit [4] to 0x1.                                       |                                                    |
| SR5690/5670/ | 12   | IOMMU L2AINDX:L2 DEBUG 0[7]=0x1· L2CFGIND:0x6             | Page mode does not override loCtl and              |
| 5650         |      | L2DEBUG0                                                  | SysMgt DTE attributes.                             |
| A21          |      | Set bit [7] to 0x1.                                       |                                                    |
|              |      |                                                           |                                                    |
|              |      |                                                           |                                                    |
|              |      | IOMMU_L2INDX:L2_DEBUG_3[0]=0x1· L2CFGIND:0x47<br>L2DEBUG3 |                                                    |
|              |      |                                                           |                                                    |
|              |      | Set bit [0] to 0x1.                                       |                                                    |

| ASIC Rev                   | Step | Register Settings                                                                                                                                                    | Function/Comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R5690/5670/<br>5650<br>A21 | 13   | IOMMU_L2AINDX:L2_DEBUG_1[1]=0x1+ L2CFGIND:0x7<br>L2DEBUG1<br>Set bit [1] to 0x1.<br>IOMMU_L2INDX:L2_DEBUG_3[1]=0x1+ L2CFGIND:0x47<br>L2DEBUG3<br>Set bit [1] to 0x1. | <ul> <li>Avoid aborting untranslated memory requests or address translation requests when any of the followingexclusion range address, system management range address, or I/O space range address is configured to block or pass through requests, and is located above the largest virtual address defined in the device table page mode field.</li> <li>Avoid aborting untranslated memory requests to the exclusion range, when the system management range address and/or the I/O space range address are configured to block or pass through requests, and when the device table entry has the translation valid bit cleared.</li> </ul> |
|                            | 14   | IOMMU_L2AINDX:L2_DEBUG_1[2]=0x1· L2CFGIND:0x7<br>L2DEBUG1<br>Set bit [2] to 0x1.                                                                                     | Abort address translation request in the syster<br>management address range when device tabl<br>entry has SysMgt=0x0, 0x1 or 0x2 and<br>IntTaLen[3:2]=0x3 or when device table entry<br>has SysMgt=0x3, IntTaLen[3:2]= 0x3, V=0x1<br>and TV=0x0.                                                                                                                                                                                                                                                                                                                                                                                               |
|                            | 15   | IOMMU_L2AINDX:L2_DEBUG_1[3]=0x1· L2CFGIND:0x7<br>L2DEBUG1<br>Set bit [3] to 0x1.<br>IOMMU_L2INDX:L2_DEBUG_3[3]=0x1· L2CFGIND:0x47<br>L2DEBUG3<br>Set bit [3] to 0x1. | Avoid treating interrupt requests as<br>untranslated memory requests or address<br>translation requests from exclusion range<br>under specific conditions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                            | 16   | IOMMU_L2AINDX:L2_DEBUG_1[4]=0x1· L2CFGIND:0x7<br>L2DEBUG1<br>Set bit [4] to 0x1.                                                                                     | Abort DMA read request in the HT interrupt address range when device table entry has IN bit cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                            | 17   | IOMMU_L2AINDX:L2_DEBUG_0[5]=0x1· L2CFGIND:0x6<br>L2DEBUG0                                                                                                            | Avoid corruption of EX bit when IOMMU has cached device table entry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                            | 18   | Set bit [5] to 0x1.<br>IOMMU_L2AINDX:L2_DEBUG_0[6]=0x1· L2CFGIND:0x6<br>L2DEBUG0<br>Set bit [6] to 0x1.                                                              | Avoid corruption of SE bit when IOMMU has cached device table entry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                            | 19   | IOMMU_L2AINDX:L2_DEBUG_1[5]=0x1· L2CFGIND:0x7<br>L2DEBUG1<br>Set bit [5] to 0x1.<br>IOMMU_L2INDX:L2_DEBUG_3[4]=0x1· L2CFGIND:0x47<br>L2DEBUG3<br>Set bit [4] to 0x1. | Avoid access right checks for pretranslated requests.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                            | 20   | IOMMU_L2AINDX:L2_DEBUG_1[6]=0x1· L2CFGIND:0x7<br>L2DEBUG1<br>Set bit [6] to 0x1.                                                                                     | Avoid corruption of IG bit for Startup and EOI interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                            | 21   | IOMMU_L2AINDX:L2_DEBUG_1[7]=0x1· L2CFGIND:0x7<br>L2DEBUG1                                                                                                            | Detect address translation request in the interrupt address range in all conditions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                            |      | Set bit [7] to 0x1.                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

### Table 8-9 IOMMU L2 Initialization (Continued)

| ASIC Rev     | Step | Register Settings                             | Function/Comment                               |
|--------------|------|-----------------------------------------------|------------------------------------------------|
| SR5690/5670/ | 22   | IOMMU_L2AINDX:L2_DEBUG_0[8]=0x1· L2CFGIND:0x6 | Abort address translation request to exclusion |
| 5650         |      | L2DEBUG0                                      | range when device table entry has both EX and  |
| A21          |      | 0-4 54 501 4- 0-4                             | TV bits cleared.                               |
|              |      | Set bit [8] to 0x1.                           |                                                |
|              | 23   | IOMMU_L2INDX:L2_PDC_WAY_CONTROL[31:0]=0xF000  | Configure PDC cache to 12-way set              |
|              |      | 0002 · L2CFGIND:0x52                          | associative cache.                             |
|              |      | PDCWayDisable                                 |                                                |
|              |      | PDCWayAccessDisable                           |                                                |
|              |      | Set bits [31:0] to 0xF000 0002.               |                                                |
| SR5690/5670/ | 24   | IOMMU_L2INDX:L2_ERR_RULE_CONTROL_0[0]=0x1·    | Lock fault detection rule sets.                |
| 5650         |      | L2CFGIND:0x80                                 |                                                |
| All Revs     |      | ERRRuleLock0                                  |                                                |
|              |      | Set bit [0] to 0x1.                           |                                                |
|              |      |                                               |                                                |
|              |      | IOMMU_L2INDX:L2_ERR_RULE_CONTROL_3[0]=0x1·    |                                                |
|              |      | L2CFGIND:0x30                                 |                                                |
|              |      | ERRRuleLock1                                  |                                                |
|              |      | Set bit [0] to 0x1.                           |                                                |

# Table 8-9 IOMMU L2 Initialization (Continued)

# 8.2.2.2 Optimizing IOMMU L2 Caches Performance Based on the Number of Functions/Devices/Buses in Use

For optimum performance of IOMMU L2 caches, SBIOS is required to scan all ReqIDs present in the configuration space topology of the system after enumeration and then apply the programming sequence described in *Table 8-10* below.

The following relationship must be maintained for each IOMMU L2 cache:

*BusBits* + *DeviceBits* + *FunctionBits* = log<sub>2</sub>(*CacheDepth/CacheAssociativity*)

NOTE: All low performing devices behind the southbridge might be excluded from the algorithm for optimal cache indexing.

| Table 8-10 | Programming \$ | Sequence of L2 | Caches Hash Control |
|------------|----------------|----------------|---------------------|
|------------|----------------|----------------|---------------------|

| ASIC Rev     | Step | Field Settings                                                  | Function/Comment                                    |
|--------------|------|-----------------------------------------------------------------|-----------------------------------------------------|
| SR5690/5670/ | 1    | For each IOMMU L2 caches, calculate maximum                     | Determine maximum number of (function + bus +       |
| 5650         |      | number of FuncBits+ DevBits + BusBits which can be              | device) bits which can be used in the algorithm for |
| All Revs     |      | used in the algorithm, based on                                 | each IOMMU L2 cache.                                |
|              |      | log <sub>2</sub> (CacheDepth/CacheAssociativity).               |                                                     |
|              |      | For DTC cache:                                                  |                                                     |
|              |      | Read back DTC cache depth by reading bits [31:28] of:           |                                                     |
|              |      | IOMMU L2AINDX:L2 DTC CONTROL[31:28]                             |                                                     |
|              |      | L2CFGIND:0x10                                                   |                                                     |
|              |      | DTCEntries                                                      |                                                     |
|              |      | and DTC cache associativity by reading back bits                |                                                     |
|              |      |                                                                 |                                                     |
|              |      | IOMMU_L2AINDX:L2_DTC_CONTROL[23:16]·<br>L2CFGIND:0x10           |                                                     |
|              |      | DTCWays                                                         |                                                     |
|              |      | As DTC cache depth = $2^{\text{DTCEntries}}$ , calculate the    |                                                     |
|              |      | maximum number of DTCFuncBits+ DTCDevBits +                     |                                                     |
|              |      | DTCBusBits bits which can be used in the algorithm              |                                                     |
|              |      | based on:                                                       |                                                     |
|              |      | DTCFuncBits + DTCDevBits + DTCBusBits =                         |                                                     |
|              |      | DTCEntries - log <sub>2</sub> (DTCWays)                         |                                                     |
|              |      | For ITC cache:                                                  |                                                     |
|              |      | Read back ITC cache depth by reading bits [31:28] of:           |                                                     |
|              |      | IOMMU_L2AINDX:L2_ITC_CONTROL[31:28]·                            |                                                     |
|              |      | L2CFGIND:0x14                                                   |                                                     |
|              |      | ITCEntries                                                      |                                                     |
|              |      | and ITC cache associativity by reading back bits [23:16] of:    |                                                     |
|              |      | IOMMU L2AINDX:L2 ITC CONTROL[23:16]                             |                                                     |
|              |      | L2CFGIND:0x14                                                   |                                                     |
|              |      | ITCWays                                                         |                                                     |
|              |      | As ITC cache depth = 2 <sup>^</sup> ITCEntries, calculate the   |                                                     |
|              |      | maximum number of ITCFuncBits+ ITCDevBits +                     |                                                     |
|              |      | ITCBusBits bits which can be used in the algorithm<br>based on: |                                                     |
|              |      | ITCFuncBits + ITCDevBits + ITCBusBits = ITCEntries -            |                                                     |
|              |      | log <sub>2</sub> (ITCWays)                                      |                                                     |
|              |      | Step 1 to be continued on the next page                         |                                                     |

| ASIC Rev     | Step | Field Settings                                                                          | Function/Comment |
|--------------|------|-----------------------------------------------------------------------------------------|------------------|
| SR5690/5670/ | 1    | Step 1 continued from the previous page                                                 |                  |
| 5650         |      |                                                                                         |                  |
| All Revs     |      | For PTCA cache:<br>Read back PTCA cache depth by reading bits [31:28]                   |                  |
|              |      | of:                                                                                     |                  |
|              |      | IOMMU_L2AINDX:L2_PTC_A_CONTROL[31:28]·                                                  |                  |
|              |      | L2CFGIND:0x18                                                                           |                  |
|              |      | PTCAEntries                                                                             |                  |
|              |      | and PTCA cache associativity by reading back bits [23:16] of:                           |                  |
|              |      | IOMMU_L2AINDX:L2_PTC_A_CONTROL[23:16]-<br>L2CFGIND:0x18                                 |                  |
|              |      | PTCAWays<br>As PTCA cache depth = 2 <sup>^</sup> PTCAEntries, calculate the             |                  |
|              |      | maximum number of PTCAFuncBits+ PTCADevBits +                                           |                  |
|              |      | PTCABusBits bits which can be used in the algorithm                                     |                  |
|              |      | based on:                                                                               |                  |
|              |      | PTCAFuncBits + PTCADevBits + PTCABusBits =                                              |                  |
|              |      | PTCAEntries - log <sub>2</sub> (PTCAWays)                                               |                  |
|              |      | For PTCB cache:                                                                         |                  |
|              |      | Read back PTCB cache depth by reading bits [31:28] of:                                  |                  |
|              |      | IOMMU_L2AINDX:L2_PTC_B_CONTROL[31:28]                                                   |                  |
|              |      | L2CFGIND:0x1C                                                                           |                  |
|              |      | PTCBEntries<br>and PTCB cache associativity by reading back bits                        |                  |
|              |      | [23:16] of:                                                                             |                  |
|              |      | IOMMU_L2AINDX:L2_PTC_B_CONTROL[23:16]                                                   |                  |
|              |      | L2CFGIND:0x1C                                                                           |                  |
|              |      | PTCBWays                                                                                |                  |
|              |      | As PTCB cache depth = 2^ PTCBEntries, calculate the                                     |                  |
|              |      | maximum number of PTCBFuncBits+ PTCBDevBits +                                           |                  |
|              |      | PTCBBusBits bits which can be used in the algorithm                                     |                  |
|              |      | based on:                                                                               |                  |
|              |      | PTCBFuncBits + PTCBDevBits + PTCBBusBits =<br>PTCBEntries - log <sub>2</sub> (PTCBWays) |                  |
|              |      | For PDC cache:                                                                          |                  |
|              |      | Read back PDC cache depth by reading bits [31:28] of:                                   |                  |
|              |      | IOMMU_L2INDX:L2_PDC_CONTROL[31:28] ·<br>L2CFGIND:0x50                                   |                  |
|              |      | PDCEntries                                                                              |                  |
|              |      | and PDC cache associativity by reading back bits                                        |                  |
|              |      | [23:16] of:                                                                             |                  |
|              |      | IOMMU_L2INDX:L2_PDC_CONTROL[23:16] ·<br>L2CFGIND:0x50                                   |                  |
|              |      | PDCWays                                                                                 |                  |
|              |      | As PDC cache depth = 2^ PDCEntries, calculate the                                       |                  |
|              |      | maximum number of PDCFuncBits + PDCDevBits +                                            |                  |
|              |      | PDCBBusBits bits which can be used in the algorithm based on:                           |                  |
|              |      | PDCFuncBits + PDCDevBits + PDCBusBits =                                                 |                  |
|              |      | PDCEntries - log <sub>2</sub> (PDCWays)                                                 |                  |
|              |      |                                                                                         |                  |

Table 8-10 Programming Sequence of L2 Caches Hash Control (Continued)

| ASIC Rev                         | Step | Field Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Function/Comment                                                                                        |
|----------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| SR5690/5670/<br>5650<br>All Revs | 2    | Identify the maximum function number present in the configuration space topology of the system and find FuncBits = log2(maxFunc +1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Identify maximum function number present in the system.                                                 |
|                                  |      | For Single Root IOV devices, SBIOS is required to read<br>back Total Number of Virtual Functions supported that<br>are associated with each Physical Function. To identify<br>TotalVFs supported by the device, follow the extended<br>capability linked list in the device's PCI Express<br>configuration space, to find the SR-IOV Extended<br>Capability header (capability ID = 0x0010), and then<br>read back bits [15:0] at offset 0xE from SR-IOV<br>Extended Capability. TotalVFs read, should then be<br>taken as max function number sub-set representative. If<br>TotalVFs >0x40, then clamp the max function number of<br>sub-set representative to 0x40. |                                                                                                         |
|                                  |      | For server systems, all southbridge internal device<br>utilizing multiple functions might be bypassed for<br>FuncBits calculation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                         |
|                                  | 3    | Identify the maximum device number present in the<br>configuration space topology of the system and find<br>DevBits = log2(maxDevice +1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Identify maximum device number present in the system.                                                   |
|                                  | 4    | Identify the maximum bus number present in the configuration space topology of the system and find BusBits = log2(maxBus +1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Identify maximum bus number present in the system.                                                      |
| -                                | 5    | For each IOMMU L2 cache, determine the actual<br>number of function bits which will be used for optimal<br>cache performance, referenced in the algorithm as<br>FuncBitsUsed.<br>FuncBitsUsed = 0x3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Determine the optimal number of function bits to<br>be used for optimal IOMMU L2 caches<br>performance. |
|                                  |      | Store FuncBitsUsed in respective fields for all L2<br>caches:<br>IOMMU_L2AINDX:L2_DTC_HASH_CONTROL[1:0]=<br>FuncBitsUsed · L2CFGIND:0x11<br>DTCFuncBits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                         |
|                                  |      | IOMMU_L2AINDX:L2_ITC_HASH_CONTROL[1:0]=<br>FuncBitsUsed · L2CFGIND:0x15<br>ITCFuncBits<br>IOMMU_L2AINDX:L2_PTC_A_HASH_CONTROL[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                         |
|                                  |      | = FuncBitsUsed · L2CFGIND:0x19<br>PTCAFuncBits<br>IOMMU_L2AINDX:L2_PTC_B_HASH_CONTROL[1:0]<br>= FuncBitsUsed · L2CFGIND:0x1D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                         |
|                                  |      | PTCBFuncBits<br>IOMMU_L2INDX:L2_PDC_HASH_CONTROL[1:0] =<br>FuncBitsUsed · L2CFGIND:0x51<br>PDCFuncBits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                         |

# Table 8-10 Programming Sequence of L2 Caches Hash Control (Continued)

| ASIC Rev     | Step | Field Settings                                                                   | Function/Comment                                  |
|--------------|------|----------------------------------------------------------------------------------|---------------------------------------------------|
| SR5690/5670/ | 6    | For each IOMMU L2 cache, determine the actual                                    | Determine the optimal number of device bits to be |
| 5650         |      | number of device bits which will be used for optimal                             | used for optimal IOMMU L2 caches performance.     |
| All Revs     |      | cache performance, referenced in the algorithm as<br>DevBitsUsed.                |                                                   |
|              |      | If max(DevBits,FuncBits-0x3) + 0x3 >=                                            |                                                   |
|              |      | log <sub>2</sub> (CacheDepth/CacheAssociativity), then                           |                                                   |
|              |      | DevBitsUsed = log <sub>2</sub> (CacheDepth/CacheAssociativity) –                 |                                                   |
|              |      | max(DevBits, FuncBits -0x3) -0x3,                                                |                                                   |
|              |      | store DevBitsUsed in respective fields for all L2 caches,                        |                                                   |
|              |      | and exit the algorithm.                                                          |                                                   |
|              |      | If max(DevBits, FuncBits -0x3) +0x3 <                                            |                                                   |
|              |      | log <sub>2</sub> (CacheDepth/CacheAssociativity), then                           |                                                   |
|              |      | DevBitsUsed = max(DevBits , FuncBits - 0x3 ),                                    |                                                   |
|              |      | store DevBitsUsed in respective fields and go to Step7.                          |                                                   |
|              |      | Store DeviceBitsUsed determined in Step5 in                                      |                                                   |
|              |      | respective fields for all L2 caches:                                             |                                                   |
|              |      | IOMMU_L2AINDX:L2_DTC_HASH_CONTROL[4:2]=                                          |                                                   |
|              |      | DeviceBitsUsed · L2CFGIND:0x11                                                   |                                                   |
|              |      |                                                                                  |                                                   |
|              |      | IOMMU_L2AINDX:L2_ITC_HASH_CONTROL[4:2] =<br>DeviceBitsUsed · L2CFGIND:0x15       |                                                   |
|              |      | ITCDevBits                                                                       |                                                   |
|              |      | IOMMU_L2AINDX:L2_PTC_A_HASH_CONTROL[4:2]                                         |                                                   |
|              |      | = DeviceBitsUsed · L2CFGIND:0x19                                                 |                                                   |
|              |      | PTCADevBits                                                                      |                                                   |
|              |      | IOMMU_L2AINDX:L2_PTC_B_HASH_CONTROL[4:2]                                         |                                                   |
|              |      | = DeviceBitsUsed · L2CFGIND:0x1D                                                 |                                                   |
|              |      | PTCBDevBits                                                                      |                                                   |
|              |      | IOMMU_L2INDX:L2_PDC_HASH_CONTROL[4:2] =                                          |                                                   |
|              |      | DeviceBitsUsed · L2CFGIND:0x51                                                   |                                                   |
|              |      | PDCDevBits                                                                       |                                                   |
|              | 7    | For each IOMMU L2 cache, determine the actual                                    | Determine the optimal number of bus bits to be    |
|              |      | number of bus bits which will be used for optimal cache                          | used for optimal IOMMU L2 caches performance.     |
|              |      | performance, referenced in the algorithm as                                      |                                                   |
|              |      | BusBitsUsed.<br>BusBitsUsed = log <sub>2</sub> (CacheDepth/CacheAssociativity) – |                                                   |
|              |      | DevBitsUsed – FuncBitsUsed,                                                      |                                                   |
|              |      | store BusBitsUsed in respective fields for all L2 caches,                        |                                                   |
|              |      | and exit the algorithm.                                                          |                                                   |
|              |      | Store BusBitsUsed in respective fields for all L2 caches                         |                                                   |
|              |      | IOMMU_L2AINDX:L2_DTC_HASH_CONTROL[8:5]=                                          |                                                   |
|              |      | BusBitsUsed · L2CFGIND:0x11                                                      |                                                   |
|              |      | DTCBusBits                                                                       |                                                   |
|              |      | IOMMU_L2AINDX:L2_ITC_HASH_CONTROL[8:5]=                                          |                                                   |
|              |      | BusBitsUsed · L2CFGIND:0x15                                                      |                                                   |
|              |      |                                                                                  |                                                   |
|              |      | IOMMU_L2AINDX:L2_PTC_A_HASH_CONTROL[8:5]                                         |                                                   |
|              |      | = BusBitsUsed · L2CFGIND:0x19                                                    |                                                   |
|              |      |                                                                                  |                                                   |
|              |      | IOMMU_L2AINDX:L2_PTC_B_HASH_CONTROL[8:5]<br>= BusBitsUsed · L2CFGIND:0x1D        |                                                   |
|              |      | PTCBBusBits                                                                      |                                                   |
|              |      | IOMMU_L2INDX:L2_PDC_HASH_CONTROL[8:5]=                                           |                                                   |
|              |      | BusBitsUsed · L2CFGIND:0x51                                                      |                                                   |
|              |      | PDCBusBits                                                                       |                                                   |

# Table 8-10 Programming Sequence of L2 Caches Hash Control (Continued)

# 8.3 Virtualization ACPI Tables

SBIOS is required to describe the IOMMUs present in the system along with their respective attributes as well as system I/O topology via configuration of I/O Virtualization ACPI tables. System software then honors the ACPI settings.

# 8.3.1 I/O Virtualization ACPI Tables Configuration

There are three types of data blocks defined by SBIOS in the IOMMU ACPI tables:

- I/O Virtualization Reporting Structure (IVRS)
- I/O Virtualization Hardware Definition (IVHD)
- I/O Virtualization Memory Definition (IVMD)

They are described in the sections below.

#### 8.3.1.1 I/O Virtualization Reporting Structure (IVRS)

SBIOS is required to build a single I/O Virtualization Reporting Structure (IVRS) block in a system that contains IOMMU/s.

For IVRS Table definition and individual fields description, refer to IOMMU 1.22+ specification.

The programming sequence of IVRS fields is described in *Table 8-11* below.

| ASIC Rev             | Step | Field Settings     | Function/Comment                                                          |
|----------------------|------|--------------------|---------------------------------------------------------------------------|
| SR5690/5670/<br>5650 | 1    | Signature ("IVRS") | ASCII encoding of IVRS.                                                   |
| All Revs             | 2    | Length (bytes)     | SBIOS is required to calculate length of total device reporting structure |
| Air Nov3             |      |                    | in bytes, including IVHD and IVMD structures, and populate the field.     |
|                      | 3    | Revision = 0x1     | IVRS revision number.                                                     |
|                      | 4    | Check              | SBIOS is required to calculate the checksum of the entire device          |
|                      |      |                    | reporting structure, including IVHD and IVMD structures, and populate     |
|                      |      |                    | this field, so that the total checksum is zero.                           |
|                      | 5    | OEM ID             | Identifies platform OEM.                                                  |
|                      | 6    | OEM Table ID       | Specified by OEM.                                                         |
| -                    | 7    | OEM Revision       | Specified by OEM.                                                         |
|                      | 8    | Creator ID         | Vendor ID of the utility that created the table                           |
|                      | 9    | Creator Revision   | Revision of the utility that created the table                            |
| -                    | 10   | lvinfo             | IVinfo field contains information common to all IOMMUs in a system.       |
|                      |      | IVinfo[31:23]=0x0  | Reserved.                                                                 |
|                      |      | Reserved.          |                                                                           |
|                      |      | IVinfo[22]=0x0     | ATS address translation range can be used for translation.                |
|                      |      | HtAtsResv          |                                                                           |
|                      |      | IVinfo[21:15]=0x40 | Maximum supported Virtual address size is 64 bits.                        |
|                      |      | VAsize             |                                                                           |
|                      |      | IVinfo[14:8]=0x34  | Maximum supported Physical address size is 52 bits.                       |
|                      |      | PAsize             |                                                                           |
|                      |      | IVinfo[7:0]=0x0    | Reserved.                                                                 |
|                      |      | Reserved.          |                                                                           |

#### Table 8-11 Programming Sequence of IOMMU IVRS

#### 8.3.1.2 I/O Virtualization Hardware Definition Block (IVHD)

SBIOS is required to build a single I/O Virtualization Hardware Definition (IVHD) block for each IOMMU that is present in the system.

For IVHD Table definition and individual fields description, refer to IOMMU 1.22+ specification.

The programming sequence of IOHD general fields is described in the table below below.

| ASIC Rev                         | Step | Field Settings                                                                                                                          | Function/Comment                                                                                                                                                                                                  |
|----------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR5690/5670/                     | 1    | Type=0x10                                                                                                                               | I/O virtualization hardware definition block.                                                                                                                                                                     |
| 5650<br>All Revs                 | 2    | IVHD flags                                                                                                                              | IVinfo field contains information common to all IOMMUs in a<br>system.                                                                                                                                            |
|                                  |      | IVHD flags [7:5]=0x0<br>Reserved.                                                                                                       | Reserved                                                                                                                                                                                                          |
|                                  |      | IVHD flags[4]<br>lotlbSup                                                                                                               | If IoTIbSup = 0x1, OEMs may choose to enable ATS support by having SBIOS set this flag or disable ATS support by clearing this flag, regardless of the state of the IoTIbSup register in PCI configuration space. |
|                                  |      | IVHD flags[3]= 0x1<br>Isoc                                                                                                              | Indicate to system software the value that should be programmed<br>into ISOC field of MMIO register at offset 0x18h.                                                                                              |
|                                  |      | IVHD flags[2]= 0x1<br>ResPassPW                                                                                                         | Indicate to system software the value that should be programmed<br>into RES_PASS_PW field of MMIO register at offset 0x18.                                                                                        |
|                                  |      | IVHD flags[1]= 0x1<br>PassPW                                                                                                            | Indicate to system software the value that should be programmed<br>into PASS_PW field of MMIO register at offset 0x18.                                                                                            |
|                                  |      | IVHD flags[0]= 0x0<br>HtTunEn<br>NOTE: Register setting for HtTunEn<br>does not apply as SR5690/5670/5650 is<br>a cave device.          | Override MMIO Offset 0x0018[HtTunEn] for system software.                                                                                                                                                         |
|                                  | 3    | Length                                                                                                                                  | SBIOS is required to calculate the size of the entire IVHD,<br>including IVHD device entries in bytes, starts from Type field and<br>record the value in this entry.                                              |
|                                  | 4    | Bus n, Device 0, Function 2                                                                                                             | DeviceID of IOMMU.                                                                                                                                                                                                |
| -                                | 5    | Capability offset                                                                                                                       | Offset in Capability space for control fields of IOMMU. It is required as IOMMU implements multiple capabilities.                                                                                                 |
|                                  | 6    | IOMMU base address                                                                                                                      | SBIOS is required to populate this field with Base address of IOMMU control registers once it maps them in Memory Mapped space.                                                                                   |
|                                  | 7    | PCI segment=0x0                                                                                                                         | PCI Segment number                                                                                                                                                                                                |
| SR5690/5670/<br>5650<br>All Revs | 8    | IOMMU info<br>IOMMU info[15:13]= 0x0<br>Reserved.                                                                                       | MSI number and UnitID<br>Reserved                                                                                                                                                                                 |
|                                  |      | IOMMU info[12:8]=0x14<br>Unit ID                                                                                                        | Unit ID number (Capability Offset 0Ch[UnitID])                                                                                                                                                                    |
|                                  |      | IOMMU info[7:5]=0x0<br>Reserved.                                                                                                        | Reserved.                                                                                                                                                                                                         |
| 005000/5070/                     | 0    | IOMMU info[4:0]=0x0                                                                                                                     | MSI message number                                                                                                                                                                                                |
| SR5690/5670/<br>5650<br>All Revs | 9    | I/O Virtualization Hardware Definition<br>(IVHD) bytes at offset 0x44-0x47 are<br>reserved and hence these fields should<br>be cleared. | Reserved                                                                                                                                                                                                          |

 Table 8-12 Programming Sequence of IOMMU IVHD General Fields

#### 8.3.1.3 I/O Virtualization Definition Blocks (IVHD) Device Entries

The IVHD Table uses 4 and 8 bytes long entries to describe all devices present in the system.

| ASIC Rev     |   |                                                                         |                                |                            | Function/Comment                             |
|--------------|---|-------------------------------------------------------------------------|--------------------------------|----------------------------|----------------------------------------------|
| SR5690/5670/ | 1 | Use 4-byte entry of Type 0x2 in order to describe the Southbridge SMBUS |                                |                            | SB SBMUS Controller                          |
| 5650         |   | Controller:                                                             |                                |                            | IVHD Entry.                                  |
| All Revs     |   | Byte0=Select                                                            | Byte1 & Byte2                  | Byte3=Data                 | NOTE: If the system                          |
|              |   | Byte0[7:0]=0x2                                                          | Bus 0x0, Device 0x14,          | Byte3[7]=0x1               | contains more than one                       |
|              |   |                                                                         | Function 0x0.                  | Lint1Pass                  | IOMMU, SB SMBUS                              |
|              |   |                                                                         |                                | Byte3[6]=0x0               | described only for the                       |
|              |   |                                                                         |                                | Lint0Pass                  | IOMMU attached to the                        |
|              |   |                                                                         |                                | Byte3[5:4]=0x1<br>SysMgt   | Southbridge.                                 |
|              |   |                                                                         |                                | Byte3[3]=0x0               |                                              |
|              |   |                                                                         |                                | Reserved                   |                                              |
|              |   |                                                                         |                                | Byte3[2]=0x1               |                                              |
|              |   |                                                                         |                                | NMIPass                    |                                              |
|              |   |                                                                         |                                | Byte3[1]=0x1               |                                              |
|              |   |                                                                         |                                | EIntPass                   |                                              |
|              |   |                                                                         |                                | Byte3[0]=0x1               |                                              |
|              |   |                                                                         |                                | INITPass                   |                                              |
| F            | 2 | Use 4-byte entry of Type 0x2 to                                         | o describe all internal Southb | oridge devices other       | SB Devices other than                        |
|              |   | than SMBUS controller (e.g. U                                           | SB controller, SATA controlle  | er etc.)                   | SMBUS controller IVHD                        |
|              |   | Byte0=Select                                                            | Byte1 & Byte2                  | Byte3=Data                 | Entry                                        |
|              |   | Byte0[7:0]=0x2                                                          | Bus 0, Device, Function        | Byte3[7]=1'b0              | NOTE: If the system                          |
|              |   |                                                                         | from PCI Configuration         | Lint1Pass                  | contains more than one                       |
|              |   |                                                                         | Topology for each SB           | Byte3[6]=1'b0              | IOMMU, Southbridge                           |
|              |   |                                                                         | device other than SMBUS        | Lint0Pas s                 | devices need to be                           |
|              |   |                                                                         | controller                     | Byte3[5:4]=1'b00<br>SysMgt | described only for the IOMMU attached to the |
|              |   |                                                                         |                                | Byte3[3]=1'b0              | -Southbridge                                 |
|              |   |                                                                         |                                | Reserved                   |                                              |
|              |   |                                                                         |                                | Byte3[2]=1'b0              | -                                            |
|              |   |                                                                         |                                | NMIPass                    |                                              |
|              |   |                                                                         |                                | Byte3[1]=1'0               | -                                            |
|              |   |                                                                         |                                | EIntPass                   |                                              |
|              |   |                                                                         |                                | Byte3[0]=1'b0              | _                                            |
|              |   |                                                                         |                                | INITPass                   |                                              |
|              | 3 | Use 4-byte entry of Type 0x2 to                                         | o describe a single device be  | hind PCIe bridge           | Device/s behind PCIe                         |
|              |   | or use Type 0x3 and 0x4 in or bridge.                                   | der to describe a range of de  | evices behind PCIe         | bridge/s;                                    |
|              |   | Byte0=Select                                                            | Byte1 & Byte2                  | Byte3=Data                 | 7                                            |
|              |   | For a single device behind                                              | DeviceID (Bus, Device,         | Byte3[7]=0x0               | 7                                            |
|              |   | PCIe bridge:                                                            | Function) from PCI             | Lint1Pass                  |                                              |
|              |   |                                                                         | Configuration Topology.        | Byte3[6]=0x0               |                                              |
|              |   | Byte0[7:0]=0x2                                                          |                                | Lint0Pass                  |                                              |
|              |   |                                                                         |                                | Byte3[5:4]=0x0             |                                              |
|              |   | For a range of devices behind                                           |                                | SysMgt                     |                                              |
|              |   | PCIe bridges:                                                           |                                | Byte3[3]=0x0               | 7                                            |
|              |   |                                                                         |                                | Reserved                   |                                              |
|              |   | Byte0[7:0]=0x3                                                          |                                | Byte3[2]=0x0               | 7                                            |
|              |   | Start of the range                                                      |                                | NMIPass                    |                                              |
|              |   |                                                                         |                                | Byte3[1]=0x0               | 7                                            |
|              |   | Byte0[7:0]=0x4                                                          |                                | EIntPass                   |                                              |
|              |   | End of the range                                                        |                                | Byte3[0]=0x0               | -                                            |
|              |   |                                                                         |                                |                            |                                              |

#### Table 8-13 IVHD Devices Entries

| ASIC Rev     | Step | Field Settings                                            |                              |                | Function/Comment          |
|--------------|------|-----------------------------------------------------------|------------------------------|----------------|---------------------------|
| SR5690/5670/ | 4    | Use 8-byte entry of Type 0x42 (Alias Select) to describe: |                              |                | Device/s behind PCI       |
| 5650         |      | 1. Single device behind PCI brid                          | -                            |                | bridge/s;                 |
| All Revs     |      | 2. Single device behind a PCI-X                           | bridge operating in PCI mod  | de.            | Device/s behind a PCI-X   |
|              |      |                                                           |                              |                | bridge/s operating in PCI |
|              |      | Or use Type 0x43 (Alias Start o                           | f the Range) to describe:    |                | mode IVHD Entries.        |
|              |      | 1. Range of devices behind PC                             | •                            |                |                           |
|              |      | 2. Range of devices behind a P                            | CI-X bridge operating in PCI | -X mode.       |                           |
|              |      | Byte0=Select                                              | Byte1 & Byte2                | Byte3=Data     |                           |
|              |      | For:                                                      | DeviceID (Bus, Device,       | Byte3[7]=0x0   |                           |
|              |      | 1.Single device behind PCI                                | Function) from PCI           | Lint1Pass      |                           |
|              |      | bridge;                                                   | Configuration Topology.      | Byte3[6]=0x0   | 1                         |
|              |      | 2. Single device behind a PCI-X                           |                              | Lint0Pass      |                           |
|              |      | bridge operating in PCI mode:                             |                              | Byte3[5:4]=0x0 | 1                         |
|              |      |                                                           |                              | SysMgt         |                           |
|              |      | Byte0[7:0]=0x42                                           |                              | Byte3[3]=0x0   | 1                         |
|              |      |                                                           |                              | Reserved       |                           |
|              |      | For:                                                      |                              | Byte3[2]=0x0   | 1                         |
|              |      | 1.Range of devices behind PCI                             |                              | NMIPass        |                           |
|              |      | bridge;                                                   |                              | Byte3[1]=0x0   | 1                         |
|              |      | 2.Range of devices behind a                               |                              | EIntPass       |                           |
|              |      | PCI-X bridge operating in PCI                             |                              | Byte3[0]=0x0   | -                         |
|              |      | mode:                                                     |                              | INITPass       |                           |
|              |      | Pvto0[7:0]=0x42                                           |                              |                |                           |
|              |      | Byte0[7:0]=0x43<br>Start of the range                     |                              |                |                           |
|              |      | Start of the range                                        |                              |                |                           |
|              |      | NOTE: Range is terminated                                 |                              |                |                           |
|              |      | with entry of Type 4:                                     |                              |                |                           |
|              |      | Byte0[7:0]=0x4                                            |                              |                |                           |
|              |      | End of the range                                          |                              |                |                           |
|              |      | Byte4=Reserved                                            | Byte5 & Byte6                | Byte7=Reserved | -                         |
|              |      | Byte4[7:0]=0x0                                            | SourceID used by             | Byte7[7:0]=0x0 | 4                         |
|              |      |                                                           | peripheral.                  |                |                           |
|              |      |                                                           | For all PCI-X and PCI        |                |                           |
|              |      |                                                           | devices: Bus = bridge        |                |                           |
|              |      |                                                           | secondary bus number (i.e.,  |                |                           |
|              |      |                                                           | PCI-X/PCI bus),              |                |                           |
|              |      |                                                           | Device=0x0, Function=0x0.    |                |                           |

| ASIC Rev                      | Step                                                                             | Field Settings                                                                                                                                                                                             |                                                                                                            |                                                                                                                                                                 | Function/Comment   |
|-------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| SR5690/5670/<br>5650 All Revs | Use objective only of Type 0x+2 (Alias Ocicel) to describe a single device berni |                                                                                                                                                                                                            |                                                                                                            |                                                                                                                                                                 | Secondary PCI bus. |
|                               |                                                                                  | Byte0=Select                                                                                                                                                                                               | Byte1 & Byte2                                                                                              | Byte3=Data                                                                                                                                                      |                    |
|                               |                                                                                  | For:<br>Single device behind SB<br>Secondary PCI Bus.<br>Byte0[7:0]=0x42<br>For:<br>Range of devices behind SB<br>Secondary PCI Bus.<br>Byte0[7:0]=0x43<br>Start of the range<br>NOTE: Range is terminated | DeviceID (Bus, Device,<br>Function) from PCI<br>Configuration Topology.                                    | Byte3[7]= 0x0<br>Lint1Pass<br>Byte3[6]= 0x0<br>Lint0Pass<br>Byte3[5:4]= 0x0<br>SysMgt<br>Byte3[3]= 0x0<br>Reserved<br>Byte3[2]= 0x0<br>NMIPass<br>Byte3[1]= 0x0 |                    |
|                               |                                                                                  | with entry of Type 4:<br>Byte0[7:0]=0x4<br>End of the range<br>Byte4=Reserved                                                                                                                              | Byte5 & Byte6                                                                                              | EIntPass<br>Byte3[0]= 0x0<br>INITPass<br>Byte7=Reserved                                                                                                         |                    |
|                               |                                                                                  | Byte4[7:0]=0x0                                                                                                                                                                                             | SourceID used by<br>peripheral.<br>Bus = 0x0, Device=0x14,<br>Function from PCI<br>Configuration Topology. | Byte7[7:0]= 0x0                                                                                                                                                 |                    |

| ASIC Rev     | Step |                          | Field Settings                |                             | Function/Comment        |  |  |
|--------------|------|--------------------------|-------------------------------|-----------------------------|-------------------------|--|--|
| SR5690/5670/ | 6    | Use 8-byte entry of type | 0x48 in order to describe IOA | PIC (one for NB and one for | for NB IOAPIC, SB IOAPI |  |  |
| 5650         |      | SB) as a special device  | IVHD Entry.                   |                             |                         |  |  |
| All Revs     |      | Byte0=Select             | Byte1 & Byte2                 | Byte3=Data                  |                         |  |  |
|              |      | Byte0[7:0]=0x48          | 0x0                           | NB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[7]=0x0                |                         |  |  |
|              |      |                          |                               | Lint1Pass                   |                         |  |  |
|              |      |                          |                               |                             |                         |  |  |
|              |      |                          |                               | SB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[7]=0x1                |                         |  |  |
|              |      |                          |                               | Lint1Pass                   |                         |  |  |
|              |      |                          |                               | NB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[6]=0x0                |                         |  |  |
|              |      |                          |                               | Lint0Pass                   |                         |  |  |
|              |      |                          |                               |                             |                         |  |  |
|              |      |                          |                               | SB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[6]=0x1                |                         |  |  |
|              |      |                          |                               | Lint0Pass                   |                         |  |  |
|              |      |                          |                               | NB IOAPIC:                  | -                       |  |  |
|              |      |                          |                               | Byte3[5:4]= 0x0             |                         |  |  |
|              |      |                          |                               | SysMgt                      |                         |  |  |
|              |      |                          |                               | Sysingt                     |                         |  |  |
|              |      |                          |                               | SB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[5:4]= 0x1             |                         |  |  |
|              |      |                          |                               | SysMgt                      |                         |  |  |
|              |      |                          |                               | Byte3[3]= 0x0               |                         |  |  |
|              |      |                          |                               | Reserved                    |                         |  |  |
|              |      |                          |                               | NB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[2]= 0x0               |                         |  |  |
|              |      |                          |                               | NMIPass                     |                         |  |  |
|              |      |                          |                               | SB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[2]= 0x1               |                         |  |  |
|              |      |                          |                               | NMIPass                     |                         |  |  |
|              |      |                          |                               | NB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[1]= 0x0               |                         |  |  |
|              |      |                          |                               | EIntPass                    |                         |  |  |
|              |      |                          |                               | SB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[1]= 0x1               |                         |  |  |
|              |      |                          |                               | EIntPass                    |                         |  |  |
|              |      |                          |                               | NB IOAPIC:                  | 4                       |  |  |
|              |      |                          |                               |                             |                         |  |  |
|              |      |                          |                               | Byte3[0]= 0x0<br>INITPass   |                         |  |  |
|              |      |                          |                               |                             |                         |  |  |
|              |      |                          |                               | SB IOAPIC:                  |                         |  |  |
|              |      |                          |                               | Byte3[0]= 0x1               |                         |  |  |
|              |      |                          |                               | INITPass                    |                         |  |  |

| ASIC Rev     | ASIC Rev Step Field Settings |                                           |                                         | Function/Comment        |                  |
|--------------|------------------------------|-------------------------------------------|-----------------------------------------|-------------------------|------------------|
| SR5690/5670/ | 6                            | Byte4=Handle                              | Byte5 & Byte6                           | Byte7=Variety           |                  |
| 5650         | (cont'd)                     | The IO APIC ID from ACPI                  | NB IOAPIC DeviceID:                     | Byte7[7:0]= 0x1         |                  |
| All Revs     |                              | MADT.                                     | Primary NB Bus Number,                  |                         |                  |
|              |                              |                                           | Device =0x0, Function=                  |                         |                  |
|              |                              |                                           | 0x1.                                    |                         |                  |
|              |                              |                                           | SB IOAPIC DeviceID:                     |                         |                  |
|              |                              |                                           | Bus=0x0, Device=0x14,                   |                         |                  |
|              |                              |                                           | Function =0x0.                          |                         |                  |
| SR5690/5670/ | 7                            | Use 8-byte entry of Type 0x48             | in order to describe HPET a             | s a special device that | HPET IVHD Entry. |
| 5650         |                              | cannot be identified through enumeration. |                                         |                         |                  |
| All Revs     |                              | Byte0=Select                              | Byte1 & Byte2                           | Byte3=Data              |                  |
|              |                              | Byte0[7:0]=0x48                           | 0x0                                     | Byte3[7]= 0x1           |                  |
|              |                              |                                           |                                         | Lint1Pass               |                  |
|              |                              |                                           |                                         | Byte3[6]= 0x1           |                  |
|              |                              |                                           |                                         | Lint0Pass               |                  |
|              |                              |                                           |                                         | IByte3[5:4]= 0x1        |                  |
|              |                              |                                           |                                         | SysMgt                  |                  |
|              |                              |                                           |                                         | Byte3[3]=0x0            |                  |
|              |                              |                                           |                                         | Reserved                |                  |
|              |                              |                                           |                                         | Byte3[2]= 0x1           |                  |
|              |                              |                                           |                                         | NMIPass                 |                  |
|              |                              |                                           |                                         | Byte3[1]= 0x1           |                  |
|              |                              |                                           |                                         | EIntPass                |                  |
|              |                              |                                           |                                         | Byte3[0]= 0x1           |                  |
|              |                              |                                           |                                         | INITPass                |                  |
|              |                              | Byte4=Handle                              | Byte5 & Byte6                           | Byte7=Variety           |                  |
|              |                              | The HPET number from the HPET table.      | Bus=0x0, Device=0x14,<br>Function =0x0. | Byte7[7:0]=0x2          |                  |

#### 8.3.1.4 I/O Virtualization Memory Definition Block (IVMD)

Since there are no specific memory usage requirements to be communicated to the system software, SBIOS is not required to build IVMD tables.

# 8.4 Programming Requirements for OS and Hypervisor Developers

# 8.4.1 DTE Setup

When building device table entries, system software should avoid using DTE.V=0x1 and DTE.IV=0x0, or their combinations, in order to achieve optimal system performance.

| ASIC Rev    | Step | Field Settings                                                                                                                                             | Function/Comment                                                |
|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| SR5690/5670 | 1    | To achieve optimum system performance when building Device Table Entries for                                                                               | Device Table Entries for unity                                  |
| /5650       |      | unity mapping mode of operation, for devices which perform DMA requests,                                                                                   | mapping mode of operation for                                   |
| All Revs    |      | program the following Device Table Entry fields as follows:                                                                                                | devices which perform DMA                                       |
|             |      | DTE[127:0]=128'h 0000 0000 0000 0000 6000 0000 0000 00                                                                                                     | requests.                                                       |
|             | 2    | To achieve optimum system performance when building Device Table Entries for                                                                               | Device Table Entries for unity                                  |
|             |      | unity mapping mode of operation, for devices which perform interrupt requests,                                                                             | mapping mode of operation for                                   |
|             |      | program the following Device Table Entry fields as follows:                                                                                                | devices which perform interrupt                                 |
|             |      | DTE[256:128]=128'h 0000 0000 0000 0000 1000 0000 0000 00                                                                                                   | requests.                                                       |
|             | 3    | For security reasons when building Device Table Entries for devices which do                                                                               | Device Table Entries for devices                                |
|             |      | not perform DMA requests, set the Device Table Entry with DTE[0]=0x1 and                                                                                   | which do not perform DMA                                        |
|             |      | DTE[127:1]=0x0                                                                                                                                             | requests.                                                       |
|             | -    | For security reasons when building Device Table Entries for devices which do not perform interrupt requests set the Device table Entry with DTE[128]=1 and | Device Table Entries for devices which do not perform interrupt |
|             |      | DTE[255:129] = 0x0.                                                                                                                                        | requests.                                                       |

## 8.4.2 Register Programming

#### Table 8-15 Register Programming Requirements

| ASIC Rev     | Register Setting              | Function/Comment                                                 |
|--------------|-------------------------------|------------------------------------------------------------------|
| SR5690/5670/ | When ComBase is written to:   | Reset command buffer tail and head pointers when command buffer  |
| 5650         | Set CmdHeadPtr to 0x0         | base address register is written to.                             |
| All Revs     | Set CmdTailPtr to 0x0         |                                                                  |
|              | When EventBase is written to: | Reset event buffer tail and head pointers when event buffer base |
|              | Set EventHeadPtr to 0x0       | address register is written to.                                  |
|              | Set EventTailPtr to 0x0       |                                                                  |

#### Rev 3.05 (August 2012)

- PDF: 43872\_sr56xx\_rpr\_pub\_3.05
- Added new Section 2.10, "Erratum 81 Programming", on page 2-7.
- Updated Table 7-41, "Registers for RAS Programming Workarounds", on page 7-26

## Rev 3.04 (May 2012)

- PDF: 43872\_sr56xx\_rpr\_pub\_3.04
- Added step 23 to Table 4-36, "PCIe Cores Common Initialization", on page 4-38.

## **Rev 3.03 (February 2012)**

- PDF: 43872 sr56xx rpr pub 3.03
- In Figure 7-2 "Fatal Error Conditions Used to Drive SERR\_FATAL#" on page 7-3 and Figure 7-3 "Non-fatal Error Conditions Used to Drive NON\_FATAL\_CORR#" on page 7-4, changed "HT Retry Error" and "HT Overflow Error" to "Per-Packet CRC error" and "Flow-control buffer overflow" respectively. Also added a note to "Other HT errors..." to refer to Tables 7-12 and 7-13 for error status and error severity settings.

## **Rev 3.02 (November 2011)**

- PDF: 43872\_sr56xx\_rpr\_pub\_3.02
- Added new Step 18.1 to Section 4.4.5, "Static PCIe® Port Power Down Control", on page 4-64.
- Updated Table 4-50, "PCIE-GPP1 Port 0 (Device 2) Power Down Control Programming Sequence", on page 4-64.
- Updated Table 4-52, "PCIE-GPP2 Port 0 (Device 11) Power Down Control Programming Sequence", on page 4-66.
- Updated Table 4-62, "PCIE-GPP3b Power Down Control", on page 4-73.
- Updated Table 4-68, "Turning off TXCLK and LCLK", on page 4-77.

# Rev 3.01 (August 2011)

- PDF: 43872\_sr56xx\_rpr\_pub\_3.01
- Added examples of "other enabled HT fatal errors" to *Figure 7-2 "Fatal Error Conditions Used to Drive SERR\_FATAL#" on page 7-3.*
- Added examples of "other enabled HT non-fatal errors" to *Figure 7-3 "Non-fatal Error Conditions Used to Drive NON FATAL CORR#" on page 7-4.*

# **Rev 3.00 (December 2010)**

- PDF: 43872\_sr56xx\_rpr\_pub\_3.00
- Re-issued as a public version.

#### **Rev 2.03 (November 2010)**

- General edits.
- Fixed typo in Section 4.3, "Architecture and Configuration Topology", on page 4-1, where SR5650 should support 22 instead of 24 lanes.
- Updated Section 7.3.5.2, "PCIe® End-to-End CRC (ECRC)", on page 7-19.

# Rev 2.02 (April 2010)

- PDF: 43872\_sr56xx\_rpr\_nda\_2.02
- Removed bullet "Turn off PLL in L1/L23 for PCIE\_SB core" from Step 26 in Section 4.4.7, "Optional Features" on

page 4-79, and added text that the PLL for the PCIE\_SB core should not be turned off in L1.

• Updated Table 5-23, "Register Settings for HT1 and HT3 Inactive Lane State", on page 5-11 in adding a step to set PHY\_OFF for 8-bit links and not follow the processor.

# Rev 2.01 (March 2010)

- PDF: 43872\_sr56xx\_rpr\_nda\_2.01
- Reorganized and updated previous sections 2.8 and 2.9. The previous section 2.8.3 "Reporting UR for Unsupported Message Codes over the Advanced Error Reporting (AER) Interface" becomes *Section 2.9.3, "Prevent Spurious UR of DMA Requests", on page 2-7.*
- Added Section 5.5.8.4, "Generalized Stutter Mode", on page 5-11.
- Updated Table 5-23, "Register Settings for HT1 and HT3 Inactive Lane State", on page 5-11.
- Below heading of Section 7.3.1, "Sideband Pin Configuration" on page 7-1, clarified that the sideband signal control diagrams only extend from the error status registers to the pins; indicated that additional controls affect the chipset's ability to set the error status registers.
- Updated Figure 7-1 "System Error Conditions Used to Drive SERR\_FATAL#" on page 7-2 to Figure 7-4 "Correctable Error Conditions Used to Drive NON\_FATAL\_CORR#" on page 7-5.
- Under the heading of *Section 7.3.1.5, "NMI# Pin", on page 7-6*, updated the second paragraph to clarify the NMI# pin usage.
- Under the heading of *Section 7.3.2.1, "HyperTransport Syncflood on Errors", on page 7-6*, added a sentence to the first paragraphy to clarify that SERR events associated with the NBCONFIG space will result in a Hypertransport syncflood.
- In Table 7-6, "Register Settings to Enable NMI# Pin", on page 7-6, for NBMISCIND x12 [31:24], added that this register should be set to the APIC ID of core 0.
- In Table 7-8, "Registers to Configure HyperTransport Syncflood on HyperTransport Errors", on page 7-7, fixed typo where NBCONFIG x D0 [1] should have been NBCONFIG x C8 [1] instead.
- Moved last two rows in Table 7-8, "Registers to Configure HyperTransport Syncflood on HyperTransport Errors", on page 7-7 to Table 7-9, "Registers to Configure HyperTransport Syncflood On Internal Parity Errors", on page 7-7.
- Under heading of Section 7.3.5, "PCIe® RAS Feature Configuration" on page 7-17, added a new paragraph to warn that only registers in active cores/ports should be accessed, and that the SB core does not support link level error reporting. Also subsequently, where applicable, emphasized that registers must be programmed for **enabled** cores/ports only.
- Under Section 7.3.5.1, "PCIe® Advanced Error Reporting (AER) Capabilities" on page 7-17, added additional text to indicate that the registers not only enable AER but also enable the chipset to properly detect and log PCIe errors. Also updated sequence for SBIOS-enabled error reporting.
- In Table 7-25, "Registers for Exposing PCIe® AER Capabilities", on page 7-18, updated description for PCIEIND x 6A [0], and added setting for PCIEIND x 10 [22:21].
- Added new Section 7.3.5.10, "Data Poisoning" on page 7-26 indicating that error status will be logged in the PCIe bridges rather than in nbconfig space.
- In Table 7-30, "Recommended ACS Settings", on page 7-21, added register location and bit numbers.
- In Table 7-41, "Registers for RAS Programming Workarounds", on page 7-26, clarified which registers are to be set and which to be cleared.

# Rev 2.00 (June 2009)

- PDF: 43872\_sr56xx\_rpr\_nda\_2.00
- Added SR5650 variant to the document.
- Updated Section 2.4.1, "S3 PME\_Turn\_Off/PME\_To\_Ack Sequence", on page 2-2.
- Added new Section 2.4.12, "Advanced Error Reporting (AER) Support", on page 2-4.
- Added new Section 2.9.1, "Forwarding of Host Non-Posted Write Completion Status", on page 2-7.
- Added new Section 2.9.2, "Increase Downstream Message Priority", on page 2-7
- Added new Section 2.8.3, "Reporting UR for Unsupported Message Codes over the Advanced Error Reporting (AER) Interface", on page 2-7.
- Added new Section 2.9, "Messaging Features (A21 only)", on page 2-7.
- Completely overhauled the entire Chapter 4: PCIe Initialization. [Note: Due to the extent of changes, it was decided not to highlight the changes in red in this chapter for this round of update.]

- Minor clarifications to Section 5.1, "HyperTransportTM Link Initialization", on page 5-1
- Minor clarifications to Section 5.2, "HTIU Indirect Register Space", on page 5-1
- In Section 5.3.3, "Link Dependent Registers", on page 5-1, changed four HT links to multiple HT links.
- Updated Table 5-2, "Enabling High-Speed HT1 Modes", on page 5-2
- Added new settings to Table 5-6, "HT General Register Settings", on page 5-4 including entries for A12.
- Updated Section 5.5.3, "Extended Address Support", on page 5-6 for minor clarification.
- Split up section 5.5.5 into several sub-sections, with added explanations and information.
- Changed heading title of Section 5.5.6 from "HyperTransport 3 Protocol Checker" to "HyperTransport Protocol Checker" and made corresponding changes to the section.
- Removed Table 5-27 Transmitter BIAS Control.
- Add Section 6.4.2, "Interrupt Swizzling by the Processor in a Multi-NB Environment", on page 6-15.
- Updated Section 7.1, "Overview", on page 7-1.
- Updated Figures 7-1 to 7-4.
- Updated Section 7.3.1.5, "NMI# Pin", on page 7-6: Added extra capability for ASIC rev A21.
- Updated Table 7-6, "Register Settings to Enable NMI# Pin", on page 7-6: Added two entries related to the new capability of A21.
- Split up the original Table 7-7, "Registers to Configure HyperTransport Syncflood", on page 7-6 into 5 separable tables depending on type of error (Table 7-9 to 7-13).
- Updated Table 7-12, "Registers to Probe for HT Error Conditions", on page 7-8: Added a note regarding the error status for Fatal and Non-Fatal error types after a warm reset.
- Updated Table 7-13, "Hypertranport Error Classification", on page 7-9 with additional settings.
- Updated Table 7-14, "Recommended HyperTransport Error Classification", on page 7-9.
- Updated Table 7-15, "HyperTransport Error Interrupt Types", on page 7-10.
- Updated Table 7-19, "Registers to Probe for HT Error Conditions", on page 7-12 with a note regarding warm reset for some settings.
- Updated Section 7.3.4.6, "Software Error Injection Facilities for Internal Parity Errors", on page 7-15: Added additional sentence to Step 4.
- Updated the entire Section 7.3.5, "PCIe® RAS Feature Configuration", on page 7-17, including the addition of new algorithms and the removal of "Recommended AER Severity Settings".
- Added Section 7.3.5.11, "RAS Programming Workarounds", on page 7-26.
- Added Section 7.3.5.12, "Masked Memory Initialization (for A21)", on page 7-26
- Updated Section 7.4, "Platform Level Error Handling", on page 7-27.
- Removed the section on "Firmware-First Fatal Error and OS-First Non-Fatal Error Support"
- Updated Section 7.4.3, "System Halt on Error" on page 7-30.
- In Table 8-1, "IOMMU L1 Indexed Register", on page 8-1, replaced (IOMMU\_L1, IOMMU\_L2) with NBCONFIGFUNC2.
- Updated Table 8-5, "IOMMU Initialization", on page 8-2.
- Updated Table 8-6, "IOMMU L1 Initialization", on page 8-3.
- Updated Table 8-7, "Enabling Phantom Function Support", on page 8-3: Separated step 3 for A11 and A21.
- Added new Section 8.2.1.2, "Enabling PCIe® to PCI-X Bridge Support", on page 8-4.
- Updated Table 8-9, "IOMMU L2 Initialization", on page 8-5: Added new steps for ASIC Rev A21
- Modified heading title of Section 8.2.2.2 to "Optimizing IOMMU L2 Caches Performance Based on the Number of Functions/Devices/Buses in Use", on page 8-8.
- Updated Table 8-10, "Programming Sequence of L2 Caches Hash Control", on page 8-8.
- Updated Table 8-13, "IVHD Devices Entries", on page 8-14: changed Entry Types naming format (e.g. from Type 2 to Type 0x2) and added a new step (5) for entries of Type 0x42 and Type 0x43.
- Updated Section 8.4, "Programming Requirements for OS and Hypervisor Developers", on page 8-19.

# Rev 1.00 (October, 2008)

- PDF: 43872\_sr56xx\_rpr\_nda\_1.00
- First release.