5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

For MSI-X, a Function is permitted to cache Address and Data values from unmasked MSI-X Table entries. However, anytime software unmasks a currently masked MSI-X Table entry either by Clearing its Mask bit or by Clearing the Function Mask bit, the Function must update any Address or Data values that it cached from that entry. If software changes the Address or Data value of an entry while the entry is unmasked, the result is undefined.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAEwCAYAAACKUTD/AAAARElEQVRoge3KoQEAIAzAsI0nsZyG5cphsPOI1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA+B9cJawFYPdiYG8AAAAASUVORK5CYII=)

**IMPLEMENTATION NOTE**

Per Vector Masking with MSI/MSI-X

Devices and drivers that use MSI or MSI-X have the challenge of coordinating exactly when new interrupt

messages are generated. If hardware fails to send an interrupt message that software expects, an interrupt event might be “lost” If hardware sends an interrupt message that software is not expecting, a “spurious” interrupt

might result.

Per-Vector Masking (PVM) can be used to assist in this coordination. For example, when a software interrupt service routine begins, it can mask the vector to help avoid “spurious” interrupts. After the interrupt service routine services all the interrupt conditions that it is aware of, it can unmask the vector. If any interrupt

conditions remain, hardware is required to generate a new interrupt message, guaranteeing that no interrupt events are lost.

PVM is a standard feature with MSI-X and an optional88 feature for MSI. For devices that implement MSI, implementing PVM as well is highly recommended.

[**6.1.4.6**](6.1.4.6) **Hardware/Software Synchronization**

If a Functionsends messages with the same vector multiple times before being acknowledged by software, only one

message is guaranteed to be serviced. If all messages must be serviced, a device driver handshake is required. In other words, once a Functionsends Vector A, it cannot send Vector A again until it is explicitly enabled to do so by its device

driver (provided all messages must be serviced). If some messages can be lost, a device driver handshake is not required. For Functions that support multiple vectors, a Function can send multiple unique vectors and is guaranteed that each

unique message will be serviced. For example, a Function can send Vector A followed by Vector B without any device driver handshake (both Vector A and Vector B will be serviced).

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

88. Exception: Within an SR-IOV Device, any PFs or VFs that implement MSI must implement MSI PVM

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAANkCAYAAACK0Ws3AAAAfklEQVR4nO3MsQ0AIAwDwYQlaRmNlinDBCg10rn9kyOaZaxTz7pnju4BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAL4AF0ADCcbZdgiWAAAAAElFTkSuQmCC)

**IMPLEMENTATION NOTE**

Servicing MSI and MSI-X Interrupts

When system software allocates fewer MSI or MSI-X vectors to a Function than it requests, multiple interrupt

sources within the Function, each desiring a unique vector, may be required to share a single vector. Without

proper handshakes between hardware and software, hardware may send fewer messages than software expects, or hardware may send what software considers to be extraneous messages.

A rather sophisticated but resource-intensive approach is to associate a dedicated event queue with each

allocated vector, with producer and consumer pointers for managing each event queue. Such event queues

typically reside in host memory. The Function acts as the producer and software acts as the consumer. Multiple interrupt sources within a Function may be assigned to each event queue as necessary. Each time an interrupt

source needs to signal an interrupt, the Function places an entry on the appropriate event queue (assuming

there’s room), updates a copy of the producer pointer (typically in host memory), and sends an interrupt message with the associated vector when necessary to notify software that the event queue needs servicing. The interrupt service routine for a given event queue processes all entries it finds on its event queue, as indicated by the

producer pointer. Each event queue entry identifies the interrupt source and possibly additional information about the nature of the event. The use of event queues and producer/consumer pointers can be used to

guarantee that interrupt events won't get dropped when multiple interrupt sources are forced to share a vector. There's no need for additional handshaking between sending multiple messages associated with the same event queue, to guarantee that every message gets serviced. In fact, various standard techniques for “interrupt

coalescing” can be used to avoid sending a separate message for every event that occurs, particularly during heavy bursts of events.

In more modest implementations, the hardware design of a Function’s MSI or MSI-X logic sends a message any time a transition to assertion would have occurred on the virtual INTx wire if MSI or MSI-X had not been enabled. For example, consider a scenario in which two interrupt events (possibly from distinct interrupt sources within a Function) occur in rapid succession. The first event causes a message to be sent. Before the interrupt service

routine has had an opportunity to service the first event, the second event occurs. In this case, only one message is sent, because the first event is still active at the time the second event occurs (a virtual INTx wire signal would have had only one transition to assertion).

One handshake approach for implementations like the above is to use standard Per-Vector Masking, and allow

multiple interrupt sources to be associated with each vector. A given vector’s interrupt service routine Sets the

vector’s Mask bit before it services any associated interrupting events and Clears the Mask bit after it has serviced all the events it knows about. (This could be any number of events.) Any occurrence of a new event while the

Mask bit is Set results in the Pending bit being Set. If one or more associated events are still pending at the time the vector’s Mask bit is Cleared, the Function immediately sends another message.

A handshake approach for MSI Functions that do not implement Per-Vector Masking is for a vector’s interrupt

service routine to re-inspect all of the associated interrupt events after Clearing what is presumed to be the last pending interrupt event. If another event is found to be active, it is serviced in the same interrupt service routine invocation, and the complete re-inspection is repeated until no pending events are found. This ensures that if an additional interrupting event occurs before a previous interrupt event is Cleared, whereby the Function does not send an additional interrupt message, that the new event is serviced as part of the current interrupt service

routine invocation.

This alternative has the potential side effect of one vector’s interrupt service routine processing an interrupting event that has already generated a new interrupt message. The interrupt service routine invocation resulting from the new message may find no pending interrupt events. Such occurrences are sometimes referred to as spurious interrupts, and software using this approach must be prepared to tolerate them.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

An MSI or MSI-X message, by virtue of being a Posted Request, is prohibited by transaction ordering rules from passing Posted Requests sent earlier by the Function. The system must guarantee that an interrupt service routine invoked as a result of a given message will observe any updates performed by Posted Requests arriving prior to that message. Thus, the interrupt service routine of a device driver is not required to read from a device register in order to ensure data

consistency with previous Posted Requests. However, if multiple MSI-X Table entries share the same vector, the interrupt

service routine may need to read from some device specific register to determine which interrupt sources need servicing.

[**6.1.4.7**](6.1.4.7) **Message Transaction Reception and Ordering Requirements**

As with all Memory Write transactions, the device that includes the target of the interrupt message (the interrupt

receiver) is required to complete all interrupt message transactions as a Completer without requiring other transactions to complete first as a Requester. In general, this means that the message receiver must complete the interrupt message transaction independent of when the CPU services the interrupt. For example, each time the interrupt receiver receives an interrupt message, it could Set a bit in an internal register indicating that this message had been received and then complete the transaction on the bus. The appropriate interrupt service routine would later be dispatched because this bit was Set. The message receiver would not be allowed to delay the completion of the interrupt message on the bus

pending acknowledgement from the processor that the interrupt was being serviced. Such dependencies can lead to deadlock when multiple devices send interrupt messages simultaneously.

Although interrupt messages remain strictly ordered throughout the PCI Express Hierarchy, the order of receipt of the

interrupt messages does not guarantee any order in which the interrupts will be serviced. Since the message receiver

must complete all interrupt message transactions without regard to when the interrupt was actually serviced, the

message receiver will generally not maintain any information about the order in which the interrupts were received. This is true both of interrupt messages received from different devices and multiple messages received from the same device. If a device requires one interrupt message to be serviced before another, the device must not send the second interrupt message until the first one has been serviced.

**6.1.5 PME Support**

PCI Express supports power management events from native PCI Express devices as well as PME-capable PCI devices. PME signaling is accomplished using an in-band Transaction Layer PME Message (PM\_PME) as described in Chapter 5 .

**6.1.6 Native PME Software Model**

PCI Express-aware software can enable a mode where the Root Complex signals PMEvia an interrupt. When configured for native PME support, a Root Port receives the PME Message and sets the PME Status bit in its Root Status register. If software has set the PME Interrupt Enable bit in the Root Control register to 1b, the Root Port then generates an

interrupt.

If the Root Port is enabled for level-triggered interrupt signaling using the INTx messages, the virtual INTx wire must be asserted whenever and as long as all of the following conditions are satisfied:

• The Interrupt Disable bit in the Command register is set to 0b.

• The PME Interrupt Enable bit in the Root Control register is set to 1b.

• The PME Status bit in the Root Status register is set.

Note that all other interrupt sources within the same Function will assert the same virtual INTx wire when requesting service.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

If the Root Port is enabled for edge-triggered interrupt signaling using MSI or MSI-X, an interrupt message must be sent everytime the logical AND of the following conditions transitions from FALSE to TRUE:

• The associated vector is unmasked (not applicable if MSI does not support PVM).

• The PME Interrupt Enable bit in the Root Control register is set to 1b.

• The PME Status bit in the Root Status register is set.

Note that PME and Hot-Plug Event interrupts (when both are implemented) always share the same MSI or MSI-X vector, as indicated by the Interrupt Message Number field in the PCI Express Capabilities register.

The software handler for this interrupt can determine which device sent the PME Message by reading the PME Requester ID field in the Root Status register in a Root Port. It dismisses the interrupt by writing a 1b to the PME Status bit in the

Root Status register. Refer toSection 7.5.3.14for more details.

Root Complex Event Collectors provide support for the above described functionality for Root Complex Integrated Endpoints (RCiEPs).

**6.1.7 Legacy PME Software Model**

Legacy software, however, will not understand this mechanism for signaling PME. In the presence of legacy system software, the system power management logic in the Root Complex receives the PME Message and informs system software through an implementation specific mechanism. The Root Complex may utilize the Requester ID in the PM\_PMEto inform system software which device caused the power management event.

Since it is delivered by a Message, PME has edge-triggered semantics in PCI Express, which differs from the

level-triggered PME mechanism used for conventional PCI. It is the responsibility of the Root Complex to abstract this difference from system software to maintain compatibility with conventional PCI systems.

**6.1.8 Operating System Power Management Notification**

In order to maintain compatibility with non-PCI Express-aware system software, system power management logic must be configured by firmware to use the legacy mechanism of signaling PME by default. PCI Express-aware system software must notify the firmware prior to enabling native, interrupt-based PME signaling. In response to this notification, system firmware must, if needed, reconfigure the Root Complex to disable legacy mechanisms of signaling PME. The details of this firmware notification are beyond the scope of this specification, but since it will be executed at system run-time, the response to this notification must not interfere with system software. Therefore, following control handoff to the

operating system, firmware must not write to available system memory or any PCI Express resources (e.g., Configuration Space structures) owned by the operating system.

**6.1.9 PME Routing Between PCI Express and PCI Hierarchies**

PME-capable conventional PCI and PCI-X devices assert the PME# pin to signal a power management event. The PME# signal from PCI or PCI-X devices may either be converted to a PCI Express in-band PME Message by a PCI Express-PCI Bridge or routed directly to the Root Complex.

If the PME# signal from a PCI or PCI-X device is routed directly to the Root Complex, it signals system software using the same mechanism used in present PCI systems. A Root Complex may optionally provide support for signaling PME from PCI or PCI-X devices to system software via an interrupt. In this scenario, it is recommended for the Root Complex to

detect the Bus, Device and Function Number of the PCI or PCI-X device that asserted PME#, and use this information to

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

fill in the PME Requester ID field in the Root Port that originated the hierarchy containing the PCI or PCI-X device. If this is not possible, the Root Complex may optionally write the Requester ID of the Root Port to this field.

Since RCiEPs are not contained in any of the hierarchy domains originated by Root Ports, RCiEPs not associated with a Root Complex Event Collector signal system software of a PME using the same mechanism used in present PCI systems. A Root Complex Event Collector, if implemented, enables the PCI Express Native PME model for associated RCiEPs.

**6.2 Error Signaling and Logging**

In this document, errors which must be checked and errors which may optionally be checked are identified. Each such error is associated either with the Port or with a specific device (or Function in a Multi-Function Device), and this

association is given along with the description of the error. This section will discuss how errors are classified and reported.

**6.2.1 Scope**

This section explains the error signaling and logging requirements for PCI Express components. This includes errors

which occur on the PCI Express interface itself, those errors which occur on behalf of transactions initiated on PCI

Express, and errors which occur within a component and are related to the PCI Express interface. This section does not focus on errors which occur within the component that are unrelated to a PCI Express interface. This type of error

signaling is better handled through proprietary methods employing device-specific interrupts.

PCI Express defines two error reporting paradigms: the baseline capability and the Advanced Error Reporting Capability. The baseline error reporting capabilities are required of all PCI Express devices and define the minimum error reporting requirements. The Advanced Error Reporting Capability is defined for more robust error reporting and is implemented with a specific PCI Express Capability structure (refer toChapter 7for a definition of this optional capability). This section explicitly calls out all error handling differences between the baseline and the Advanced Error Reporting Capability.

All PCI Express devices support existing, non-PCI Express-aware, software for error handling by mapping PCI Express errors to existing PCI reporting mechanisms, in addition to the PCI Express-specific mechanisms.

**6.2.2 Error Classification**

PCI Express errors can be classified as two types: Uncorrectable errors and Correctable errors. This classification

separates those errors resulting in functional failure from those errors resulting in degraded performance. Uncorrectable errors can further be classified as Fatal or Non-Fatal (see [Figure 6-1)](#bookmark2).

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAABWCAYAAADYOyajAAABVklEQVRoge3ZPUoDQRyG8T+DQdKkUmzSptVWAnYqtuIFcgFtbAK5gDZ25gK5gB5Ae6231E47CxHRIjiPxbqIMR/7MbOCvE+9Oz/YhZeFNasQ0Khyf1l0FxjWjTaBe8AD3TrhU75LannkwAYw5meD2KgDbvndO9CJCR9NQbOuY6Ft4GUODNCLAV8uQAGegNWQ6EEONGsUCm0BjwVggJ0Q8LAgCum4NKugXdJ1KtNJWbRBukplGwPrZeBBBTTrBnBF0A7pGoXosAh8FQiFdHTaedBeQDTrYhG6Qro+MdqfB48ioQAPQGsauh0RzTqfRJvAXQ3wB7BpZrb0ZR+b2ZqZvU57Bd77Zedcrs8b7z1m9uacY8YlZ8BWnrOs3+9PfurMLEmSZzPbW3Rm/lUJnGDBggULFixYsGDBggULFixYsGDBggULFixYsGDBgv8fDLN+jFa79k/6BGhACnU5KbzEAAAAAElFTkSuQmCC)

ERR\_COR

![](data:image/png;base64,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)

Data Link Physical

Internal Transaction

Correctable Errors

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAABWCAYAAADYOyajAAABjUlEQVRoge3ZrUsDcRjA8ed0c6jBY7ggKJiWhDURFhYVLYKIySKsGgwLgv+AQ6yiVaMIBjFNrDaDVQyKAxmGCQrn7WuYh/hyd7tXy/Ot99zzCfeDXziRkAHZsO9GCjgBSmmjy3S7AvrTQk3gka820oL3+N4LMJk0WgY6/O48SXQAuPkDdVpNCt7yQAGegNG40SLw5gMDHMYNX/SAOs3Fha4FQAHugOGoaAFoBYQBdqPCRyFQABuYDovOhkSdrgl6kQBDwG1EGGAzKLwdAwrwChR7RUuAFRMMcAkYfmgf3asu7qp+8HoCKMAzMOaGTgDthGCAYzf4NEHUafEnupQCCvAAjIiIZCqVylSz2TwwTdNy+/a5XC5rGN4H08m27XfLsnB5XGg0GmciUjZEZFxEVjx2zbRarYV8Pj/YC1yv1zu1Wq3mMdIWkf2MiNyLyI7HYNUwjPle0M/w2SciIn0BFsaawgorrLDCCiussMIKK6ywwgorrLDCCiussMIKK6ywwgornBgMbj9Ho83+Sx86qvRV93E3iwAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB0AAACICAYAAAAbOOD/AAACNklEQVRoge3bP4sTURSH4TfLsmsjmuwG7URBN+Km0Moo/i1EhNtFEAujCLLfQBTE9C6sYgoFv8XBxkJsBLugQbDSUjYJRitDDInFJBrWTObOJMsW/k43c889z5wLh5lmYAcilWSTmS0AT4E151w/7v65JChwF7gD3E6yOXanZnYYqAGLQAvIOefqcWok6fTZAARIAxtxC8RCzewGcHHL7etmdilOHe/jNbMl4BOwPGb5M7DqnPvpUytOp+shIMAh4IFvIa9Ozewc8CYi7Rdw3Dn3cWp0MJMfgBWP53sLnImaXZ/jvecJApwmmN+JMbFTM1sB3vN3RHziO8HsboYlRHU6OpO+sRd4PCkhFDWzm8D5mOAwrpnZ5bDFscdrZssEM7mUEAX4AhwbN7thna5PCQIcBB6OW/inUzO7ALyeEhxGFzjhnKuFoma2SDCTR2aEArwDTo3O7tbjvT9jEOAksDZ640+nZpYjmMmFGaMAP4CjzrmvMOjUzFLA820CAfYAT4YXw+O9BZzdJnAYV83sCsBcsVhc7Xa7sd/+SaLT6bwoFAoHUvl8vpzJZEphidlsdlepVNrvW7hSqWy22+3Ql3mz2Xw0X6vVykA5LCmXy70CvNFqtfqyXq9P/EpM+gk6VQgVKlSoUKFChQoVKlSoUKFChQoVKlSoUKFChQoVKlSoUKFChQoVKlSoUKFChQoVKlSoUKFChf7P6HxUQq/Xq7Zard3pdPpbVG6j0djX7/cj/8rckfgNo/mFtdtniIYAAAAASUVORK5CYII=)

ERR\_NONFATAL ERR\_FATAL

|  |  |
| --- | --- |
| Data Link  Fa | Physical tal |
| Internal | Transaction |

![](data:image/png;base64,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)

Uncorrectable Errors

OM13827A

Figure 6-1 Error Classification

Classification of error severity as Fatal, Uncorrectable, and Correctable provides the platform with mechanisms for

mapping the error to a suitable handling mechanism. For example, the platform might choose to respond to correctable errors with low priority, performance monitoring software. Such software could count the frequency of correctable

errors and provide Link integrity information. On the other hand, a platform designer might choose to map Fatal errors to a system-wide reset. It is the decision of the platform designer to map these PCI Express severity levels onto platform level severities.

[**6.2.2.1**](6.2.2.1) **Correctable Errors**

Correctable errors include those error conditions where hardware can recover without any loss of information.

Hardware corrects these errors and software intervention is not required. For example, an LCRC error in a TLP that might be corrected by Data Link Level Retry is considered a correctable error. Measuring the frequency of Link-level correctable errors may be helpful for profiling the integrity of a Link.

Correctable errors also include transaction-level cases where one agent detects an error with a TLP, but another agent is responsible for taking any recovery action if needed, such as re-attempting the operation with a separate subsequent

transaction. The detecting agent can be configured to report the error as being correctable since the recovery agent may be able to correct it. If recovery action is indeed needed, the recovery agent must report the error as uncorrectable if the recovery agent decides not to attempt recovery.

The triggering of Downstream Port Containment (DPC) is not handled as an error, but it can be signaled as if it were a correctable error, since software that takes advantage of DPC can sometimes recover from the uncorrectable error that triggered DPC. See [Section 6.2.10](#bookmark4). An ERR\_COR Message that’s used for DPC signaling is intended to target system

firmware, and may indicate so via the ERR\_COR Subclassfield.

Similarly,ERR\_COR may be used by the System Firmware Intermediary (SFI) capability to signal system firmware, and must indicate so via the ERR\_COR Subclassfield. See [Section 6.7.4 .](#bookmark5)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[**6.2.2.2**](6.2.2.2) **Uncorrectable Errors**

Uncorrectable errors are those error conditions that impact functionality of the interface. There is no mechanism

defined in this specification to correct these errors. Reporting an uncorrectable error is analogous to asserting SERR# in PCI/PCI-X. For more robust error handling by the system, this specification further classifies uncorrectable errors as Fatal and Non-fatal.

**6.2.2.2.1 Fatal Errors**

Fatal errors are uncorrectable error conditions which render the particular Link and related hardware unreliable. For

Fatal errors, a reset of the components on the Link may be required to return to reliable operation. Platform handling of Fatal errors, and any efforts to limit the effects of these errors, is platform implementation specific.

**6.2.2.2.2 Non-Fatal Errors**

Non-fatal errors are uncorrectable errors which cause a particular transaction to be unreliable but the Link is otherwise fully functional. Isolating Non-fatal from Fatal errors provides Requester/Receiver logic in a device or system

management software the opportunity to recover from the error without resetting the components on the Link and disturbing other transactions in progress. Devices not associated with the transaction in error are not impacted by the error.

**6.2.3 Error Signaling**

There are three complementary mechanisms which allow the agent detecting an error to alert the system or another device that an error has occurred. The first mechanism is through a Completion Status, the second method is with in-band error Messages, and the third is with Error Forwarding (also known as data poisoning).

Note that it is the responsibility of the agent detecting the error to signal the error appropriately.

[Section 6.2.7](#bookmark9)describes all the errors and how the hardware is required to respond when the error is detected.

[**6.2.3.1**](6.2.3.1) **Completion Status**

The Completion Status field (when status is not Successful Completion) in the Completion header indicates that the

associated Request failed (seeSection 2.2.8.10). This is one method of error reporting which enables the Requester to associate an error with a specific Request. In other words, since Non-Posted Requests are not considered complete until after the Completion returns, the Completion Status field gives the Requester an opportunity to “fix” the problem at

some higher level protocol (outside the scope of this specification). For example, if a Read is issued to prefetchable

Memory Space and the Completion returns with an Unsupported Request Completion Status, the Requester would not be in violation of this specification if it chose to reissue the Read Request. Note that from a PCI Express point of view, the reissued Read Request is a distinct Request, and there is no relationship (on PCI Express) between the initial Request and the reissued Request.

[**6.2.3.2**](6.2.3.2) **Error Messages**

Error Messages are sent to the Root Complex for reporting the detection of errors according to the severity of the error.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Error messages that originate from PCI Express or Legacy Endpoints are sent to corresponding Root Ports. Errors that originate from a Root Port itself are reported through the same Root Port.

If an optional Root Complex Event Collectoris implemented, errors that originate from RCiEPsare sent to the

corresponding Root Complex Event Collector. Errors that originate in a Root Complex Event Collectoritself are reported through the same Root Complex Event Collector. The Root Complex Event Collectormust declare supportedRCiEPsas

part of its capabilities; each RCiEP must be associated with no more than one Root Complex Event Collector.

When multiple errors of the same severity are detected, the corresponding error Messages with the same Requester ID may be merged for different errors of the same severity. At least one error Message must be sent for detected errors of

each severity level. Note, however, that the detection of a given error in some cases will preclude the reporting of certain errors. Refer to[Section 6.2.3.2.3](#bookmark11). Also note special rules in[Section 6.2.4](#bookmark12)regarding non-Function-specific errors in

Multi-Function Devices.

Table 6-1 Error Messages

|  |  |
| --- | --- |
| Error Message | Description |
| ERR\_COR | This Message is issued when the Function or Device detects a correctable error on the PCI Express interface. Refer to[Section 6.2.2.1f](#bookmark3)or the definition of a correctable error. |
| ERR\_NONFATAL | This Message is issued when the Function or Device detects a Non-fatal, uncorrectable error on the PCI Express interface. Refer to[Section 6.2.2.2.2f](#bookmark8)or the definition of a Non-fatal, uncorrectable error. |
| ERR\_FATAL | This Message is issued when the Function or Device detects a Fatal, uncorrectable error on the PCI Express interface. Refer to[Section 6.2.2.2.1f](#bookmark7)or the definition of a Fatal, uncorrectable error. |

For these Messages, the Root Complex identifies the initiator of the Message by the Requester ID of the Message header. The Root Complex translates these error Messages into platform level events.

**IMPLEMENTATION NOTE**

Use of ERR\_COR, ERR\_NONFATAL, and ERR\_FATAL

In [PCIe-1.0] and [PCIe-1.0a], a given error was either correctable, non-fatal, or fatal. Assuming signaling was enabled, correctable errors were always signaled with ERR\_COR, non-fatal errors were always signaled with ERR\_NONFATAL, and fatal errors were always signaled with ERR\_FATAL.

In subsequent specifications that support Role-Based Error Reporting, non-fatal errors are sometimes signaled

with ERR\_NONFATAL, sometimes signaled with ERR\_COR, and sometimes not signaled at all, depending upon the role of the agent that detects the error and whether the agent implements AER (see [Section 6.2.3.2.4)](#bookmark13). On some platforms, sending ERR\_NONFATALwill preclude another agent from attempting recovery or determining the

ultimate disposition of the error. For cases where the detecting agent is not the appropriate agent to determine the ultimate disposition of the error, a detecting agent with AER can signal the non-fatal error withERR\_COR,

which serves as an advisory notification to software. For cases where the detecting agent is the appropriate one, the agent signals the non-fatal error withERR\_NONFATAL.

For a given uncorrectable error that’s normally non-fatal, if software wishes to avoid continued hierarchy operation upon the detection of that error, software can configure detecting agents that implement AER to escalate the severity of that error to fatal. A detecting agent (if enabled) will always signal a fatal error with ERR\_FATAL, regardless of the agent’s role.

Software should recognize that a single transaction can be signaled by multiple agents using different types of error Messages. For example, a poisoned TLP might be signaled by intermediate Receivers withERR\_COR, while the ultimate destination Receiver might signal it with ERR\_NONFATAL.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAGvCAYAAABmYZRpAAAAUUlEQVRoge3KoREAIAwAsZYlsYyGZcpisF2Ay9tPxjoVXXvmaOcLAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAL4HF1lsBl4gADjqAAAAAElFTkSuQmCC)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.2.3.2.1 Uncorrectable Error Severity Programming (Advanced Error Reporting)**

For device Functions implementing the Advanced Error Reporting Capability, the Uncorrectable Error Severity register allows each uncorrectable error to be programmed to Fatal or Non-Fatal. Uncorrectable errors are not recoverable using defined PCI Express mechanisms. However, some platforms or devices might consider a particular error fatal to a Link or device while another platform considers that error non-fatal. The default value of the Uncorrectable Error Severity

register serves as a starting point for this specification but the register can be reprogrammed if the device driver or platform software requires more robust error handling.

Baseline error handling does not support severity programming.

**6.2.3.2.2 Masking Individual Errors**

[Section 6.2.7](#bookmark15)lists all the errors governed by this specification and describes when each of the above error Messages are issued. The transmission of these error Messages by class (correctable, non-fatal, fatal) is enabled using the Reporting Enable bits of the Device Control register (seeSection 7.5.3.4) or the SERR# Enable bit in the PCI Command register (see Section 7.5.1.1.3).

For devices implementing the Advanced Error Reporting Capability the Uncorrectable Error Mask register and

Correctable Error Mask register allows each error condition to be masked independently. If Messages for a particular class of error are not enabled by the combined settings in the Device Control register and the PCI Command register, then no Messages of that class will be sent regardless of the values for the corresponding mask register.

If an individual error ismasked when it is detected, its error status bit is still affected, but no error reporting Message is sent to the Root Complex, and the error is not recorded in the Header Log,TLP Prefix Log, or First Error Pointer.

**6.2.3.2.3 Error Pollution**

Error pollution can occur if error conditions for a given transaction are not isolated to the most significant occurrence. For example, assume the Physical Layer detects a Receiver Error. This error is detected at the Physical Layer and an error is reported to the Root Complex. To avoid having this error propagate and cause subsequent errors at upper layers (for example, a TLP error at the Data Link Layer), making it more difficult to determine the root cause of the error,

subsequent errors which occur for the same packet will not be reported by the Data Link or Transaction layers. Similarly, when the Data Link Layer detects an error, subsequent errors which occur for the same packet will not be reported by

the Transaction Layer. This behavior applies only to errors that are associated with a particular packet - other errors are reported for each occurrence.

Corrected Internal Errors are errors whose effect has been masked or worked around by a component; refer to[Section](#bookmark17) [6.2.9 f](#bookmark18)or details. Therefore, Corrected Internal Errors do not contribute to error pollution and should be reported when detected.

For errors detected in the Transaction layer and Uncorrectable Internal Errors, it is permitted and recommended that no more than one error be reported for a single received TLP, and that the following precedence (from highest to lowest) be used:

• Uncorrectable Internal Error

• Receiver Overflow

• Malformed TLP

• ECRC Check Failed

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• AtomicOp Egress Blocked

• TLP Prefix Blocked

• ACS Violation

• [MC Blocked TLP](#bookmark19)

• Unsupported Request (UR),Completer Abort (CA), or Unexpected Completion

• Poisoned TLP Received or Poisoned TLP Egress Blocked

The Completion Timeout error is not in the above precedence list, since it is not detected by processing a received TLP. Errors listed under the same bullet are mutually exclusive, so their relative order does not matter.

**6.2.3.2.4 Advisory Non-Fatal Error Cases**

In some cases the detector of a non-fatal error is not the most appropriate agent to determine whether the error is recoverable or not, or if it even needs any recovery action at all. For example, if software attempts to perform a

configuration read from a non-existent device or Function, the resulting UR Status in the Completion will signal the error to software, and software does not need for the Completer in addition to signal the error by sending an ERR\_NONFATAL Message. In fact, on some platforms, signaling the error withERR\_NONFATAL results in a System Error, which breaks

normal software probing.

“Advisory Non-Fatal Error” cases are predominantly determined by the role of the detecting agent (Requester,

Completer, or Receiver) and the specific error. In such cases, an agent with AER signals the non-fatal error (if enabled) by sending an ERR\_COR Message as an advisory to software, instead of sending ERR\_NONFATAL. An agent without AER

sends no error Message for these cases, since software receiving ERR\_CORwould be unable to distinguish Advisory Non-Fatal Error cases from the correctable error cases used to assess Link integrity.

Following are the specific cases of Advisory Non-Fatal Errors. Note that multiple errors from the same or different error classes (correctable, non-fatal, fatal) may be present with a single TLP. For example, an unexpected Completion might

also be poisoned. Refer to[Section 6.2.3.2.3f](#bookmark16)or requirements and recommendations on reporting multiple errors. For the previous example, it is recommended that Unexpected Completion be reported, and that Poisoned TLP Received not be reported.

If software wishes for an agent with AER to handle what would normally be an Advisory Non-Fatal Error case as being more serious, software can escalate the severity of the uncorrectable error to fatal, in which case the agent (if enabled) will signal the error withERR\_FATAL.

This section covers Advisory Non-Fatal Error handling for errors managed by the PCI Express Extended Capability and

AER.[Section 6.2.10.3](#bookmark21)covers the RP PIO error handling mechanism for Root Ports that support RP Extensions for DPC. RP PIO advisory errors are similar in concept to AER Advisory Non-Fatal Errors, but apply to different error cases and are

managed by different controls.

**6.2.3.2.4.1 Completer Sending a Completion with UR/CA Status**

A Completer generally sends a Completion with an Unsupported Request or Completer Abort (UR/CA) Status to signal an uncorrectable error for a Non-Posted Request.89 If the severity of the UR/CA error90 is non-fatal, the Completer must

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

89. If the Completer is returning data in a Completion, and the data is bad or suspect, the Completer is permitted to signal the error using the Error Forwarding (Data Poisoning) mechanism instead of handling it as a UR or CA.

90. Certain other errors (e.g., ACS Violation) with a Non-Posted Request also result in the Completer sending a Completion with UR or CA Status. If the severity of the error (e.g., ACS Violation) is non-fatal, the Completer must also handle this case as an Advisory Non-Fatal Error. However, seeSection 2.7.2.2regarding certain Requests with Poisoned data that must be handled as uncorrectable errors.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

handle this case as an Advisory Non-Fatal Error.91 A Completer with AER signals the non-fatal error (if enabled) by sending an ERR\_COR Message. A Completer without AER sends no error Message for this case.

Even though there was an uncorrectable error for this specific transaction, the Completer must handle this case as an Advisory Non-Fatal Error, since the Requester upon receiving the Completion with UR/CA Status is responsible for

reporting the error (if necessary) using a Requester-specific mechanism (see [Section 6.2.3.2.5)](#bookmark23).

**6.2.3.2.4.2 Intermediate Receiver**

When a Receiver that’s not serving as the ultimate PCI Express destination for a TLP detects92 a non-fatal error with the TLP, this “intermediate” Receiver must handle this case as an Advisory Non-Fatal Error.93 A Receiver with AER signals the error (if enabled) by sending an ERR\_COR Message. A Receiver without AER sends no error Message for this case. An

exception to the intermediate Receiver case for Root Complexes (RCs) is noted below.

An example where the intermediate Receiver case occurs is a Switch that detects poison or bad ECRC in a TLP that it is routing. Even though this was an uncorrectable (but non-fatal) error at this point in the TLP’s route, the intermediate Receiver handles it as an Advisory Non-Fatal Error, so that the ultimate Receiver of the TLP (i.e., the Completer for a

Request TLP, or the Requester for a Completion TLP) is not precluded from handling the error more appropriately

according to its error settings. For example, a given Completer that detects poison in a Memory Write Request94 might have the error masked (and thus go unsignaled), whereas a different Completer in the same hierarchy might signal that error withERR\_NONFATAL.

A Poisoned TLP Egress Blocked error is never handled as an intermediate Receiver case since it is not detected as a part of processing a received TLP.

If an RC detects a non-fatal error with a TLP it normally would forward peer-to-peer between Root Ports, but the RC does not support propagating the error related information (e.g., a TLP Digest, EP bit, or equivalent) with the forwarded

transaction, the RC must signal the error (if enabled) with ERR\_NONFATALand also must not forward the transaction. An example is an RC needing to forward a poisoned TLP peer-to-peer between Root Ports, but the RC’s internal fabric does not support poison indication.

**6.2.3.2.4.3 Ultimate PCI Express Receiver of a Poisoned TLP**

When a poisoned TLP is received by its ultimate PCI Express destination, if the severity is non-fatal and the Receiver

deals with the poisoned data in a manner that permits continued operation, the Receiver must handle this case95 as an Advisory Non-Fatal Error.96 A Receiver with AER signals the error (if enabled) by sending an ERR\_COR Message. A Receiver without AER sends no error Message for this case. Refer toSection 2.7.2.2for special rules that apply for poisoned

Memory Write Requests.

An example is a Root Complex that receives a poisoned Memory Write TLP that targets host memory. If the Root Complex

propagates the poisoned data along with its indication to host memory, it signals the error (if enabled) with an

ERR\_COR. If the Root Complex does not propagate the poison to host memory, it signals the error (if enabled) with ERR\_NONFATAL.

Another example is a Requester that receives a poisoned Memory Read Completion TLP. If the Requester propagates the poisoned data internally or handles the error like it would for a Completion with UR/CA Status, it signals the error (if

enabled) with an ERR\_COR. If the Requester does not handle the poison in a manner that permits continued operation, it signals the error (if enabled) with ERR\_NONFATAL.

|  |  |
| --- | --- |
| 91. If the severity is fatal, the error is not an Advisory Non-Fatal Error, and must  92. If the Receiver does not implement ECRC Checking or ECRC Checking is not  93. If the severity is fatal, the error is not an Advisory Non-Fatal Error, and must | be signaled (if enabled) with ERR\_FATAL.  enabled, the Receiver will not detect an ECRC Error. be signaled (if enabled) with ERR\_FATAL. |
| 94. SeeSection 2.7.2.2for special rules that apply for poisoned Memory Write Requests. | |
| 95. However, seeSection 2.7.2.2 regarding certain Requests with Poisoned data that must be handled as uncorrectable errors. | |
| 96. If the severity is fatal, the error is not an Advisory Non-Fatal Error, and must be signaled (if enabled) with ERR\_FATAL. | |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.2.3.2.4.4 Requester with Completion Timeout**

This section applies to Requesters other than Root Ports performing programmed I/O (PIO). See [Section 6.2.10.3f](#bookmark26)or related RP PIO functionality in Root Ports that support RP Extensions for DPC.

When the Requester of a Non-Posted Request times out while waiting for the associated Completion, the Requester is permitted to attempt to recover from the error by issuing a separate subsequent Request. The Requester is permitted to attempt recovery zero, one, or multiple (finite) times, but must signal the error (if enabled) with an uncorrectable error Message if no further recovery attempt will be made.

If the severity of the Completion Timeout is non-fatal, and the Requester elects to attempt recovery by issuing a new

request, the Requester must first handle the current error case as an Advisory Non-Fatal Error.97 A Requester with AER signals the error (if enabled) by sending an ERR\_COR Message. A Requester without AER sends no error Message for this case.

Note that automatic recovery by the Requester from a Completion Timeout is generally possible only if the Non-Posted Request has no side-effects, but may also depend upon other considerations outside the scope of this specification.

**6.2.3.2.4.5 Receiver of an Unexpected Completion**

When a Receiver receives an unexpected Completion and the severity of the Unexpected Completion error is non-fatal, the Receiver must handle this case as an Advisory Non-Fatal Error.98 A Receiver with AER signals the error (if enabled) by sending an ERR\_COR Message. A Receiver without AER sends no error Message for this case.

If the unexpected Completion was a result of misrouting, the Completion Timeout mechanism at the associated

Requester will trigger eventually, and the Requester may elect to attempt recovery. Interference with Requester recovery can be avoided by having the Receiver of the unexpected Completion handle the error as an Advisory Non-Fatal Error.

**6.2.3.2.5 Requester Receiving a Completion with UR/CA Status**

When a Requester receives back a Completion with a UR/CA Status, generally the Completer has handled the error as an Advisory Non-Fatal Error, assuming the error severity was non-fatal at the Completer (see[Section 6.2.3.2.4.1)](#bookmark22). The

Requester must determine if any error recovery action is necessary, what type of recovery action to take, and whether or not to report the error.

If the Requester needs to report the error, the Requester must do so solely through a Requester-specific mechanism. For example, many devices have an associated device driver that can report errors to software. As another important

example,the Root Complex on some platforms returns all 1’s to software if a Configuration Read Completion has a UR/ CA Status.

[Section 6.2.10.3](#bookmark28)covers RP PIO controls for Root Ports that support RP Extensions for DPC. Outside of the RP PIO

mechanisms, Requesters are not permitted to report the error using PCI Express logging and error Message signaling.

[**6.2.3.3**](6.2.3.3) **Error Forwarding (Data Poisoning)**

Error Forwarding, also known as data poisoning, is indicated by setting the EP bit in a TLP. Refer toSection 2.7.2 . This is another method of error reporting in PCI Express that enables the Receiver of a TLP to associate an error with a specific

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

97. If the severity is fatal, the error is not an Advisory Non-Fatal Error, and must be signaled (if enabled) withERR\_FATAL. The Requester is strongly discouraged from attempting recovery since sending ERR\_FATALwill often result in the entire hierarchy going down.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)98. If the severity is fatal, the error is not an Advisory Non-Fatal Error, and must be signaled (if enabled) with ERR\_FATAL.

Page 512

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Request or Completion. Unlike the Completion Status mechanism, Error Forwarding can be used with either Requests or Completions that contain data. In addition, “intermediate” Receivers along the TLP’s route, not just the Receiver at the ultimate destination, are required to detect and report (if enabled) receiving the poisoned TLP. This can help software

determine if a particular Switch along the path poisoned the TLP.

[**6.2.3.4**](6.2.3.4) **Optional Error Checking**

This specification contains a number of optional error checks. Unless otherwise specified, behavior is undefined if an optional error check is not performed and the error occurs.

When an optional error check involves multiple rules, unless otherwise specified, each rule is independently optional. An implementation may check against all of the rules, none of them or any combination.

Unless otherwise specified, implementation specific criteria are used in determining whether an optional error check is performed.

**6.2.4 Error Logging**

[Section 6.2.7](#bookmark29)lists all the errors governed by this specification and for each error, the logging requirements are specified. Device Functions that do not support the Advanced Error Reporting Capability log only the Device Status register bits

indicating that an error has been detected. Note that some errors are also reported using the reporting mechanisms in the PCI-compatible (Type 00hand 01h) configuration registers.Section 7.5.1describeshow these register bits are

affected by the different types of error conditions described in this section.

For device Functions supporting the Advanced Error Reporting Capability, each of the errors in [Table 6-3 ,](#bookmark30)[Table 6-4 ,](#bookmark31) and [Table 6-5](#bookmark32)corresponds to a particular bit in the Uncorrectable Error Status register or Correctable Error Status

register. These registers are used by software to determine more precisely which error and what severity occurred. For specific Transaction Layer errors and Uncorrectable Internal Errors, the associated TLP header is recorded.

In a Multi-Function Device, PCI Express errors that are not related to any specific Function within the device, are logged in the corresponding status and logging registers of all Functions in that device.

The following PCI Express errors are not Function-specific:

• All Physical Layer errors

• All Data Link Layer errors

• These Transaction Layer errors: 。 ECRC Check Failed

。 Unsupported Request, when caused by no Function claiming a TLP 。 Receiver Overflow

。 Flow Control Protocol Error 。 Malformed TLP

。 Unexpected Completion, when caused by no Function claiming a Completion

。 Unexpected Completion, when caused by a Completion that cannot be forwarded by a Switch, and the Ingress Port is a Switch Upstream Port associated with a Multi-Function Device

。 Some Transaction Layer errors (e.g., Poisoned TLP Received) may be Function-specific or not,

depending upon whether the associated TLP targets a single Function or all Functions in that device.

• Some Internal Errors

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

。 The determination of whether an Internal Error is Function-specific or not is implementation specific.

On the detection of one of these errors, aMulti-Function Deviceshould generate at most one error reporting Message of a given severity, where the Message must report the Requester ID of a Function of the device that is enabled to report

that specific type of error. If no Function is enabled to send a reporting Message, the device does not send a reporting

Message. If all reporting-enabled Functions have the same severity level set for the error, only one error Message is sent. If all reporting-enabled Functions do not have the same severity level set for the error, one error Message for each

severity level is sent. Software is responsible for scanning all Functions in a Multi-Function Devicewhen it detects one of those errors.

[**6.2.4.1**](6.2.4.1) **Root Complex Considerations (Advanced Error Reporting)**

**6.2.4.1.1 Error Source Identification**

In addition to the above logging, a Root Port or Root Complex Event Collector that supports the Advanced Error

Reporting Capability is required to implement the Error Source Identification register, which records the Requester ID of the firstERR\_NONFATAL/ERR\_FATAL (uncorrectable errors) and ERR\_COR (correctable errors) Messages received by the Root Port or Root Complex Event Collector. System software written to support Advanced Error Reporting can use the Root Error Status register to determine which fields hold valid information.

If an RCiEPis associated with a Root Complex Event Collector, the RCiEP must report its errors through that Root Complex Event Collector.

For both Root Ports and Root Complex Event Collectors, in order for a received error Message or an internally generated error Message to be recorded in the Root Error Status register and the Error Source Identification register, the error

Message must be “transmitted” Refer to[Section 6.2.8.1f](#bookmark33)or information on how received Messages are forwarded and transmitted. Internally generated error Messages are enabled for transmission with the SERR# Enable bit in the

Command register (ERR\_NONFATALand ERR\_FATAL) or the Reporting Enable bits in the Device Control register (ERR\_COR,ERR\_NONFATAL, and ERR\_FATAL).

**6.2.4.1.2 Interrupt Generation**

The Root Error Command register allows further control of Root Complex response to Correctable, Non-Fatal, and Fatal error Messages than the basic Root Complex capability to generate system errors in response to error Messages. Bit

fields enable or disable generation of interrupts for the three types of error Messages. System error generation in response to error Messages may be disabled via the PCI Express Capability structure.

If a Root Port or Root Complex Event Collector is enabled for level-triggered interrupt signaling using the INTx messages, the virtual INTx wire must be asserted whenever and as long as all of the following conditions are satisfied:

• The Interrupt Disable bit in the Command register is set to 0b.

• At least one Error Reporting Enable bit in the Root Error Command register and its associated error Messages Received bit in the Root Error Status register are both set to 1b.

Note that all other interrupt sources within the same Function will assert the same virtual INTx wire when requesting service.

If a Root Port or Root Complex Event Collector is enabled for edge-triggered interrupt signaling using MSI or MSI-X, an interrupt message must be sent everytime the logical AND of the following conditions transitions from FALSE to TRUE:

• The associated vector is unmasked (not applicable if MSI does not support PVM).

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• At least one Error Reporting Enable bit in the Root Error Command register and its associated error Messages Received bit in the Root Error Status register are both set to 1b.

Note that Advanced Error Reporting MSI/MSI-X interrupts always use the vector indicated by the Advanced Error Interrupt Message Number field in the Root Error Status register.

[**6.2.4.2**](6.2.4.2) **Multiple Error Handling (Advanced Error Reporting Capability)**

For the Advanced Error Reporting Capability, the Uncorrectable Error Status register and Correctable Error Status register accumulate the collection of errors which correspond to that particular PCI Express interface. The bits remain set until

explicitly cleared by software or reset. Since multiple bits might be set in the Uncorrectable Error Status register, the First

Error Pointer (when valid) points to the oldest uncorrectable error that is recorded. The First Error Pointer is valid when the corresponding bit of the Uncorrectable Error Status register is set. The First Error Pointer is invalid when the

corresponding bit of the Uncorrectable Error Status register is not set, or is an undefined bit.

The Advanced Error Reporting Capability provides the ability to record headers99 for errors that require header logging. An implementation may support the recording of multiple headers, but at a minimum must support the ability of

recording at least one. The ability to record multiple headers is indicated by the state of the Multiple Header Recording Capable bit and enabled by the Multiple Header Recording Enable bit of the Advanced Error Capabilities and Control register. When multiple header recording is supported and enabled, errors are recorded in the order in which they are detected.

If no header recording resources are available when an unmasked uncorrectable error is detected, its error status bit is set, but the error is not recorded. If an uncorrectable error ismasked when it is detected, its error status bit is set, but the error is not recorded.

When software is ready to dismiss a recorded error indicated by the First Error Pointer, software writes a 1b to the

indicated error status bit to clear it, which causes hardware to free up the associated recording resources. If another

instance of that error is still recorded, hardware is permitted but not required to leave that error status bit set. If any

error instance is still recorded, hardware must immediately update the Header Log,TLP Prefix Log,TLP Prefix Log

Present bit, First Error Pointer, and Uncorrectable Error Status register to reflect the next recorded error. If no other error is recorded, it is recommended that hardware update the First Error Pointer to indicate a status bit that it will never set, e.g., a Reserved status bit. See the Implementation Note below.

If multiple header recording is supported and enabled, and the First Error Pointer is valid, it is recommended that

software not write a 1b to any status bit other than the one indicated by the First Error Pointer100 . If software writes a 1b to such non-indicated bits, hardware is permitted to clear any associated recorded errors, but is not required to do so.

If software observes that the First Error Pointer is invalid, and software wishes to clear any unmasked status bits that were set because of earlier header recording resource overflow, software should be aware of the following race

condition. If any new instances of those errors happen to be recorded before software clears those status bits, one or more of the newly recorded errors might be lost.

If multiple header recording is supported and enabled, software must use special care when clearing the Multiple

Header Recording Enable bit. Hardware behavior is undefined if software clears that bit while the First Error Pointer is valid. Before clearing the Multiple Header Recording Enable bit, it is recommended that software temporarily mask all uncorrectable errors, and then repetitively dismiss each error indicated by the First Error Pointer.

Since an implementation only has the ability to record a finite number of headers, it is important that software services the First Error Pointer, Header Log, and TLP Prefix Log registers in a timely manner, to limit the risk of missing this

information for subsequent errors. A Header Log Overflow occurs when an error that requires header logging is detected

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

99. If a Function supports TLP Prefixes, then its AER Capability also records any accompanying TLP Prefix along with each recorded header. References to header recording also imply TLP Prefix recording.

100. Status bits for masked errors are an exception. Software can safely clear them if software is certain that they have no recorded headers, as would be the case if they have remained masked since the First Error Pointer was last invalid.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

and either the number of recorded headers supported by an implementation has been reached, or the Multiple Header Recording Enable bit is not Set and the First Error Pointer is valid.

Implementations may optionally check for this condition and report a Header Log Overflow error. This is a reported error associated with the detecting Function.

The setting of Multiple Header Recording Capable and the checking for Header Log Overflow are independently optional.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAJcCAYAAADEj+VDAAAAX0lEQVR4nO3KoQEAIAgAQXBJqqNZnVILlQ3u61/Gvi+mTuUaZwcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB8iTsHuKIy3ygAAAAASUVORK5CYII=)

**IMPLEMENTATION NOTE**

First Error Pointer Register Being Valid

The First Error Pointer (FEP) field is defined to be valid when the corresponding bit of the Uncorrectable Error Status register is set. To avoid ambiguity with certain cases, the following is recommended:

• After an uncorrectable error has been recorded, when the associated bit in the Uncorrectable Error Status register is cleared by software writing a 1b to it, hardware should update the FEP to point to a status bit that it will never set, e.g., a Reserved status bit. (This assumes that the Function does not already have another recorded error to report, as could be the case if it supports multiple header

recording.)

• The default value for the FEP should point to a status bit that hardware will never set, e.g., a Reserved status bit.

Here is an example case of ambiguity with Unsupported Request (UR) if the above recommendations are not followed:

• UR and Advisory Non-Fatal Error are unmasked while system firmware does its Configuration Space probing.

• The Function encounters a UR due to normal probing, logs it, and sets the FEP to point to UR.

• System firmware clears the UR Status bit, and hardware leaves the FEP pointing to UR.

• After the operating system has booted, it masks UR.

• Normal probing sets the UR Status bit, but the error is not recorded since UR is masked.

At this point, there’s the ambiguity of the FEP pointing to a status bit that is set (thus being valid), when in fact, there is no recorded error that needs to be processed by software.

If hardware relies on this definition of the FEP being valid to determine when it’s possible to record a new error, the Function can fail to record new unmasked errors, falsely determining that it has no available recording

resources. Hardware implementations that rely on other internal state to determine when it’s possible to record a new error might not have this problem; however, hardware implementations should still follow the above

recommendations to avoid presenting this ambiguity to software.

[**6.2.4.3**](6.2.4.3) **Advisory Non-Fatal Error Logging**

[Section 6.2.3.2.4](#bookmark13)describes Advisory Non-Fatal Error cases, under which an agent with AER detecting an uncorrectable

error of non-fatal severity signals the error (if enabled) using ERR\_CORinstead ofERR\_NONFATAL. For the same cases, an agent without AER sends no error Message. The remaining discussion in this section is in the context of agents that do

implement AER.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

For Advisory Non-Fatal Error cases, since an uncorrectable error is signaled using the correctable error Message, control/ status/mask bits involving both uncorrectable and correctable errors apply.[Figure 6-2](#bookmark35)shows a flowchart of the

sequence. Following are some of the unique aspects for logging Advisory Non-Fatal Errors.

First, the uncorrectable error needs to be of severity non-fatal, as determined by the associated bit in the Uncorrectable Error Severity register. If the severity is fatal, the error does not qualify as an Advisory Non-Fatal Error, and will be

signaled (if enabled) with ERR\_FATAL.

Next, the specific error case needs to be one of the Advisory Non-Fatal Error cases documented in [Section 6.2.3.2.4 .](#bookmark20) If not, the error does not qualify as an Advisory Non-Fatal Error, and will be signaled (if enabled) with an uncorrectable error Message.

Next, the Advisory Non-Fatal Error Status bit is set in the Correctable Error Status register to indicate the occurrence of

the advisory error, and the Advisory Non-Fatal Error Mask bit in the Correctable Error Mask register is checked, and, if set, no further processing is done.

If the Advisory Non-Fatal Error Mask bit is clear, logging proceeds by setting the “corresponding” bit in the Uncorrectable Error Status register, based upon the specific uncorrectable error that’s being reported as an advisory error. If the

“corresponding” uncorrectable error bit in the Uncorrectable Error Mask register is clear and the error is one that

requires header logging, then the prefix and header are recorded, subject to the availability of resources. See [Section](#bookmark34) [6.2.4.2 .](#bookmark34)

Finally, an ERR\_COR Message is sent if the Correctable Error Reporting Enable bit is set in theDevice Control Register.

[**6.2.4.4**](6.2.4.4) **TLP Prefix Logging**

For any device Function that supports both TLP Prefixes and Advanced Error Reporting the TLP Prefixes associated with the TLP in error are recorded in the TLP Prefix Log register according to the same rules as the Header Log register (such that both the TLP Prefix Log and Header Log registers always correspond to the error indicated in the First Error Pointer, when the First Error Pointer is valid).

The TLP Prefix Log Present bit (seeSection 7.8.4.7) indicates that the TLP Prefix Log register (seeSection 7.8.4.12) contains information.

Only End-End TLP Prefixes are logged by AER. Logging of Local TLP Prefixes may occur elsewhere using prefix specific mechanisms.101

End-End TLP Prefixes are logged in the TLP Prefix Log register. The underlying TLP Header is logged in the Header Log register subject to two exceptions:

• If the Extended Fmt Field Supported bit is Set (seeSection 7.5.3.15), a Function that does not support TLP

Prefixes and receives a TLP containing a TLP Prefix will signal Malformed TLP and the Header Log register will contain the first four DWs of the TLP (TLP Prefixes followed by as much of the TLP Header as will fit).

• A Function that receives a TLP containing more End-End TLP Prefixes than are indicated by the Function’s Max End-End TLP Prefixes field must handle the TLP as an error (seeSection 2.2.10.2for specifics) and store the first overflow End-End TLP Prefix in the 1st DW of the Header Log register with the remainder of the Header Log

register being undefined.

**6.2.5 Sequence of Device Error Signaling and Logging Operations**

[Figure 6-2](#bookmark38)shows the sequence of operations related to signaling and logging of errors detected by a device.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

101. For example, errors involving MRI-IOVTLP Prefixes are logged in MR-IOV structures and are not logged in the AER Capability.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Error from Table 6-2, 6-3, 6-4, or 6-5 Detected

![](data:image/png;base64,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)

Error Type?

![](data:image/png;base64,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)Uncorrectable Correctable Abbreviations:

reg

register

Cmd

Command register SERR# Enable

Device Control register Unsupported Request Reporting Enable

Fatal Error Reporting Enable

Non-Fatal Error

Reporting Enable Correctable Error Reporting Enable

|  |
| --- |
| Determine severity according to Uncorrectable Error Severity reg |

SERR\_En DCR

URRE FERE NERE CERE

Advisory

Non-Fatal Error? (Section 6.2.3.2.4)

Yes Implted? Yes

No

No

y

|  |
| --- |
| Set Fatal/Non-Fatal Error Detected bit in Device Status reg |

|  |
| --- |
| Set Correctable Error Detected bit in Device Status reg |

|  |
| --- |
| If UR, Set Unsupported Request Detected bit in Device Status reg |

|  |
| --- |
| If UR, Set Unsupported Request Detected bit in Device Status reg |

Advanced

|  |
| --- |
| Set corresponding bit in  Uncorrectable Error Status reg |

|  |
| --- |
| Set corresponding bit in Correctable Error Status reg |

Error

Reporting

only

in C![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAkAAAAZCAYAAADjRwSLAAABt0lEQVQokc2RPWsUURSG3/sxH3cmM3dmdzM7O7O7g6ktBEUi2oiNIAT8FfYpbP0P6SwsAzZW+wMsUxhSqCEgQbEISFiEEN07M3fujI0r6xrsBJ/qwHk4h/MexDK4LSjuAADA4AWRE/vOYwIkWLI1nbwaBewTAIBLZJPi0bWh7BjwcOlQo43hrjilwDb3XLBG77TAa6xA0VTQXMx8ynZ8l9l1ZSYATn+XUEMZ69Dz/BuC6buqwREAsyZ1WJRG24H/2WrUruowwxoUAMyihOHWrCnVzRY4Wpf+R5iIEjKM5F4vdJ+23xdFmGQXAxnuBy59olV13gAfsLE5pVtpOLcYe2A7Qoxj8YYSq5DJOBxH9lsC9DgAGF01jTHv+sPEtUhzKxfYBwE6Y1GCesRXVnembctanZ+dXeh73Avhd9X9FjhelXB5qdRGPNwbC/OecvJx8fWbg7Vn/zzFhnCdyKJI/2Vif4Eti8003x5I+VL61m5bKlG3OPjDznr+M0bs6/3RNM5DNl/t/YrA2NFBnpHnlJFQE/Su3Dvtiy+M2EU/K+JcsvLKSUzEJ2mKF5SiI4wTAjPogDkA/AAZC4TCJ69CzAAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAYAAAAXCAYAAAAoRj52AAABUklEQVQokbWPu24TURRF173nztjj8TztsZ0Zx5agTUGZPl9AR5c+BQU/AP9AhaL0SOkooKVBKVKmSB0psSIZoWCDH/OksuQPCLvcW2tJW7C6JIPkuB8EnwPXeldv1k5ec4XlJaSx+16UfdQ7mESZLz8BTJlvqdzwKkvVJy3KLxQxAMFwYk16zqMoe9pLp1EWyAbA5HlZiRvdjkZcaE2jxCioABSm1VZto8b8nygAxKWfREddS13W20VnPv/9FoBO/1C9GPl3tnZOkjR7OejoHwBEB1P7MDTNvkoDVDW1FikUetiNh2bQlXMBKGpT+2G8CF3vi9duTleL5XqPtXGcVmRpRs/9MEvHZ9MsvRl41tf9XiJr+332V155LbzVOm8auAcQvz+WuM23fLMuV9vysoEnAL2cP/yaPZVOKwivfeHjTmWiZPi6qPQbVfzJNjUfdsM/43ReH9ajzoEAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAYAAAAXCAYAAAAoRj52AAABPUlEQVQokY2Qu0oDURRF19w7d15kkpnRxJhEAxbWgig2/oEgdnaCYKOFlYKd/yC2/oCFnYKVnYWlv2DSBEyIMZlM5mGRFAkRdFeHs9h7cw4A1UrttF6tvJdc9chEEsBXw5fmt9xwTdz+IMoy+JAA+cWaDCyeonAQ94fxfQYdAfDVanw2O7FtFry3vOQGQAfwi0sHo0QcaqNeNUy5ZlqOpVYlFPinJIbSjemNAJCFImXPuhOwPQM8x1jXLXcvcMTVTJDylqkXcw8SdmYc2XjOMkhnwG8aO5IUzXQbviMu57gyLWnqrPx9mrJd8pbcnQPOQlXUfONVg2CuHEA6vlYuBUc5nROYvF1TBcqOfha2W5u9mP2JQ0OZtqGn0Xk/jJ+nojKiXitqJ/ZW4NnHAtamOhK67W4nsf2LwNZuAX4AfPFRO1HyE0oAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAZCAYAAAD9jjQ4AAABL0lEQVQokb2SPU7DQBCF3+ysHW8S7KydRCaOEik1VAiJhooDcAQkJCoKJCRqzkBBQUHPGWgofQAKrhDJEUFRBMbxxhT8yDFp4evevnkzu6MFAFhqA67D+1hHPYhEX9sxAX75XJQF1zWFXf+oKXECAPLbIMtDWJen6TTZmec4LCUJVk3Zcpmdvab5faVtgWyeZFOjdv2WOhbAqDLTYDadvRilL3xF12tv/g9wJ4z22p535zWs82X6prIl4h+35zcumeytYHOgI5cn5aQ0diuOenQjmNwFre4Wg0CNmexh0BvqyON0JclKP4UhboVAQSyJYNoF8Nle1hxyJPX/7Mm/obJQrS75jrySYrH9PE4eViqbnYEYhe7EYj5gwJaoYBbveW7MYwFkomp+UQCV31flA/q7RnDCFl07AAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAYAAAAXCAYAAAAoRj52AAABL0lEQVQoka2RPUoDURhFz/vmvZlMNJkfJ38zEwIW1hZuQFyEC7BwMza6hyzB2iqF2ImIWAQFQRBJkESTTDKJjQqJARtPeW9xLxwLIKrFu5FXbpcKcjwdTV5mcA9AGrhXokzLq6bl1LevFYQawBTDvcSljYJFbkSRNQBIPPMEoItlPFfvA2gAKdXOUje/Ea26H72hA1zwjVtwfCPU+RPPtQ7WFs3QvlOwtZqL5YSSxMlJWvU7ReHwp9luhF1X7CO/1gzSwH5QEALILHvPxvPsfDjJ+9rYtwI7ACJiLEHFthaZ53k6h2cALY6n4oZ3aslUvb2OLxfw+LWiMLYtRv1+9k9YAOgNokplySIApUpirbEIUdwKSmrWmy3ooBSLcd8HIKg33VWLGmAwGI02g2WLn98wVC09i4woAAAAAElFTkSuQmCC)l![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAdCAYAAABmH3YuAAABkElEQVQokbWSzYrTYBSGn+8vyTdp/mrTNiRt3bl1McsREcHrcOcVeAPudOnS/VyHuBN0NQiC4CAqLVhmNpmZtCZpXAwtUxDcjO/yPO85nPNy4BYk8PxQBK548heoiEcTJw/Vt21FCyck7QcPPbl5tRFi0YHd+cPhxEz79qsywSybzB7koep2nY7GX1+smraWP6o6Xvgw30LZbqiUli5CGS1lD4h3nWVZrYMke1P43XutWdWwG3t9hHaxrk4FHNxGKP+Qul7LZ5Cm9wdReBx48lldrX818AWAIM1VkdgPUphZNCzCInZOBPQ1gGt0aJz+YW45RkDXGin4nQGQjCc2j8xPAH0QEln9CEADlGVV9ZLR68K2n6QWp1fnFy7w9sZqDtZzYyMZ/+cQBMAoKx67onlZN3xuLpft8rJ9unNM+/ZUmeBuNpkd5dGNTwBYr1ZtW8vvVZ3MfVjsQW20h1C+USIC7uxBEYxfzHrdCao7azrWe7A6nw/PKn1vkKWJbrt3e9AmGdOEj11ddsurzfMt/ANf1W/NXt8tOwAAAABJRU5ErkJggg==)?Error Yes

Masked

in Uncorrectable Error

Mask reg?

No

Yes

I No End

End

(Error is UR)

|  |
| --- |
| As appropriate, record prefix and  header, and update prefix and  header reporting fields and regs |

V

<>

|  |
| --- |
| If Advisory Non-Fatal Error: (1) Set  corresponding bit in Uncorrectable  Error Status reg, and (2) if  unmasked in Uncorrectable Error  Mask reg, as appropriate, record  prefix and header and update prefix  and header reporting fields and regs |

Yes

AND (DCR:URRE=0)

AND (Cmd:SERR\_En=0)?

I No

<>

No

End

Yes

(Error is UR) AND

(DCR:URRE=0)?

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAD8AAAAjCAYAAAAjS9I/AAAE4UlEQVRogd3Z8UtVZxzH8Y8d7z3e53nOc54zFSfNJsvhBA1HkwltISIio9FoDZomawiC0JLJmkNYtAyGCCELZNUcEovFWjQEVwnNBfqDsVUzmrQmaSiKOkU99xz13nue/bAx5GKZevVhvf6C7/uHc8/5fi+gzis+n68WgKFwhg33ohCi3bIsp6ioyKWUzui6/iEAXfVg6ynVNM1Wxph7/PjxsG3bUkopb9++LQsLC23G2JimaeUANqkeNJYEY6yREOLU1NQsTExMyKVcv35d5ubm2pzzfgBvAIhTPfhaJAQCgU8IIbPl5eXuw4cPl4xezPM8eenSJZmenm6bpvkrgHzVESul+f3+CsbYXyUlJcG7d+8uGx0tFArJlpYWmZSU5AghOgBkqY5aTlx8fPxbnPPBvLw8u7u7e8XR0RzHkY2NjRHOuSuE+BZAmurIpbwuhOjNyMiw29vbped5aw5fbGpqStbW1i5QSl3DML4A8IzqYADIEUL8nJKSEjx79qwMh8MxjY42PDwsKyoq5gghdiAQ+BQAURGdbprm96ZpOk1NTd7c3Ny6Rke7d++e3L17d5BSOuXz+aoA+DYiOplz/iWl1D1y5Eh4ZmZmQ6Oj3bhxQ+7YscPmnA9rmvYO1un1yAgh9YSQYFVV1fzo6KjS6GgdHR0yKyvLFkL0ASiMVbRf1/VqSun03r17nf7+ftWdjxSJROT58+fl5s2bg0KIbgAvrzZ6k6ZpZYZhjBYUFNi3bt1S3fbEFhYWZHNzs2dZliOEaAOQ8aTRcQBKhBB/5uTk2J2dnapbVs22bVlfXx9mjLmGYbQAePZx4a9alvXLli1b7IsXL8b8Xa3K+Pi4rK6unieEOIyxBgB8cXSWEOJKUlKSc+bMGRkKhVTPuy4GBwdlWVmZQymd1XX9YwA6NE0bAiCvXr2qer51FwwG5f79+z0AEkAd8M8i8h5jbKyoqCjY29uresaYC4VC8tSpUzIxMdERQvwIIDP6mdd1Xa+hlM7s27fPffDggeqZ18zzPHnhwgWZlpZmCyF6AOQt94vPGWOfE0KcgwcPzo+NjaluWJVr167J7Oxs2zTNPwAUY4VffymmaX7FGHOPHj0anp2dVd3zRG7evCl37txpG4Yxomnau1jjWewFIcQPQgjn5MmT3vz8vOq+Jd2/f1/u2bPHoZROJyQkfADAv5boaLmWZXWlpqYGz507JyORiOpeKaWUIyMjsrKyco4QEiSEfAaAxTI6WoEQ4vfMzEz78uXLyj6GpqenZV1dXYhS6nLOmwEkrWf0YnHx8fFvc86H8vPz7Z6eng2Ldl1XnjhxwjNN0zVN8zsAz29UdLR4n89XSSmd3LVrV7Cvr2/dosPhsGxtbZXJyclBy7J+ApCtKjpaIBAI1BFC7AMHDswNDQ3FLNrzPNnW1ia3bt1qCyF+A/Ca6thHsQzDaKKUuocPH16YnJxcU3hXV5fcvn27zTkfAPAm/id/ZDwnhPiGc+42NDREHMdZUfSdO3dkcXFxkDE24ff73wegqQ5ajZcsy7qSmJjonD59etmNcWBgQJaWlrr/bl4fAUhQHRALj70VjI+Py0OHDi3euU3VA8faf1eibdu22Z2dndK2bXns2LEwY8w1TfNrLHNteRps0jSt1DCMUZ/PF1npne1p4ccSe/VG+huGjCKWDbS++gAAAABJRU5ErkJggg==)DPC Trigger Enabled?

<>

No

Yes

End

V

<> ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAYAAAAKCAYAAACXDi8zAAAAgElEQVQImXWMMQrCQBQFJzEgQorPXmAXtlU8e8olEPAOli7832klKAa00cKNpsnrhmFeFX3YAZpN7wDRhxbwKyeyBQYncnEie6ADUhV9WANXYMN3D8DV2fQJHPhvyKavukA/EwlgUTQFjsAZGLPp6Vdk03ep0pQ1s4seuC2JcYIP3fkmQgIOBoMAAAAASUVORK5CYII=)i

No

(DCR:CERE=1)?

End

|  |
| --- |
| Set DPC Trigger Status & DPC Trigger Reason |

Fatal Non-fatal

Yes

Severity?

![](data:image/png;base64,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)

End

|  |
| --- |
| Send ERR\_COR |

![](data:image/png;base64,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)(Cmd:SERR\_En=1)

(Cmd:SERR\_En=1)

OR

(DCR:FERE=1)?

No

No

OR

(DCR:NERE=1)?

V

End

V

End

End

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGsAAAAbCAYAAAB7nXHNAAAAxElEQVRoge3RsQ2CUABF0avhx1DQAi0LWNlYOQAbOICFe7kCc2BnY0spIVAYtXABSOy+L3lngpvcFXAqiuKYpukd+0vDMGz7vj8nQN627b4sy0PsKJvXNM2zrutsDXQhhHfsIFsWQngBj3XsEPudZwnxLCGeJcSzhHiWEM8S4llCPEuIZwnxLCGeJcSzhHiWEM8S4llCPEuIZwnxLCGeJcSzhHiWkASoxnEMWZZ9YsfYvGmaNkCeANeqqi7ALXKTLdsB3Rdl/B6MIqpKiQAAAABJRU5ErkJggg==)Yes

Yes

Send ERR\_FATAL

|  |
| --- |
| Send ERR\_NONFATAL |

End

OM14546E

End

Figure 6-2 Flowchart Showing Sequence of Device Error Signaling and Logging Operations

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 518

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.2.6 Error Message Controls**

Error Messages have a complex set of associated control and status bits.[Figure 6-3](#bookmark40)provides a high-level summary in the form of a pseudo logic diagram for how error Messages are generated, logged, forwarded, and ultimately notified to the system. Not all control and status bits are shown. The logic gates shown in this diagram are intended for conveying

general concepts, and not for direct implementation.

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Root Ports |  | Root Complex Event Col lectors |  | Virtual PC I Bridges (Type 1 devices) |  | All PCI Express devices |  | System Specific  Error Interrupt (INTx or MSI)   |  |  | | --- | --- | | Q  X | *AER consolidation (RP/RCECportion of optional AER)*  AER Reporting Enables (one per error class)  Root Error Command register  Root Error Status register |  |  | | --- | | Error  Message Received |   Q  Not contained by DPC  Set if ERR\_FATAL or ERR\_NONFATAL  triggers DPC  DPC Status Register   |  | | --- | | DPC Trigger Status & DPC Trigger Reason |   SQ  SERR# Enable (for forwarding) Control register  Set upon ERR\_FATAL or ERR\_NONFATAL only  Secondary Status register  Bridge    System Error (platform specific)   |  |  |  | | --- | --- | --- | |  | System Error Enables (one per error class) Root Control register |  |   ERR\_\*Message  Set upon ERR\_NONFATAL or ERR\_FATAL only Status register   |  | | --- | | Signaled  System  Error |   Error Reporting Enables (one per error class)  Q  Q A  SERR# Enable (for transmission) Command register  ERR\_NONFATAL and ERR\_FATAL only  Device Control register  ERR\_COR,  ERR\_NONFATAL, and ERR\_FATAL  Internally generated ERR\_\*  Messages   |  | | --- | | Received  System  Error |   Received  ERR\_\*  Messages  A-0479B |

Figure 6-3 Pseudo Logic Diagram for Selected Error Message Control and Status Bits

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 519

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.2.7 Error Listing and Rules**

[Table 6-2](#bookmark41)through[Table 6-4](#bookmark42)list all of the PCI Express errors that are defined by this specification. Each error is listed

with a short-hand name, how the error is detected in hardware, the default severity of the error, and the expected action taken by the agent which detects the error. These actions form the rules for PCI Express error reporting and logging.

The Default Severity column specifies the default severity for the error without any software reprogramming. For device Functions supporting the Advanced Error Reporting Capability, the uncorrectable errors are programmable to Fatal or Non-fatal with the Error Severity register. Device Functions without Advanced Error Reporting Capability use the default associations and are not reprogrammable.

The detecting agent action for Downstream Ports that implement Downstream Port Containment (DPC) and have it enabled will be different if the error triggers DPC. DPC behavior is not described in the following tables. See [Section](#bookmark43) [6.2.10 f](#bookmark44)or the description of DPC behavior.

Table 6-2 General PCI Express Error List

|  |  |  |  |
| --- | --- | --- | --- |
| Error Name | Error Type  (Default Severity) | Detecting Agent Action102 | References |
| Corrected Internal Error | Correctable  (masked by default) | Component:  Send ERR\_CORto Root Complex. | [Section](#bookmark45) [6.2.9](#bookmark46) |
| Uncorrectable Internal Error | Uncorrectable  (Fatal and masked by default) | Component: Send ERR\_FATALto Root Complex.  Optionally, log the prefix/header of the first TLP associated with the error. | [Section](#bookmark47) [6.2.9](#bookmark48) |
| Header Log Overflow | Correctable  (masked by default) | Component:  Send ERR\_CORto Root Complex. | [Section](#bookmark34) [6.2.4.2](#bookmark34) |

Table 6-3 Physical Layer Error List

|  |  |  |  |
| --- | --- | --- | --- |
| Error Name | Error Type (Default Severity) | Detecting Agent Action103 | References |
| Receiver Error | Correctable | Receiver:  Send ERR\_CORto Root Complex. | Section 4.2.1.1.3 Section 4.2.1.2 Section 4.2.4.8 Section 4.2.6 |

Table 6-4 Data Link Layer Error List

|  |  |  |  |
| --- | --- | --- | --- |
| Error Name | Error Type  (Default Severity) | Detecting Agent Action104 | References |
| Bad TLP | Correctable | Receiver:  Send ERR\_CORto Root Complex. | Section 3.6.3.1 |
| Bad DLLP | Receiver:  Send ERR\_CORto Root Complex. | Section 3.6.2.2 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

102. For these tables,detecting agent action is given as if all enable bits are set to “enable” and, for Advanced Error Handling, mask bits are disabled and severity bits are set to their default values. Actions must be modified according to the actual settings of these bits.

103. For these tables,detecting agent action is given as if all enable bits are set to “enable” and, for Advanced Error Handling, mask bits are disabled and severity bits are set to their default values. Actions must be modified according to the actual settings of these bits.

104. For these tables,detecting agent action is given as if all enable bits are set to “enable” and, for Advanced Error Handling, mask bits are disabled and severity bits are set to their default values. Actions must be modified according to the actual settings of these bits.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |
| --- | --- | --- | --- |
| Error Name | Error Type  (Default Severity) | Detecting Agent Action | References |
| Replay Timer Timeout |  | Transmitter:  Send ERR\_CORto Root Complex. | Section 3.6.2.1 |
| REPLAY\_NUM Rollover | Transmitter:  Send ERR\_CORto Root Complex. | Section 3.6.2.1 |
| Data Link Protocol Error | Uncorrectable (Fatal) | If checking, send ERR\_FATALto Root Complex. | Section 3.6.2.2 |
| Surprise Down | If checking, send ERR\_FATALto Root Complex. | Section 3.2.1 |

Table 6-5 Transaction Layer Error List

|  |  |  |  |
| --- | --- | --- | --- |
| Error Name | Error Type (Default Severity) | Detecting Agent Action105 | References |
| Poisoned TLP  Received | Uncorrectable (Non-Fatal) | Receiver:  Send ERR\_NONFATALto Root Complex or ERR\_CORfor the Advisory Non-Fatal Error cases described in [Section 6.2.3.2.4.1](#bookmark22) and [Section 6.2.3.2.4.2 .](#bookmark24)  Log the prefix/header of the Poisoned TLP.106 | Section 2.7.2.2 |
| Poisoned TLP Egress Blocked | Downstream Port Transmitter:  Send ERR\_NONFATALto Root Complex.  Log the prefix/header of the poisoned TLP. | Section 2.7.2.2 |
| ECRC Check Failed | Receiver (if ECRC checking is supported):  Send ERR\_NONFATALto Root Complex or ERR\_CORfor the Advisory Non-Fatal Error case described in [Section 6.2.3.2.4.1](#bookmark22) and [Section 6.2.3.2.4.2 .](#bookmark24)  Log the prefix/header of the TLP that encountered the ECRC  error. | Section 2.7.1 |
| Unsupported Request (UR) | Uncorrectable (Non-Fatal) | Request Receiver:  Send ERR\_NONFATALto Root Complex or ERR\_CORfor the  Advisory Non-Fatal Error case described in [Section 6.2.3.2.4.1 .](#bookmark22) Log the prefix/header of the TLP that caused the error. | Table F-1 ,Section 2.3.1 ,Section 2.3.2 ,Section 2.7.2.2 ,  Section 2.9.1 ,Section 5.3.1 ,[Section 6.2.3.1 ,](#bookmark10)[Section 6.2.6 ,](#bookmark39) [Section 6.2.8.1 ,](#bookmark49)[Section 6.5.7 ,](#bookmark50)Section 7.3.1 ,Section 7.3.3 , Section 7.5.1.1.3 ,Section 7.5.1.1.4 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

105. For these tables,detecting agent action is given as if all enable bits are set to “enable” and, for Advanced Error Handling, mask bits are disabled and severity bits are set to their default values. Actions must be modified according to the actual settings of these bits.

106. Advanced Error Handling only.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |
| --- | --- | --- | --- |
| Error Name | Error Type (Default Severity) | Detecting Agent Action | References |
| Completion Timeout | Uncorrectable (Non-Fatal) | Requester:  Send ERR\_NONFATALto Root Complex or ERR\_CORfor the  Advisory Non-Fatal Error case described in [Section 6.2.3.2.4.4 .](#bookmark25)  If the Completion Timeout  Prefix/Header Log Capable bit is Set in the Advanced Error  Capabilities and Control  register, log the prefix/header of  the Request TLP that encountered the error. | Section 2.8 |
| Completer Abort | Completer:  Send ERR\_NONFATALto Root Complex or ERR\_CORfor the  Advisory Non-Fatal Error case described in [Section 6.2.3.2.4.1 .](#bookmark22)  Log the prefix/header of the Request that encountered the error. | Section 2.3.1 |
| Unexpected Completion | Receiver:  Send ERR\_CORto Root  Complex. This is an Advisory Non-Fatal Error case described in [Section 6.2.3.2.4.5 .](#bookmark27)  Log the prefix/header of the Completion that encountered the error. | Section 2.3.2 |
| ACS  Violation | Receiver (if checking):  Send ERR\_NONFATALto Root Complex or ERR\_CORfor the  Advisory Non-Fatal Error case described in [Section 6.2.3.2.4.1 .](#bookmark22)  Log the prefix/header of the Request TLP that encountered the error. |  |
| [MC Blocked](#bookmark51) [TLP](#bookmark52) | Receiver (if checking):  Send ERR\_NONFATALto Root Complex.  Log the prefix/header of the Request TLP that encountered the error. | [Section 6.14.4](#bookmark53) |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 522

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |
| --- | --- | --- | --- |
| Error Name | Error Type (Default Severity) | Detecting Agent Action | References |
| AtomicOp Egress  Blocked | Uncorrectable (Non-Fatal) | Egress Port:  Send ERR\_CORto Root  Complex. This is an Advisory Non-Fatal Error case described in [Section 6.2.3.2.4.1 .](#bookmark22)  Log the prefix/header of the AtomicOp Request that  encountered the error. | Section 6.15.2 |
| TLP Prefix Blocked | Egress Port:  Send ERR\_NONFATALto Root Complex or ERR\_CORfor the  Advisory Non-Fatal Error case described in [Section 6.2.3.2.4.1 .](#bookmark22) Log the prefix/header of the TLP that encountered the error. | Section 2.2.10.2 |
| Receiver Overflow | Uncorrectable (Fatal) | Receiver (if checking):  Send ERR\_FATALto Root Complex. | Section 2.6.1.2 |
| Flow Control Protocol  Error | Receiver (if checking):  Send ERR\_FATALto Root Complex. | Section 2.6.1 |
| Malformed TLP | Receiver:  Send ERR\_FATALto Root Complex.  Log the prefix/header of the TLP that encountered the error. | Section 2.2.2 ,Section 2.2.3 ,Section 2.2.5 ,Section 2.2.7 ,  Section 2.2.8.1 ,Section 2.2.8.2 ,Section 2.2.8.3 ,Section 2.2.8.4 ,Section 2.2.8.5 ,Section 2.2.8.10 ,Section 2.2.10 ,Section  2.2.10.1 ,Section 2.2.10.2 ,Section 2.3 ,Section 2.3.1 ,Section 2.3.1.1 ,Section 2.3.2 ,Section 2.5 ,Section 2.5.3 ,Section 2.6.1 ,Section 2.6.1.2 ,[Section 6.2.4.4 ,](#bookmark36)[Section 6.3.2](#bookmark54) |

For all errors listed above, the appropriate status bit(s) must be set upon detection of the error. For Unsupported Request (UR), additional detection and reporting enable bits apply (see [Section 6.2.5)](#bookmark37).

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Device UR Reporting Compatibility with Legacy and 1.0a Software

With 1.0a device Functions that do not implement Role-Based Error Reporting,107 the Unsupported Request

Reporting Enable bit in the Device Control Register, when clear, prevents the Function from sending any error

Message to signal a UR error. With Role-Based Error Reporting Functions, if the SERR# Enable bit in the Command Registeris set, the Function is implicitly enabled108 to sendERR\_NONFATALor ERR\_FATAL messages to signal UR errors, even if the Unsupported Request Reporting Enable bit is clear. This raises a backward compatibility

concern with software (or firmware) written for 1.0a devices.

With software/firmware that sets the SERR# Enable bit but leaves the Unsupported Request Reporting Enableand Correctable Error Reporting Enable bits clear, a Role-Based Error Reporting Function that encounters a UR error will send no error Message if the Request was non-posted, and will signal the error withERR\_NONFATALif the

Request was posted. The behavior with non-posted Requests supports PC-compatible Configuration Space probing, while the behavior with posted Requests restores error reporting compatibility with PCI and PCI-X, avoiding the potential in this area for silent data corruption. Thus, Role-Based Error Reporting devices are backward compatible with envisioned legacy and 1.0a software and firmware.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAFmCAYAAABQhtsVAAAATUlEQVRoge3MoREAIAwEwYQmsZSGpcpQAROH2re38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAfAMXUdUFygN8xjUAAAAASUVORK5CYII=)

[**6.2.7.1**](6.2.7.1) **Conventional PCI Mapping**

In order to support conventional PCI driver and software compatibility, PCI Express error conditions, where appropriate, must be mapped onto the PCI Status register bits for error reporting.

In other words, when certain PCI Express errors are detected, the appropriate PCI Status register bit is set alerting the error to legacy PCI software. While the PCI Express error results in setting the PCI Status register, clearing the PCI Status register will not result in clearing bits in the Uncorrectable Error Status register and Correctable Error Status register.

Similarly, clearing bits in the Uncorrectable Error Status register and Correctable Error Status register will not result in clearing the PCI Status register.

The PCI command register has bits which control PCI error reporting. However, the PCI Command register does not affect the setting of the PCI Express error register bits.

**6.2.8 Virtual PCI Bridge Error Handling**

Virtual PCI Bridge configuration headers are associated with each PCI Express Port in a Root Complex or a Switch. For these cases, PCI Express error concepts require appropriate mapping to the PCI error reporting structures.

[**6.2.8.1**](6.2.8.1) **Error Message Forwarding and PCI Mapping for Bridge - Rules**

In general, a TLP is either passed from one side of the Virtual PCI Bridge to the other, or is handled at the ingress side of the Bridge according to the same rules which apply to the ultimate recipient of a TLP. The following rules cover PCI

Express specific error related cases. Refer to[Section 6.2.6f](#bookmark39)or a conceptual summary of Error Message Controls.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

107. As indicated by the Role-Based Error Reporting bit in the Device Capabilities register. SeeSection 7.8.3 .

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)108.Assuming the Unsupported Request Error Mask bit is not set in theUncorrectable Error Mask Registerif the device implements AER.

Page 524

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• If a Request does not address a space mapped to either the Bridge’s internal space, or to the egress side of the Bridge, the Request is terminated at the ingress side as an Unsupported Request

• Poisoned TLPs are forwarded according to the same rules as non-Poisoned TLPs 。 When forwarding a Poisoned Request Downstream:

▪ Set the Detected Parity Error bit in the Status register

▪ Set the Master Data Parity Error bit in the Secondary Status register if the Parity Error Response Enable bit in the Bridge Control register is set

。 When forwarding a Poisoned Completion Downstream:

▪ Set the Detected Parity Error bit in the Status register

▪ Set the Master Data Parity Error bit in the Status register if the Parity Error Response bit in the Command register is set

。 When forwarding a Poisoned Request Upstream:

▪ Set the Detected Parity Error bit in the Secondary Status register

▪ Set the Master Data Parity Error bit in the Status register if the Parity Error Response bit in the Command register is set

。 When forwarding a Poisoned Completion Upstream:

▪ Set the Detected Parity Error bit in the Secondary Status register

▪ Set the Master Data Parity Error bit in the Secondary Status register if the Parity Error Response Enable bit in the Bridge Control register is set

• ERR\_COR,ERR\_NONFATAL, and ERR\_FATALare forwarded from the secondary interface to the primary

interface, if theSERR# Enable bit in the Bridge Control Registeris set. A Bridge forwarding an error Message must not set the corresponding Error Detected bit in the Device Status register. Transmission of forwarded error Messages by the primary interface is controlled by multiple bits, as shown in [Figure 6-3 .](#bookmark40)

• For a Root Port, error Messages forwarded from the secondary interface to the primary interface must be

enabled for “transmission” by the primary interface in order to cause a System Error via the Root Control

register or (when the Advanced Error Reporting Capability is present) reporting via the Root Error Command register and logging in the Root Error Status register and Error Source Identification register.

• For a Root Complex Event Collector (technically not a Bridge), error Messages “received” from associated

RCiEPs must be enabled for “transmission” in order to cause a System Error via the Root Control register or

(when the Advanced Error Reporting Capability is present) reporting via the Root Error Command register and logging in the Root Error Status register and Error Source Identification register.

**6.2.9 Internal Errors**

An Internal Error is an error associated with a PCI Express interface that occurs within a component and which may not be attributable to a packet or event on the PCI Express interface itself or on behalf of transactions initiated on PCI

Express. The determination of what is considered an Internal Error is implementation specific and is outside the scope of this specification.

Internal Errors may be classified as Corrected Internal Errors or Uncorrectable Internal Errors. A Corrected Internal Error is an error that occurs within a component that has been masked or worked around by hardware without any loss of

information or improper operation. An example of a possible Corrected Internal Error is an internal packet buffer

memory error corrected by an Error Correcting Code (ECC). An Uncorrectable Internal Error is an error that occurs within a component that results in improper operation of the component. An example of a possible Uncorrectable Internal

Error is a memory error that cannot be corrected by an ECC. The only method of recovering from an Uncorrectable Internal Error is reset or hardware replacement.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Reporting of Corrected Internal Errors and Uncorrectable Internal Errors is independently optional. If either is reported, then AER must be implemented.

Header logging is optional for Uncorrectable Internal Errors. When a header is logged, the header is that of the first TLP that was lost or corrupted by the Uncorrectable Internal Error. When header logging is not implemented or a header is not available, a header of all ones is recorded.

Internal Errors that can be associated with a specific PCI Express interface are reported by the Function(s) associated with that Port. Internal Errors detected within Switches that cannot be associated with a specific PCI Express interface are reported by the Upstream Port. Reporting of Internal Errors that cannot be associated with a specific PCI Express interface in all other multi-Port components (e.g., Root Complexes) is outside the scope of this specification.

**6.2.10 Downstream Port Containment (DPC)**

Downstream Port Containment (DPC) is an optional normative feature of a Downstream Port. DPC halts PCI Express

traffic below a Downstream Port after an unmasked uncorrectable error is detected at or below the Port, avoiding the potential spread of any data corruption, and supporting Containment Error Recovery (CER) if implemented by software. A Downstream Port indicates support for DPC by implementing a DPC Extended Capability structure, which contains all DPC control and status bits. See Section 7.9.15 .

DPC is disabled by default, and cannot be triggered unless enabled by software using theDPC Trigger Enablefield. When the DPC Trigger Enablefield is set to 01b, DPC is enabled and is triggered when the Downstream Port detects an

unmasked uncorrectable error or when the Downstream Port receives an ERR\_FATAL Message. When the DPC Trigger Enablefield is set to 10b, DPC is enabled and is triggered when the Downstream Port detects an unmasked

uncorrectable error or when the Downstream Port receives an ERR\_NONFATALor ERR\_FATAL Message. In addition to uncorrectable errors of the type managed by the PCI Express Extended Capability and Advanced Error Reporting (AER), RP PIO errors can be handled as uncorrectable errors. See [Section 6.2.10.3 .](#bookmark55) There is also a mechanism described in

[Section 6.2.10.4f](#bookmark56)or software or firmware to trigger DPC.

When DPC is triggered due to receipt of an uncorrectable error Message, the Requester ID from the Message is recorded in the DPC Error Source ID Registerand that Message is discarded and not forwarded Upstream. When DPC is triggered by an unmasked uncorrectable error, that error will not be signaled with an uncorrectable error Message, even if

otherwise enabled. However, when DPC is triggered, DPC can signal an interrupt or send an ERR\_COR Message if enabled. See [Section 6.2.10.1](#bookmark57)and [Section 6.2.10.2 .](#bookmark58)

When DPC is triggered, the Downstream Port immediately Sets theDPC Trigger Status bit and DPC Trigger Reasonfield to indicate the triggering condition (unmasked uncorrectable error,ERR\_NONFATAL,ERR\_FATAL, RP\_PIO error, or software triggered), and disables its Link by directing the LTSSM to the Disabled state. Once the LTSSM reaches the Disabled state, it remains in that state until theDPC Trigger Status bit is Cleared. To ensure that the LTSSM has time to reach the

Disabled state or at least to bring the Link down under a variety of error conditions, software must leave the Downstream Port in DPC until the Data Link Layer Link Active bit in the Link Status Register reads 0b; otherwise, the result is

undefined. See Section 7.5.3.8 . See Section 2.9.3for other important details on Transaction Layer behavior during DPC.

After DPC has been triggered in a Root Port that supports RP Extensions for DPC, the Root Port may require some time to quiesce and clean up its internal activities, such as those associated with DMA read Requests. When theDPC Trigger

Status bit is Set and theDPC RP Busy bit is Set, software must leave the Root Port in DPC until the DPC RP Busy bit reads 0b.

After software releases the Downstream Port from DPC, the Port’s LTSSM must transition to the Detect state, where the Link will attempt to retrain. Software can use Data Link Layer State Changed interrupts, DL\_Active ERR\_COR signaling, or both, to signal when the Link reaches the DL\_Active state again. See [Section 6.7.3.3](#bookmark59)and [Section 6.2.10.5 .](#bookmark60)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Data Value of All 1’s

Many platforms, including those supporting RP Extensions for DPC, can return a data value of all 1’s to software when an error is associated with a PCI Express Configuration, I/O, or Memory Read Request. During DPC, the

Downstream Port discards Requests destined for the Link and completes them with an error (i.e., either with an

Unsupported Request (UR) or Completer Abort (CA) Completion Status). By ending a series of MMIO or

configuration space operations with a read to an address with a known data value not equal to all 1’s, software may determine if a Completer has been removed or DPC has been triggered.

Also see the Implementation Note “[Use of RP PIO Advisory Error Handling](#bookmark61)”

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADkCAYAAACliWVyAAAAQElEQVRYhe3MsQ0AIAwDwYQlaRmNlinDBCg9Ord/ckSzjHXqWffM0T0AAAAAAAAAAAAAAAAAAAAAAAAAAAB8Ay67TATGzqKZhAAAAABJRU5ErkJggg==)

**IMPLEMENTATION NOTE**

Selecting Non-Posted Request Response During DPC

The DPC Completion Control bit determineshow a Downstream Port responds to a Non-Posted Request (NPR) received during DPC. The selection needs to take into account how the rest of the platform handles Containment Error Recovery (CER).

While specific CER policy details in a platform are outside the scope of this specification, here are some guidelines based on general considerations.

If the platform or drivers do not supportCER policies, it’s recommended to select UR Completions, which is the standard behavior when a device is not present.

If the CERstrategy relies on software detecting containment by looking for all 1’s returned by PIO reads, then a UR Completion may be the more appropriate selection, assuming the RP synthesizes an all 1’s return value for PIO

reads that return UR Completions. The all 1’s synthesis would need to occur for PIO reads that target Configuration Space, Memory Space, and perhaps I/OSpace.

If the CERstrategy utilizes a mechanism that handles UR and CA Completions differently for PIO reads, then a CA Completion might be the more appropriate selection. CA Completions coming back from a PCIe device normally indicate a device programming model violation, which may need to trigger Port containment and error recovery.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAF3CAYAAACYDAorAAAAT0lEQVRoge3MoREAIAwEwYQmsZSGpcpQAROL2Le38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMCf4AIptAXsuDjm/QAAAABJRU5ErkJggg==)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Selecting the DPC Trigger Condition

Non-Fatal Errors are uncorrectable errors that indicate that a particular TLP was unreliable, and in general the

associated Function should not continue its normal operation. Fatal errors are uncorrectable errors that indicate that a particular Link and its related hardware are unreliable, and in general the entire hierarchy below that Link should not continue normal operation. This distinction between Non-Fatal and Fatal errors together with the Root Port error containment capabilities can sometimes be used to select the appropriate DPC trigger condition. The following assumes that there is no peer-to-peer traffic between devices.

Some RCs implement a proprietary feature that will be referred to generically as “Function Level Containment” (FLC). This is not an architected feature of PCI Express. A Root Port that implements FLC is capable of containing

the traffic associated with a specific Function when a Non-Fatal Error is detected in that traffic. Switch

Downstream Ports below a Root Port with FLC should be configured to trigger DPC when the Downstream Port

detects an unmasked uncorrectable error itself or when the Downstream Port receives an ERR\_FATAL Message. Under this mode, the Switch Downstream Port passesERR\_NONFATAL Messages it receives Upstream without

triggering DPC. This enables Root Port FLC to handle Non-Fatal Errors that render a specific Function unreliable and Switch Downstream Port DPC to handle errors that render a sub-tree of the hierarchy domain unreliable. The Downstream Port still needs to trigger DPC for all unmasked uncorrectable errors it detects, since an

ERR\_NONFATALit generates will have its own Requester ID, and the FLC hardware in the Root Port would not be able to determine which specific Function below the Switch Downstream Port was responsible for the Non-Fatal Error.

Switch Downstream Ports below a Root Port without FLC should be configured to trigger DPC when the Switch

Downstream Port detects an unmasked uncorrectable error or when the Switch Downstream Port receives an

ERR\_NONFATALor ERR\_FATAL Message. This enables DPC to contain the error to the affected hierarchy below the Link and allow continued normal operation of the unaffected portion of the hierarchy domain.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAHoCAYAAAB0PK69AAAAWUlEQVRoge3MoREAIAwEwYQmsZSGpcrgcEwa2LO/8xFNGevUd90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAK8L7lYGzowq918AAAAASUVORK5CYII=)

**IMPLEMENTATION NOTE**

Software Polling the DPC RP Busy Bit

The DPC RP Busy bit is a means for hardware to indicate to software that the RP needs to remain in DPC

containment while the RP does some internal cleanup and quiescing activities. While the details of these

activities are implementation specific, the activities will typically complete within a few microseconds or less. However, under worst-case conditions such as those that might occur with certain internal errors in large

systems, the busy period might extend substantially, possibly into multiple seconds. If software is unable to tolerate such lengthy delays within the current software context, software may need to rely on using timer interrupts to schedule polling under interrupt.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADaCAYAAACb+QOvAAAAQElEQVRYhe3MoREAIAwEwYQmsZSGpcpQAROJ2be38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAMB3cAGfUASyvx43+AAAAABJRU5ErkJggg==)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Determination of DPC Control

DPC may be controlled in some configurations by platform firmware and in other configurations by the operating system. DPC functionality is strongly linked with the functionality in Advanced Error Reporting. To avoid conflicts over whether platform firmware or the operating system have control of DPC, it is recommended that platform firmware and operating systems always link the control of DPC to the control of Advanced Error Reporting.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAACoCAYAAADdE69lAAAAOklEQVRYhe3MMREAIAwEwQSTtEijRWVQADGw1/7ORzRlrFPPdc8c3QMAAAAAAAAAAAAAAAAAAADw6QKWKwRO6L9RAwAAAABJRU5ErkJggg==)

[**6.2.10.1**](6.2.10.1) **DPC Interrupts**

A DPC-capable Downstream Port must support the generation of DPC interrupts. DPC interrupts are enabled by the DPC Interrupt Enable bit in the DPC Control Register. DPC interrupts are indicated by the DPC Interrupt Status bit in the DPC Status Register.

If the Port is enabled for level-triggered interrupt signaling using INTx messages, the virtual INTx wire must be asserted whenever and as long as the following conditions are satisfied:

• The value of the Interrupt Disable bit in the Command register is 0b.

• The value of theDPC Interrupt Enable bit is 1b.

• The value of theDPC Interrupt Status bit is 1b.

Note that all other interrupt sources within the same Function will assert the same virtual INTx wire when requesting service.

If the Port is enabled for edge-triggered interrupt signaling using MSI or MSI-X, an interrupt message must be sent every time the logical AND of the following conditions transitions from FALSE to TRUE:

• The associated vector is unmasked (not applicable if MSI does not support PVM).

• The value of theDPC Interrupt Enable bit is 1b.

• The value of theDPC Interrupt Status bit is 1b.

The Port may optionally send an interrupt message if interrupt generation has been disabled, and the logical AND of the above conditions is TRUE when interrupt generation is subsequently enabled.

The interrupt message will use the vector indicated by the DPC Interrupt Message Number field in the DPC Capability register. This vector may be the same or may be different from the vectors used by other interrupt sources within this Function.

[**6.2.10.2**](6.2.10.2) **DPC ERR\_COR Signaling**

A DPC-capable Downstream Port must support ERR\_COR signaling, independent of whether it supports Advanced Error Reporting (AER) or not. DPC ERR\_COR signaling is enabled by the DPC ERR\_COR Enable bit in the DPC Control Register. DPC triggering is indicated by the DPC Trigger Status bit in the DPC Status Register. DPC ERR\_COR signaling is managed independently of DPC interrupts, and it is permitted to use both mechanisms concurrently.

If the DPC ERR\_COR Enable bit is Set, and the Correctable Error Reporting Enable bit in the Device Control Registeror the DPC SIG\_SFW Enablebit in the DPC Control Registeris Set, the Port must send an ERR\_COR Message each time the DPC Trigger Status bit transitions from Clear to Set. DPC ERR\_COR signaling must not Set the Correctable Error Detected bit in

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

the Device Status Register, since this event is not handled as an error. If the Downstream Port supports ERR\_COR

Subclass capability, this DPC ERR\_COR signaling event must set theDPC SIG\_SFW Status bit in the DPC Status Register and also set theERR\_COR Subclassfield in the ERR\_COR Message to indicateECS SIG\_SFW.

For a given DPC trigger event, if a Port is going to send both an ERR\_COR Message and an MSI/MSI-X transaction, then the Port must send theERR\_COR Message prior to sending the MSI/MSI-X transaction. There is no corresponding

requirement if the INTx mechanism is being used to signal DPC interrupts, since INTx Messages won’t necessarily remain ordered with respect to ERR\_COR Messages when passing through routing elements.

**IMPLEMENTATION NOTE**

Use of DPC ERR\_COR Signaling

It is recommended that operating systems use DPC interrupts for signaling when DPC has been triggered. While DPC ERR\_COR signaling indicates the same event, DPC ERR\_COR signaling is primarily intended for use by system firmware, when it needs to be notified in order to do its own logging of the event or provide firmware first

services.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAACoCAYAAADdE69lAAAAN0lEQVRYhe3KoQEAIAzAsI0nsZyG5cphsFPY1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAADgpwskJwROWh0xhAAAAABJRU5ErkJggg==)

[**6.2.10.3**](6.2.10.3) **Root Port Programmed I/O (RP PIO) Error Controls**

The RP PIO error control registers enable fine-grained control over what happens when Non-Posted Requests that are

tracked by the Root Port encounter certain uncorrectable or advisory errors. SeeSection 2.9.3for a description of which Non-Posted Requests are tracked. A set of control and status bits exists for receiving Completion with Unsupported

Request status (URCpl), receiving Completion with Completer Abort status (CACpl), and Completion Timeout (CTO)

errors. Independent sets of these error bits exist for Configuration Requests, I/O Requests, and Memory Requests. This

finer granularity enables more precise error handling for this subset of uncorrectable errors (URCpl, CA Cpl, and CTO). As a key example, UR Cpl errors with Memory Read Requests can be configured to trigger DPC for proper containment and error handling,while UR Cpl errors with Configuration Requests can be configured to return all 1’s (without trigging DPC) for normal probing and enumeration.

A UR or CA error logged in AER is the result of the Root Port operating in the role of a Completer, and for a received

Non-Posted Request, returning a Completion. In contrast, a UR Cpl or CA Cpl error logged as an RP PIO error is the result of the Root Port operating in the role of a Requester, and for an outstanding Non-Posted Request, receiving a

Completion. CTO errors logged in both AER and RP PIO are the result of the Root Port operating in the role of a

Requester, though the RP PIO error controls support per-space granularity. Depending upon the control register settings, CTO errors can be logged in AER registers, in RP PIO registers, or both. If software unmasks CTO errors in RP PIO, it is

recommended that software mask CTO errors in AER in order to avoid unintended interactions.

The RP PIO Header Log Register,RP PIO ImpSpec Log Register, and RP PIO TLP Prefix Log Registersare referred to

collectively as the RP PIO log registers. TheRP PIO Header Log Register must be implemented; theRP PIO ImpSpec Log Registerand RP PIO TLP Prefix Log Registerare optional. The RP PIO Log Sizefield indicates how many DWORDs are

allocated for the RP PIO log registers, and from this the allocated size for the RP PIO TLP Prefix Log Registercan be calculated. See Section 7.9.15.2. The RP PIO log registers always record information from a PIO Request, not any associated Completions.

The RP PIO Status, Mask, and Severity registers behave similarly to the Uncorrectable Error Status, Mask, and Severity registers in AER. See Section 7.8.4.2 ,Section 7.8.4.3 , and Section 7.8.4.4>. When an RP PIO error is detected while it is unmasked, the associated bit in the RP PIO Status Registeris Set, and the error is recorded in the RP PIO log registers

(assuming that RP PIO error logging resources are available). When an RP PIO error is detected while it is masked, the associated bit is still Set in theRP PIO Status Register, but the error does not trigger DPC and the error is not recorded in the RP PIO log registers.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Each unmasked RP PIO error is handled either as uncorrectable or advisory, as determined by the value of the corresponding bit in the RP PIO Severity Register. If the associated Severity bit is Set, the error is handled as

uncorrectable, triggering DPC (assuming that DPC is enabled) and signaling this event with a DPC interrupt and/or

ERR\_COR (if enabled). If the associated Severity bit is Clear, the error is handled as advisory (without triggering DPC) and signaled with ERR\_COR (if enabled).

**IMPLEMENTATION NOTE**

Use of RP PIO Advisory Error Handling

Each RP PIO error can be handled either as uncorrectable or advisory. Uncorrectable error handling usually logs the error, triggers DPC, and signals the event either with a DPC interrupt, an ERR\_COR, or both. Advisory error handling usually logs the error and signals the event with ERR\_COR.

RP PIO advisory error handling can be used by software in certain cases to handle RP PIO errors robustly without incurring the disruption caused if DPC is triggered in the RP. If an RP PIO Exception is not enabled for a given error, an all 1’s value is returned whenever the error occurs. If the error does not trigger DPC, software may be uncertain if the all 1’s value returned by a given PIO read is the actual data value returned by the Completion versus

indicating that an error occurred with that PIO read. If software enables advisory error handling for that error, instances of that error will be logged, enabling software to distinguish the two cases.

The use of RP PIO advisory error handling is notably beneficial if DPC is triggered in a Switch Downstream Port, and that causes one or more Completion Timeouts inthe RP as a side-effect, as described in Section 2.9.3 . If the RP handles Completion Timeout errors as advisory, this avoids DPC being triggered in the RP, permitting

continued operation with the other Switch Downstream Ports.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAFRCAYAAABJ+ewAAAAASElEQVRoge3KoREAIAwAsZYlsYyGZcpisF2Ay9tPxjoVXXvmaOcLAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD4GF5UHBaJr4VUWAAAAAElFTkSuQmCC)

The RP PIO First Error Pointer, RP PIO Header Log, and RP PIOTLP Prefix Log behave similarly to the First Error Pointer, Header Log, and TLP Prefix Log in AER. The RP PIO First Error Pointer is defined to be valid when its value indicates a bit in the RP PIO Status Registerthat is Set. When the RP PIO First Error Pointer is valid, the RP PIO log registers contain the

information associated with the indicated error. The RP PIO ImpSpec Log, if implemented, contains implementation-specific information, e.g., the source of the Request TLP.

In contrast to AER, where the recording of CTO error information in the AER log registers is optional, RP PIO implementations must support recording RP PIO CTO error information in the RP PIO log registers.

If an error is detected with a received Completion TLP associated with an outstanding PIO Request, the set of RP PIO

error control bits used to govern the error handling is determined in a similar manner. The DPC Completion Control bit determines whether UR or CA applies, and the Space (Configuration, I/O, or Memory) is that of the associated PIO

Request. For example, if the DPC Completion Control bit is configured for CA, and a Root Port receives a poisoned

Completion for a PIO Memory Read Request, the Mem CA Cpl bit (bit 17) is used in the RP PIO control and status registers for handling the error.

The RP PIO SysError Registerprovides a means to generate a System Error when an RP PIO error occurs. If an unmasked RP PIO error is detected while its associated bit in the RP PIO SysError Registeris Set, a System Error is generated.

The RP PIO Exception Register provides a means to generate a synchronous processor exception109 when an error occurs with certain tracked Non-Posted Requests that are generated by a processor instruction. See Section 2.9.3 . This

exception must support all such tracked read Requests, and may optionally support Configuration write, I/O write, and AtomicOp Requests. If an error with an exception-supported Non-Posted Request is detected110 or a Completion for it is synthesized, and its associated bit in the RP PIO Exception Registeris Set, the processor instruction that generated the Non-Posted Request must take a synchronous exception. This still applies even if the RP PIO or AER controls specify that the error be handled as masked or advisory.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

109. “Exception” is used as a generic term for a variety of mechanisms used by processors, including interrupts, traps, machine checks, instruction aborts, etc.

110. This includes any errors with the Completion TLP itself (e.g., Malformed TLP) or where the Completion Status is other than Successful Completion.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

The details of a processor instruction taking a synchronous exception are processor-specific, but at a minimum, the

mechanism must be able to interrupt the normal processor instruction flow either before completion of the instruction that generated the Non-Posted Request, or immediately following that instruction. The intent is that exception handling routines in system firmware, the operating system, or both, can examine the cause of the exception and take corrective action if necessary.

If an RP PIO error occurs with a processor-generated read or AtomicOp Request, and the RP PIO Exception Registervalue does not cause an exception, a value of all 1’s must be returned for the instruction that generated the Request.

**IMPLEMENTATION NOTE**

Synchronous Exception Implementation

The exact mechanism for implementing synchronous exceptions is processor and platform specific. One possible implementation is poisoning the data returned to the processor for a read or AtomicOp Request that encounters an error. While this approach is likely to work with those Requests, it might not work with Configuration and I/O write Requests since they return no data.

Another possible implementation is marking the response transaction for processor-generated Non-Posted Requests with some other type of indication of the Request having failed, e.g., a “hard fail” response. This approach is more likely to work with all processor-generated Non-Posted Requests.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADkCAYAAACliWVyAAAAP0lEQVRYhe3KoREAIAwAsZYlsYyGZUow2B6ey9tPxlg7qmbPVs4bAAAAAAAAAAAAAAAAAAAAAAAAAADAN+DZAVjABMaUt4K1AAAAAElFTkSuQmCC)

**IMPLEMENTATION NOTE**

RP PIO Mask Bit Behavior and Rationale

For a given RP PIO error, the associated mask bit in the RP PIO Mask Registeraffects its associated status bit setting, error logging, and error signaling in a manner that closely parallels the behavior of mask bits in AER.

SysError generation for a given RP PIO error is primarily controlled by the associated bit in the RP PIO SysError Register, but is also contingent upon the associated RP PIO mask bit being Clear. This behavior was chosen for consistency with AER,and also since it is poor practice to generate a SysError without logging the reason.

Exception generation for a given RP PIO error is independent of the associated RP PIO mask bit value. Usage

Models are envisioned where an RP PIO error needs to generate an Exception without logging an RP PIO error or triggering DPC.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAD+CAYAAAAHxESPAAAAQElEQVRoge3KoQEAIAzAsI0nsZyG5cphsFPY1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAfcAG6wAT8QF204wAAAABJRU5ErkJggg==)

Root Port error handling for tracked Non-Posted Requests with errors other than receiving UR and CA Completions is

governed by a combination of AER and RP PIO error controls. Examples are CTO111 , Poisoned TLP Received, and

Malformed TLP. For a given error managed by AER, the associated AER Mask and Severity bits determine if the error must be handled as an uncorrectable error, handled as an Advisory Non-Fatal Error, or handled as a masked error.

• If the AER-managed error is to be handled as an uncorrectable error (see[Section 6.2.2.2](#bookmark6)), DPC is triggered. The RP PIO SysError and RP PIO Exception bits associated with the Request type and Completion Status apply.

• If the AER-managed error is to be handled as an Advisory Non-Fatal Error (see[Section 6.2.3.2.4](#bookmark13)), DPC is not triggered. The RP PIO SysError and RP PIO Exception bits do apply.

• If the AER-managed error is to be handled as a masked error (see[Section 6.2.3.2.2](#bookmark14)), DPC is not triggered. RP PIO SysError bit does not apply, but the RP PIO Exception bit does apply.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

111. CTO errors have status and mask bits in both AER and RP PIO, though RP PIO has independent sets of bits for each of the 3 spaces. Other errors in AER have no equivalent errors in RP PIO.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[**6.2.10.4**](6.2.10.4) **Software Triggering of DPC**

If the DPC Software Triggering Supported bit in the DPC Capability register is Set, then software can trigger DPC by

writing a 1b to the DPC Software Trigger bit in the DPC Control Register, assuming that DPC is enabled and the Port isn’t currently in DPC. This mechanism is envisioned to be useful for software and/or firmware development and testing. It also supports usage models where software or firmware examines RP PIO Exceptions or RP PIO advisory errors, and

decides to trigger DPC based upon the situation.

When this mechanism triggers DPC, theDPC Trigger Reasonand DPC Trigger Reason Extensionfields in the DPC Status Registerwill indicate this as the reason.

If a Port is already in DPC when a 1b is written to the DPC Software Trigger bit, the Port remains in DPC, and the DPC Trigger Reasonand DPC Trigger Reason Extensionfields are not modified.

**IMPLEMENTATION NOTE**

Avoid Disable Link and Hot-Plug Surprise Use With DPC

It is recommended that software not Set the Link Disable bit in the Link Control register while DPC is enabled but not triggered. Setting the Link Disable bit will cause the Link to be directed to DL\_Down, invoking some semantics similar to those in DPC, but lacking others. If DPC is enabled, the subsequent arrival of any Posted Requests will likely trigger DPC anyway. If DPC is enabled, the recommended method for software to disable the Link is to write a 1b to the optional DPC Software Trigger bit in the DPC Control Register. If the DPC Software Trigger bit is not

implemented, software should disable DPC and useLink Disableinstead. If the operating system is performing this action, but DPC is owned by system firmware, the operating system should coordinate disabling DPC with system firmware.

DPC is not recommended for use concurrently with the Hot-Plug Surprise mechanism, indicated by the Hot-Plug Surprise bit in the Slot Capabilities register being Set. Having this bit Set blocks the reporting of Surprise Down errors, preventing DPC from being triggered by this important error, greatly reducing the benefit of DPC. See

[Section 6.7.4.5f](#bookmark62)or guidance on slots supporting both mechanisms.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAE3CAYAAACXVABHAAAARUlEQVRoge3KoQEAIAzAsI0nsZyG5cphsPOI1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD4BFwbPBW4tIwV2AAAAAElFTkSuQmCC)

[**6.2.10.5**](6.2.10.5) **DL\_Active ERR\_COR Signaling**

Support for this feature is indicated by the DL\_Active ERR\_COR Signaling Supported bit in the DPC Capability register. The feature is enabled by the DL\_ACTIVE ERR\_COR Enable bit in theDPC Control Register. The DL\_ACTIVE state is

indicated by the Data Link Layer Link Active bit in the Link Status Register. DL\_ACTIVE ERR\_COR signaling is managed independently of Data Link Layer State Changed interrupts, and it is permitted to use both mechanisms concurrently.

If the DL\_ACTIVE ERR\_COR Enable bit is Set, and the Correctable Error Reporting Enable bit in the Device Control register or the DPC SIG\_SFW Enablebit in the DPC Control Registeris Set, the Port must send an ERR\_COR Message each time the Link transitions into the DL\_ACTIVE state. DL\_ACTIVE ERR\_COR signaling must not Set the Correctable Error Detected bit in the Device Status register, since this event is not handled as an error. If the Downstream Port supports ERR\_COR

Subclasscapability, this DPC ERR\_COR signaling event must set theDPC SIG\_SFW Status bit in the DPC Status register

and also set theERR\_COR Subclassfield in the ERR\_COR Message to indicateECS SIG\_SFW. In contrast to Data Link Layer State Changed interrupts, DL\_Active ERR\_COR signaling only indicates the Link enters the DL\_Active state, not when the Link exits the DL\_Active state.

For a given DL\_ACTIVE event, if a Port is going to send both an ERR\_COR Message and an MSI/MSI-X transaction, then the Port must send the ERR\_COR Message prior to sending the MSI/MSI-X transaction. There is no corresponding

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

requirement if the INTx mechanism is being used to signal DL\_ACTIVE interrupts, since INTx Messages won’t necessarily remain ordered with respect to ERR\_COR Messages when passing through routing elements.

**IMPLEMENTATION NOTE**

Use of DL\_ACTIVE ERR\_COR Signaling

It is recommended that operating systems use Data Link Layer State Changed interrupts for signaling when

DL\_ACTIVE changes state. While DL\_ACTIVE ERR\_COR signaling indicates a subset of the same events, DL\_ACTIVE ERR\_COR signaling is primarily intended for use by system firmware, when it needs to be notified in order to do Downstream Port configuration or provide firmware first services.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAACnCAYAAAAsRR2wAAAAN0lEQVRYhe3KoQEAIAzAsI0nsZyG5cphsOOC1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAADg0wWWCgRONTYlZAAAAABJRU5ErkJggg==)

**6.3 Virtual Channel Support**

**6.3.1 Introduction and Scope**

The Virtual Channel mechanism provides a foundation for supporting differentiated services within the PCI Express

fabric. It enables deployment of independent physical resources that together with traffic labeling are required for

optimized handling of differentiated traffic. Traffic labeling is supported using Traffic Class TLP-level labels. The policy for traffic differentiation is determined by the TC/VC mapping and by the VC-based, Port-based, and Function-based arbitration mechanisms. The TC/VC mapping depends on the platform application requirements. These requirements drive the choice of the arbitration algorithms and configurability/programmability of arbiters allows detailed tuning of the traffic servicing policy.

The definition of the Virtual Channel and associated Traffic Class mechanisms is covered in Chapter 2 . The VC configuration/programming model is defined in Section 7.9.1and Section 7.9.2 .

This section covers VC mechanisms from the system perspective. It addresses the next level of details on:

• Supported TC/VC configurations

• VC-based arbitration - algorithms and rules

• Traffic ordering considerations

• Isochronous support as a specific usage model

**6.3.2 TC/VC Mapping and Example Usage**

A Virtual Channel is established when one or more TCs are associated with a physical resource designated by a VC ID. Every Traffic Class that is supported on a given path within the fabric must be mapped to one of the enabled Virtual Channels. Every Port must support the default TC0/VC0 pair -this is “hardwired” Any additional TC mapping or

additional VC resource enablement is optional and is controlled by system software using the programming model described in Sections 7.9.1 and 7.9.2.

The number of VC resources provisioned within a component or enabled within a given fabric may vary due to

implementation and usage model requirements, due to Hot-Plug of disparate components with varying resource capabilities, or due to system software restricting what resources may be enabled on a given path within the fabric.

Some examples to illustrate:

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• A set of components (Root Complex, Endpoints, Switches) may only support the mandatory VC0 resource that must have TC0 mapped to VC0. System software may, based on application usage requirements, map one or all non-zero TCs to VC0 as well on any or all paths within the fabric.

• A set of components may support two VC resources, e.g., VC0 and VC1. System software must map TC0/VC0

and in addition, may map one or all non-zero TC labels to either VC0 or VC1. As above, these mappings may be enabled on any or all paths within the fabric. Refer to the examples below for additional information.

• A Switch may be implemented with eight Ports - seven x1 Links with two VC resources and one x16 Link with one VC resource. System software may enable both VC resources on the x1 Links and assign one or more

additional TCs to either VC thus allowing the Switch to differentiate traffic flowing between any Ports. The x16 Link must also be configured to map any non-TC0 traffic to VC0 if such traffic is to flow on this Link. Note:

multi-Port components (Switches and Root Complex) are required to support independent TC/VC mapping per Port.

In any of the above examples, system software has the ability to map one, all, or a subset of the TCs to a given VC. Should system software wish to restrict the number of traffic classes that may flow through a given Link, it may configure only a subset of the TCs to the enabled VC resources. Any TLP indicating a TC that has not been mapped to an enabled VC

resource must be treated as a Malformed TLP. This is referred to as TC Filtering. Flow Control credits for this TLP will be lost, and an uncorrectable error will be generated, so software intervention will usually be required to restore proper operation after a TC Filtering event occurs.

A graphical example of TC filtering is illustrated in [Figure 6-4](#bookmark63), where TCs (2:6) are not mapped to the Link that connects Endpoint A and the Switch. This means that the TLPs with TCs (2:6) are not allowed between the Switch and Endpoint A.

Switch

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAWCAYAAAD9091gAAABnklEQVQokWWRz4raUBTGv5xoTLwJ91oUZ2WDiBbppnRjQaj4Al2570rog7gZGJiNr9CHKIKbQgsi7tKFg4SBZmeG0ZJ0xNzbRSfBTL7l+X6cP98BnlWtVr+YphkLIX4AMPBCPcZYtF6v1Xg8jmzbvs65Qoivs9lMKqVUEASqUqk8AbBTnxhjj9vtVqUaDAYHAJ8AgAC8q9Vq1Ol0so6TycQRQkxS4P1oNNIvRw6HQ+i6/gEAyDTNTrfbtS4B13URRdFVOv+N67q5pRuNBpIkMQA4pGlau9Vq5QBN09BsNmMAr0lKaXPOX+YCx3EkAJuklKVyuVwAPM/jAN4SAKWUKgDPeiQiOp9Op4LT7/cPAO6JiB7CMCwAYRgSgAdKkuTO9/2cmSQJ9vt9FcA9HY/HX77v55YIggCGYRwB/KXz+bzzPC+6BHa7HSzLCoD/v/i+XC51KWUGLBYLGcfxt6zAOf+9Wq2yd/d6vQOAjxnAGLudTqdPSim12WyUZVl/AOTSe8UYC+fzuWq325FhGJ8Ld5dKpVG9Xv/JOb8BoKX1f5zhoWI1BzUqAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADEAAAAcCAYAAADIrlf0AAAC8ElEQVRYhdWYT0iTYRzHP9veKe59X7c5gvxDlCyGhIdgmpREJRj9OUR2sS67RAjRoUMHT8XoYlAHD0lQCdKti0KjOsRSykORBhboyMYIswa2BN8m7N3T4c3h37lN9y4/x/f5feHzvM/L73neB3Y2bYCl1BKFUgE8BD4BVdZlAzbgBHCwFFZ5UA+8ARzAIWAuM+JwOG5WV1drsiwngWMl0duc08AP4BrrfEaNqqpqsVhMhEIhoShKHGPJ/hdswC3gG3Bk3QpZlu91d3fr4h9+v38eOGOiZDY8wHMgDOzesMrlcsVGR0eX5iB6enqE0+l8bJJkNvxAFLgDSNkK61RVTaZSqcwkJiYmRGVl5U8zLDfAAlwG4kBHLoG2pqamhFhGKpUSdrtdB8qLaboBFcAjjPbpyyVgBfZ6vd4VS2Wz2fB4PBqwZ9sVs7PUPisw2udkLiGprKys3ufzOQCi0SiTk0bO6XRaZ2dnLwAfiuO7hmaM1hkEegGRa1BSVdVbW1trARgbG6Ovrw+ARCJRDlzCvD2jEegCnuad9Hg8QwMDA2I1gUBAA65st2kxsFosFkmS1nav/v7+CuCq+Ur5YwV0XdfXDHR2diaBB6YbFYA1nU4nFxcX1xtLAwsm+xSEpGna9MzMDADDw8MMDg4CEA6HJeAscMAkl2bgOvAu36CUTCa/TE1NaYBDlmVqamoAWFhYAIgAZu3cv4BnQAAI5Rtub2lpWbFj67ou7HZ7CvNPsoeBGHCbTc5Kq9nncrm0dDqdmUQkEhGKosxtHi0Ku4CXwCuynVqXYQW+CiHmx8fHMw9DoRCSJL0oiuLmxIFTwGvgPXA0p5SiKPeDwWBmKVpbW+eB88XzzJl24DtwA+OFZ6XZ7XZr8XhcjIyMCFmWfwNqsQ1zpA54CwwB7qyVqqr2NjQ0aG63+48kSefMsMsDO3AXmMb4UdqQcuAicNIEqULpwGj5Xezg+yaA/cBH4AmglNhlSyxdnn0GqkrssmWOA5a/JKsWX5PGX0IAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAWCAYAAAD9091gAAABqUlEQVQokW2RMa/SYBSGn369pb23oS0tJiYs1MZcEhOnu7iRMDDdhc2FCQf/A7+D/+CggYGB0eBioomTCTIUTadLIPSmXCgVPgcFEXyXk7znOe+X7xz4q+eFQuGr4zjvgfzeVP9U3bKsD+12+6mu64+jKHqSpum7w6iqqq+q1epyt9vJOI6l4zgr4BpAADiO87LVal0pioJlWTQaDTRNu90H6IZhrKfTqdyr1+tJz/M+7YGbIAju5ZHiOJa5XC4DFAGUgyCQR7/Bsix0Xd8Cj4SqquVKpXLJiUqlUgqUhWma177va6eA7/sKUBaaphVd1z3tUywWVcAWiqLkNO0sgOFwaAAvBKCcdYHNZgNwIaSUaZZlZ0CtVlsDQ5Fl2WyxWJwBs9lsC9yL5XL5LQzDn6dAGIYSmIjtdhuORqPVKRBFUQ6YCGAyHo//2WSSJKzX6wvgDuDSMIx0Pp8fbtHv96XneV/g97lXpml+HAwGh4Rut5smSfLmYKiq+rperz9IKWWSJNJ13Qfg2fGzV/l8/ken05HNZjO1bfvt/5Z3Y9v2d9u2PwPO3vwFxZ+wUhjKXToAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAWCAYAAAD9091gAAABpElEQVQokW2RP8/SUBTGf721fSuVXko7yQINycvwbsa4MTGwuDC6kcjiN+Cj8BGc3k4MDCbGsOiicSIMJZGQGJKmaKFW/lwHBRF8lpM853eek3sP/NWd67qfXdd9Azw6mvqfeuM4zrt+v98wTfPxYrGo5nl+fxrVdf1ls9lcHw4HlSSJklJugFsAAVAqlV70er2CpmlIKel0OpphGM+PATeWZf1YLpfqqDAMled5H47AkyAIvqkzrVYrZZrmT0ATQLVer6uz1+A4DqZpHgBf6LpeazQaD7lQpVLJgaqwbfu2VqsZl0AQBBpQE4Zh+OVy+bKP7/s6IIWmaaZhXAUwHo8t4JkAtKsukGWZBlhCKZVvt9sroNVqZcBbsdvt4iRJroA4jvfAd5Gm6SSKot0lEEWRAmZiv9/PJpNJdgnM53MTmAlgNp1O//nJNE3JsuwB8BWgYFlWHsfx6RbD4VB5nvcJfp97Y9v2+9FodEoIwzBP0/T1ydB1/VW73d4opdR6vVae522Au/O1hWKxOB8MBqrb7eZSynv+o6eO43yRUn4E3KP5C6GzsG3LSYSJAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFAAAAAWCAYAAABXEBvcAAABUUlEQVRYhe3YsWqDYBSG4eNnFEWIQdvFqRWJDl1zG90KxdU7SLaCV9ExN9ApQ3HqXXQLraRLpoJIh6IlVTOkoR1jl8MBn+kfX77p5yj062o8Hj82TePS4CSz2SwZ/bx127ZXaZpexHGssFYJAqA+DngTRZE3n88VRRn266EBEZHjOLdJkljDeL1BISLNNM2PPM9Nz/O4g6S5BhFNXddthvH+BSCiS9/3W+4SoQ4DhmGoc5cIpcKyrGkQBAZ3iVCArutnjuNwh0gFADA0TeMOkQrgLhBORdu29W634w6RCqjr+r0oCu4QqYCqql7zPK+5S4QCiOhtvV5/cZcIdRhws9mo3CVCqSCil7Issd1uuWMkAojo2zCMpyzLuGMkOvwDy7J8WC6Xn2073BR6wvGCOrJt+3mxWERxHA+f6xMBuPt7gg4nk8mq67pztiJhgiC43wNrwFF2yuamwAAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFEAAAAWCAYAAAC40nDiAAABcUlEQVRYhe3YsUrDQBzH8d/9ubQXL20EaZ0ilI6ZXK0uHcRZpK8i+DJ9Azeh0MWuPkCWDhakEJRAtE3TEE1cLFoQqu1wHNxnS7jhy5HjT47hG3dd934+n58QUQljo3q9HkdRdMBXL6SUN77vH49GI8Y5ZyrjNJIwxrDaLEsI8RoEgd1qtZRWaeaJMXZEXw+n7Xb73WzgdggApJSXvV5Pqo7RFQGAbdtnnU6HNi02fkcAkGWZZ47y9giAtVwu9z3PU92iLQLgua6bWpalukVbBMBxHOdDdYjOCIBVqVRUd2iNAJRFUaju0BoByPM8N795OyAAURzHZqrsgACEi8WCJ0miukVbBKCQUr5MJhPVLdoiAOCcP47HY9Ut2iIAmM1md4PBIFMdo6vVVPabzeZDGIZ7jJlB/Q9r94lBmqZvw+FQaZGufn52F41G47bf79tCCGVBOiGi5263e7h2dmu12rUQ4qosS3O3+AfVajWaTqfnn2uwWqrgcEadAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFAAAAAXCAYAAACcTMh5AAABaUlEQVRYhe3YsWrCUBTG8S/nJteEiAGlQ6VDRIitQwb7HlkcpHRy6RP4JoJrX6Cb0Bcobj6AGNJ2aB1KcZKiGJNOth0KLVkOB/Kb7nCHP5czXI6BbwaACwAnKP3Xo3k8aa2HWutJEARbziJJer3e7fEBzyzLGs9ms0oYhhXWKlleCAAsy7oeDAYqDEPuIHEIAGq12lW/3y8nrwADgGfb9tt6vdaO43D3SDMiAOe+72/LxyuGALTa7bbBHSIVAWh1Op1y/Aoiz/MC3/fNv6+WfkNKKdd1Xe4OscgwDG2a5QAWRXmep4fDgbtDLMqybLvb7bg7xKLNZvO0Wq1y7hCpKE3TZLFYfHCHSEUAnuM4TrlDpCIAcZIklSzLuFtEIgCvSqn3+XzO3SISAcB+v7+bTqflX6aA4xLhsl6vPyyXS6fRaLAGCTP62sJUq9VJt9sdRlFkcxZJ0mw2xz/XWA6AG631KVeQNEqp+0+qqVDR1RLsXAAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFAAAAAWCAYAAABXEBvcAAABVklEQVRYhe3YP0vDQBjH8V+fC0mvlf4hDiKkoJFk6RxfRItzha4O3X0nLm7SQcQ30EFH30KXQGnnQqgUKrScJC4VdVBLl4cH7gMHN9zBl7vh4Er4EjSbzTul1DGsnQRBcOts51Sv1x/7/X7S6/UUa5UgruselrbziziO78fj8YHjOH9usn64JgBoNBqXg8HAHt4eCAAZYzrdbpe7RSQCcFatVikMQ+4WkQjAaRiG79whUhGAkziOXe4QqUhrHUVRpLlDpKJyuXzk+z53h1iklPI8z+PuEIvyPC/9v8z6DRVFsTHGcHeIRcaY1+Vyyd0hFq1Wq3QymWy4Q6QiALM0Te0B7okAzKbTqX1I9kQA0vl87mZZxt0iEgHYVCqVl9FoxN0iEgHAYrF4GA6Hb9wxEn1+36dZll21Wq1au91GURR27Daevz8e51rrp/V6XeO4SYmSJLn5ALTOL3G/vlL9AAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFAAAAAWCAYAAABXEBvcAAABTklEQVRYhe3YsUrDUBTG8S/HpBlCKCEidWxSzJb6Cq55ACHdupW+hHNWQcgj6OJW8SF8gEJLpKNDCR1MY0MTF4sOgrHL4cD9TXe4w58zHY6Gb5e2bT9VVeVAaSUMw1v9623atv2YJMl5HMesUZI0TZMfBng9HA7PJpMJNE1jjRKmIgBwXTcej8eWGt7/EQCjKIqrKIq4W0QiAIHrulWv1+NuEYkA9H3fb7hDpCIA/SAITO4QqciyrIvBYKAGeCTqdDqnjqN252MREZmGYXB3iEXcAdJRXdflbrfj7hCLyrJ8W6/X3B1i0Xa7XSyXy5I7RCoC8Dqfzz+4Q6QiAFmWZfqfP5VfEYDFZrPBarXibhGJAOxN03yezWbcLSIRAOR5fp+m6Xtd19w94hwuqCfdbvdlOp2Go9FILdct6bp+8/ME7TmO8wBAHQZb8jzv7hPd2FDqwPYU9QAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAXCAYAAAA2jw7FAAABmklEQVQokWXRPa8SQRTG8b8zcpfsEnbBQMhFIBeDhFwt7Ih0dMbEzsLPYvgIVIaK0lYLE3oLGio6chOCAYFGC4uLw47ycmyEwPKU8/wmMydHc553WutXInIH2LNGa/02m82um83mH9/3v0Qu4rmuez8YDMQYI6VSyQCvT8Gber1+L//T6XQklUp9Ora+739st9uHXmazmbiu+xvQACSTyZ+j0UhOUywWV8ALBcTW6/WjSqVy9qlarSbAEwU8DoLAxmKxM1CtVuNa6xsFlAqFwiY6Vrlcjnme91QBuXw+r6Igl8vhOE5JAVfxePxBFGy3W6y11wpQWusLMBwOWa1WtwrYbjYbiYJGo0Emk/mqAGuMuQBhGCIioQIW8/n8AiwWC4wxYwV8Xy6XV1EwmUxsGIYTBfyw1j40xpyB8Xj8F5gBkE6nv/X7/eMedrudBEEQAjcKwFr7udfrbU9HFJFfwPRw9rJcLq/2+72IiLRarZ3neR9On9S+74+73a5Mp1NJJBJr4Fn047eO41jf963nee+j5SHXwHPguLx/ipPEP5BDe3EAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAWCAYAAAD9091gAAABoElEQVQokWXPMa/SYBTG8X/f0hbfphQoEpkgUQYdGQizibMDCe4O7ITVxe/gh3BhkoHEsBETF2MiCwyXwmIIbTDm1lva0NeJ66U+4zm/k3MO/EtdSrk3DCMtFAp9ctFc1/08Ho+TxWKhbNv+DTx5CF54nhfFcayUUmo4HCbFYvE9gACwLOt1v9/XLcsCYDAYGFLKN/fjnud9n06n6pLT6aSklCegDqBZlhWHYageptvt/gJeCaAshNAqlcrV1e122wCaAmg1Go2Tpml5IE3TfCqAZqvVUvm/m80mjuM8F4Dtuq7IA8dxEEI4AjBM09TyYLlccjgcXgpAZVn234p6vY5hGLcCSJIkyfep1WqUy+WvAgj3+/05D4IgIE3TnwLYbrdbPQ82m805iqKVAHZBEDzKsuwKrNfruzRNbwRwZ5pmtNvtrsBqtcoAXwCYprmYz+f3zTAM8X3fAr4JgOPx+HEymdxewGw2w7btL0B8qT2WUsa+76vz+ax6vV6k6/rbq522bb/rdDp/RqNR5rruD6CQ/0wvlUofqtXqJ+DZpfgXKIqmkpUTWxUAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAWCAYAAAD9091gAAABlUlEQVQokWWRsW7aUBSGf5/ayOJa3GOQGjEhS1HKjkQkkLx3qJT3YGHumBcgS16BoRtDH4AwREjstJWCi6giFsvQCidg2adLIBj+8XzfPfeec4H3mMz8XWv9bJrmDU7jOM5tu92OB4OBKKX+AajmuG3b28ViISIi3W43cRzn/li4abVaf+Utk8lEtNbPB8rM/V6vt+eSpqkwcwzgkgDAMIy27/uHA0QE3/dTANcEwIjj+MLzvNyj6/V60bIsjwC4RGQwc07wPI+UUnUCUKtWq1vDMHJCrVaDZVlXBKCktc5O98LMyLKsRACsQqFwtrgwDBGG4Sc6I0eTAAABSHa73Zngui4qlcpPArBerVZnnaIoAhGtCcDv5XJpi0hOmM/nSJLkFwFYiUgWRVFOCIIg3Ww2PwgAisXicjab5YTpdPqSJElAAJCm6cNwODzALMswGo1MAI/72pdms7ne/+Z4PBZm/nPcUdm2/RoEgYiIdDqdnVLqLnenUupro9HY9Pt9UUqtAXw8Hf2D67rfyuXyk2man/fF/9+FqjYqkU/9AAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAXCAYAAAA2jw7FAAABn0lEQVQokW2SwcraQBSFPycmZhKjboQuCkkX0kVX1baC0BeouCi49SW67AO4tc/Rt+hKuv/RRZEm/gWhRQoxVTQzmS6skEjPbu589945h4GqAuA1IPmP3CAIvne73VOr1foKiGprEHyaTCZHpZTp9/t/pJQfyvd1KeVxu90aY4xZLpem0+n8KANve71eav5Ja23a7fYJeCYAPM+bTKdT70YLIRiPx8ayrHcCwPf9V4PBwCqPHA6HstlsvhQAWusoiqLKo8MwxHGc5wLgeDw+uQeiKEIpFQL4juPkRVGYsvb7vXFd9yQA13EcXavVKhOklGitbQHUhRDmPlbLssjz3BJAYYyp3QNFUVwtAxellLgHLpcLjUYjF0Cqta5lWVYBdrsdruv+FoDxPO9nkiQVIEkSbNt+FAC2bT/GcVwB4jhGa/1NAJzP54f1el0BVquVyrLs4XZ+PxqN0nJQYRgeuP4uAALXdS9pemU2m43xfT8FxM3eQUr5ZbFYKID5fH6u1+ufgaK89qnneYfZbKZ83/8FtO+zAXhjWdZH4MWt8BcKDLrMM3UAMwAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAWCAYAAAD9091gAAABmklEQVQokWWRMY7aQBSGf489o8Fjgm25ShpLWIrIGVKkiFikFYfYC+QopMgFaMMBqIhEulCn2KUJdhMqoiCvR+ux8UuxYmU7fzfzfXrz3hsbrXie92k4HH4BoOu6/ole3vu+r5fLJSmlNIC3Her7/sNqtSIiosVi0YRh+K3NXyulnqqqIiKi0+lEUsoSgGQAYNv27XQ6vTiOAwAIwxCTyeQJwAcGAKPR6GY2m7ntkvP5/JWU8llgjCVJknR6Go/HUEpNGAAYY97EcdwR4jiGZVljAHAcx6nLsqR2siwjz/P+AkDgum6XElGe5ySEqBgAbtt2098a5xzGGIcBsCzL6vOXMADV5XJhfVDXNTjnNQNQGGOcpum+kuc5OOclA1AKIR6Px2NHyLIMg8HgyABASvk7TdOOkKYpGGMHhucufx0Oh/8ErfU9A4Dz+fx9u92WbWGz2TwWRfHjen4XRVHRNA0REWmtr98dXse7N8YUu90OALBer+G67gOAPy8lhRB3SZIU+/2eoijSAD72d2MFQfBVCFEGQfD5evkPf8i9ck7wn5MAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAWCAYAAAD9091gAAABnklEQVQokWWQP2/aUBTFz3v2e/I/jAF5qFQJJAhC+QhZ0gFVQZX4El37VRiqzuwsXVkqBrp0YI2ULMRmCQtqJYhx3sP4dqkrm5zt3vPTOVfXQEme533xff8rESVZlt3jQjf1ev04nU7Jdd0EwFXFDYLgYTabERHRZDLJm83mj7L/znVdpbUmIqLdbkeWZb0CsDgAGIbxaTgcnoQQAIBWq4XBYKAA3HIA8H3/42g0csuR4/G4JqX8UCRc9Xq9yk3dbpfVarVrDgBa6/edTqcCtNttMMa6AGCappkppaisOI7J87w/ANBwHKfqEtHhcCAp5YkDEIZh5JdfE0JAa21yAIwxdumj2HEAp/P5zC+BLMsghMg4gERrbeZ5tWW/30MIoTgAJaV82W63FWCz2cC27S0HAMuynuM4fgMwxqKi+ymKogoQRRHSNH3k//p+LpdLVQYWi8VLkiS/ivk6DMMkz3MiIkrTlGzb1gCaRcWDUuq4Wq0AAPP5HI7jPAL4/T9SSvm53+8n6/WawjA8mqZ59+Z5jUbjuxAiC4LgW7H8C2SuwIjZv6ypAAAAAElFTkSuQmCC)

TC7

|  |
| --- |
| Root  Complex  TC[0:1]  TC[2:4]  TC[5:6] |

Link

|  |
| --- |
| Endpoint A  TC[0:1]    TC7 |

![](data:image/png;base64,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)

VC0

VC3

TC[0:1]

Link

TC7

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFEAAAAWCAYAAAC40nDiAAABeUlEQVRYhe3YsUrDQBzH8d9dL+mladri0gxqodCO7i0GB3cHwT6JD+DTFN9A6dQuPkBdCxakBEEloc1JjCYurbVDKXY5/pDPduECX44LfwjDWqFard4vFovzLMuQ281xnCAMwwOxemBZ1nW73e4Oh0NWLBZ1tlESCSHAlgshpQzH43Gp1WpprSLmmTF2zJeLbqPR+M4PcD8cAGzbvuz1eiXdMVRxALAs68zzvILuGKo4AMRxfNRsNnW3kMUAGEKID6VUwTAM3T3U/A6Ww1qtFucHuD8OwCmXy1+6QyjjAAzTNHV3kMYBZGma6u4gjQNIkiRhO3fmtuIA3oMgEDt35rbiAHyllKGU0t1CFgeQ2rb9Op1OdbeQxQFACPE0mUx0t5DFAWA+n98NBoNP3TFUrabySb1ef/B932YsH9T/sPE/8TGKIjUajbQWUfX32l24rnvb7/ctKaW2IEoYYy+dTsfd+HYrlcqNaZpXWZbxbS/m1qSUb7PZ7PQH+ylefAkjivoAAAAASUVORK5CYII=)

VC0

TC[0:1]

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFEAAAAXCAYAAABzjqNHAAABcElEQVRYhe3Zv0rDQACA8e9Om1yvCrVQA1K0LyB2cWlx9gXq5Gv0Dbr3EdwL0kmfwrUo1KGg4B/o0SJF0qQ1TlELglWH4yC/KRwZPpK7S0gEy/aAQ0CSWcUrcCG+DGxrrW/r9bpQStmKckqhUHjpdruVj4FisXjZarVmSeY37gDSmbillHoyxnhaaxs31VX3QojddO87bjQas+wC/o0EKJVKJ81mc9N2jKvSmbhfq9WshrhMAoRhuFOtVi2nuEsCG/P53A+CwHaLsyRQKZfLoRDix5Mz35OA8n3/zXaIyySwlsvlbHc4TQKLOI5tdzhNAlEURdmG+A8SeBiNRvkkSWy3OEsCEyA2xthucZYE0Fo/DodD2y3OkgBCiJt+v2+7xVkSwBhz3uv1prZjXJU+lQOt9d14PPY8z7Ma5Jil74nPnudddTqdhdUkR62nB5PJ5LTdbl8PBgOplMreG1eQz+d9+FzOqQPgiOxv36qmwNk7+/SAGzBZGDAAAAAASUVORK5CYII=)

VC1

TC[2:4]

Link

|  |
| --- |
| Endpoint B  TC[0:1]  TC[2:4]  TC[5:6]  TC7 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFEAAAAWCAYAAAC40nDiAAABaUlEQVRYhe3ZsUrDQBzH8d/9k6NpjpLQTFUwSLo4S5+guAk6dNTV13H0ARy72KmLkAdw6gsUqigtxYKhxaa9Ehdb3SxxOP5wny2ZvhwEfuQEfogwDO+KorgAQLD+VK1WZ+Px+MTdvnAc56per1/3ej3f8zyTbWwIITbNZhPi+5mUUrM0TYNWq2U0jJkXIcTR9rM9jaLIsQdYDgGA53mXnU6nYjqGKwIApdRZu92WpmO4IgDQWsdJkphuYYsAOIvFIorj2HQLWwTgoFarreysKY8AhEEQaNMhnBEA6bpuYTqEMwJ2g9sqiQCstNb2IP+BAHxkWeaYDuGMALxmWVbJ89x0C1sEYKOUmo1GI9MtbBEASCmfh8Oh6Ra2CADm8/ljmqZ2K5ZEALBcLh+63e6n6Riutv8TnyaTCQaDgdEYrnb7UEp5kyTJbb/ft9cD+3trNBqHv0e2CMPwfr1en8NeVO3F9/336XR6/AXlplbWAx9X1gAAAABJRU5ErkJggg==)

VC2

TC[5:6]

VC0

TC[0:1]

VC3

TC7

VC1

TC[2:4]

VC2

TC[5:6]

TC7

VC3

![](data:image/png;base64,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)

Mapping

OM13828

Figure 6-4 TC Filtering Example

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[Figure 6-5](#bookmark64)shows an example of TC to VC mapping. A simple Switch with one Downstream Port and one Upstream Port connects an Endpoint to a Root Complex. At the Upstream Port, two VCs (VC0 and VC1) are enabled with the following

mapping: TC(0-6)/VC0, TC7/VC1. At the Downstream Port, only VC0 is enabled and all TCs are mapped to VC0. In this

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFcAAAAYCAYAAACPxmHVAAABaklEQVRoge3ZMUoDQRTG8W8fkx3JZnbZSmIRzEIQsRBT2biNbJGcIanSpfIUqYRcwAN4hxwgYGOlhUIS0kbYBTFgMsvYKNobePDIr3rT/XnlGw+/LqMourfWxtj7tzRNr7zvOTDGvI7H43q322WNEuRUAYDW+ibLsngwGHAHSWIJAIIg6A2HwwPuGmk8AIfVanWZ57nv+z53jyQtAnCdpunnfrG7R0qpk3a7HXCHSERhGJ4lSULcIRIREbWazSZ3h0i02WyOGo0Gd4dIZK3VtVqNu0Mkcs6pSqXC3SESAXDOOe4OkYiIyu12y90hEiml1kVRcHeIREqp5WKx4O4QicqyfJnP59wdIlFRFE+z2cxyh0hEAJ6n0+maO0QiD4DRWr+tVivfGMPdI0mLALwbYx4nkwl3jDgEAHme341Go4+yLLl7RPn5oKQwDB/6/f5Fp9PZnx93IIqic+/P+ziO41ulVJ2tSJAkSXpf3WVXrzhXP1QAAAAASUVORK5CYII=)![](data:image/png;base64,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)example while TC7 is mapped to VC0 at the Downstream Port, it is re-mapped to VC1 at the Upstream Port. Although the Endpoint only supports VC0, when it labels transactions with different TCs, transactions associated with TC7 from/to the Endpoint can take advantage of the second Virtual Channel enabled between the Switch and the Root Complex.

Link

Switch

Link

|  |
| --- |
| Endpoint  TC[0:7] |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFgAAAAZCAYAAAC1ken9AAABm0lEQVRoge3ZP2vCQBjH8d/z5C4mIbku3TIUQRCKroU6+BIKbq59AwWhU8cufTMODkLXDq5dU3DRjpVSgn9QT8ROikIphSoHx33GQODLM4TncoRDJd/3b6WUCs5/LWez2T3tPSgkSfLWbDYvyuUyG8uyhOd5y1arFewGHMfxU71ev+t2uxER/fau8zcTIlLbSZJSatTr9c6r1arRKotMiEhtPwWXQRBElUrFaJGNGACklDeNRsNzn4bjYwBQSl3XarWC6RgbMQAQUalYLJpusRIDwHw+T92AT4MAhFLKyWKx8Jjd+ntEuy3iLIoi7YZ7GgzAF0JsTIfYigEwEbkBnwgDWK3Xa7cAnwgDWGitPdMhtmIAX6vVyptOp6ZbrMQANlEUfQyHQ9MtVmIAEEK8DwYD0y1WYgDQWmf9ft90i5UYAMbj8XOn0xmbjrHRdj1LgiD4HI1GfpIkRoMscvDDfRKG4Wu73TZaZKP9A8aVUuoly7IwTVNjQRY5uJMDAMRx/Ki1fhBCrE1V2cL3/WWe5+qnI3IIwN1uHEf+DQ0KXyGmmPS6AAAAAElFTkSuQmCC)

VC0

TC[0:6] TC7

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFsAAAAYCAYAAACV+oFbAAADFElEQVRoge2YT0sbWxjGn5yTmSTNTDJWLBSijrkWryi4sBaD7SYrXVwVItwPIK4ueJfdFnRR6CeoX+EuXLjIdXlBcClWJY2BzoSQXv9t5Cbz73Tm3I0RQ1IoESZ0mB+8i3nel+HhmRnmnBNBO5OSJP0piuJThPSM67oJznnGcZwdy7I+AvAAIPJgJiHL8ueNjY2Rqamp/rgMAIwxbG1tYW1tDcVi0ajVau9M0/zQNiRJ0vuVlZWm53k8pHe2t7d5oVDgnHNeLpd5Mpk0ADx7mHUklUpdHR0d9dnqz8/09DQ/PDy8v15eXm5QStcBgNyF/asgCMmZmRlfPrWgUq1WcXl5ibm5uXutUCgk0+n078Bd2IIg/La6ukojkch3bhPyIxSLRSwuLoJSeq8tLS3BMIw3AAQCALIsv8rlcrF+mQwKZ2dnmJ2dbdOGhoYgSZILIEMAgBDyYmxsrB/+AoWu6xgdHe3QR0ZGvgFQCQBYlpUJw348uq5DVdUOfXx8PIq7sAXbtpXh4WG/vQWO773ZExMTT6LRaJYAkERR/BaNRv13FyA452g0GlAUpaOnKEokHo8PEgAipdT1316wYIxBEAR0W9HV63Uwxl4SACRc8j0ez/O6Bg0AlUoFtm3PEQCO67qk61TIDyMIAhhjXXv5fB6pVGqHALAcx6Gcc3/dBQxKKSilsG27o2eaJhhjTQKgSSllNzc3/jsMGJlMBrVarUPXNM02TVMjAJBIJL5qmua7uaChqip0Xe/QK5WKDUBv7SC1MOzHo6oqqtVqh65pWgStsJvN5kmpVPL8Nhc0stksyuVym+Y4Di4uLuJohW2a5t+7u7uNfhgMEvl8Hvv7+23awcEBksnkFwD/tZZ8/5yfn8eur699Nxgk5ufnUa/X236Se3t7zDCMvwCgdfDqyrL8emBg4JdcLhfucHqEEIKTkxNcXV1hYWEBlmVhfX3dvr29fQvg34ezk5IkGaenp9zzvLB6rFKpxAcHB/nx8THf3NxkiqLsd30y8Xj8j1gsZgHgYfVelFIuiiJPp9OfADxv5fs/FXAkJnj7t+wAAAAASUVORK5CYII=)

VC0

TC[0:7]

VC1

Mapping

|  |
| --- |
| Root  Complex  TC[0:6]  TC7 |

OM13829

Figure 6-5 TC to VC Mapping Example

**IMPLEMENTATION NOTE**

Multiple TCs Over a Single VC

A single VC implementation may benefit from using multiple TCs. TCs provide ordering domains that may be used to differentiate traffic within the Endpoint or the Root Complex independent of the number of VCs supported.

In a simple configuration, where only VC0 is supported, traffic differentiation may not be accomplished in an

optimum manner since the different TCs cannot be physically segregated. However, the benefits of carrying

multiple TCs can still be exploited particularly in the small and “shallow” topologies where Endpoints are

connected directly to Root Complex rather than through cascaded Switches. In these topologies traffic that is

targeting Root Complex only needs to traverse a single Link, and an optimized scheduling of packets on both

sides (Endpoint and Root Complex) based on TCs may accomplish significant improvement over the case when a single TC is used. Still, the inability to route differentiated traffic through separate resources with fully

independent flow control and independent ordering exposes all of the traffic to the potential head-of-line blocking conditions. Optimizing Endpoint internal architecture to minimize the exposure to the blocking conditions can reduce those risks.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAE3CAYAAACXVABHAAAASUlEQVRoge3MoREAIAwEwYQmsZSGpcpQAROH2re38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMAfcAFTswVsit6M6AAAAABJRU5ErkJggg==)

**6.3.3 VC Arbitration**

Arbitration is one of the key aspects of the Virtual Channel mechanism and is defined in a manner that fully enables

configurability to the specific application. In general, the definition of the VC-based arbitration mechanism is driven by the following objectives:

• To prevent false transaction timeouts and to guarantee data flow forward progress

• To provide differentiated services between data flows within the fabric

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• To provide guaranteed bandwidth with deterministic (and reasonably small) end-to-end latency between components

Links are bidirectional,i.e., each Port can be an Ingress or an Egress Port depending on the direction of traffic flow. This is illustrated by the example of a 3-Port Switch in [Figure 6-6](#bookmark65), where the paths for traffic flowing between Switch Ports are highlighted with different types of lines. In the following sections, VC Arbitration is defined using a Switch arbitration model since the Switch represents a functional superset from the arbitration perspective.

In addition, one-directional data flow is used in the description.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAD4AAAAVCAYAAAAeql2xAAAEbElEQVRYhdWYT0gcVxzHP/PnzZ9djNFGE3Q3rClE7cG2EVpSSqHVEAw1hvbSg0R6LQGvSaCBHoJ3A4Uk0HtK00PBUsFDb7E2mhZRNmyJ2awa/2UNRN3deTPzeljXlmBajW62/cCXx7xlH7/vm3lv5vs0yoMDxP6mKsACxHNSgNxGT4FZIAPMbfbtK9oe/lsLvA28BTS5rvu6YRgJ3/cb8vn8AQAhRFhXV+dVV1crIQRCCCzL0kqtUgrP85SUcquVUrK6uqo9efLE9n1f0zQN27ZXhRDzvu/P5HK5B8AD4N6mnpXTuAa8AXQ5jvOBruvvbGxsHLYsK2xtbfVaW1vF0aNHjVgsRjwe39KhQ4fQdf1l6iIIAhYXF8lkMszOzm616XTan56e9lOplC2l1KLRaEZKOeZ53s/AjxQnZU/GdaDTNM1PhRDncrlcfUtLS/7UqVNOe3s7J06coKWlBSHESxnbK4VCgampKcbHxxkfH2d4eLjw8OFDOxqNPsrlct+HYfgtMEpxOe2IaqA/Eok8siwr6OnpkTdv3lSZTEb910mlUmpwcFB1dHQUDMMII5HIFNBHcc95IRrwuWVZ60eOHCkMDAyo5eXlSnt5adLptLp48aKqrq72bNteAk5vZ7rGdd1hx3H8a9euKSllpeveNzY2NtSlS5eUYRihEOIGYG7dacdxfjh+/HghlUpVus6ycefOHVVTU+Ppuv5Vyfhntm37yWSy0rWVnaGhIWUYRgi06cC7XV1dqrm5eaeb3/+WM2fO0NDQUADadSA7OTkZep634wFWVlZ4/Phx2QosFwsLCywvLwsgqwNfz83NPbt8+bJSamevvOHhYUZGRspa5H4jpaS3t1dqmnYPGCr1f2Sapnf27Fm5uLj4r2ult7dXnT9/vuxrcr+YnJxUbW1tBdu2s0Di+Ulpdl33t4MHD3pXr15VS0tL2w4ShqGqr69XjY2Nr7j83ZNMJtWFCxdCIUTgOM53wGsveiJM4ItIJJK2LCvo6+vzR0ZGVD6f3xrs7t27iuJnoJqenq6gre1ZXV1Vt27dUp2dnR6gXNcdBbp3uiR04LTruj+Zpild15Xd3d3e9evXVX9//5bxwcHBSvtUuVxOjY2NqYGBAXXy5Mm8YRihbdtrQohvgDdfZHAn6SwKfGia5sebYeVw6YempiauXLnCsWPHiMfjNDQ0YNv2Tid3V6ytrW0ltPv37zMxMaFGR0cLqVTKDoJAi0QiyfX19dsUE9ovQPBP4+02jx8AsoCxee27rrvieV5dEAQGQG1trdfY2BgkEgkzkUiIWCxGVVUVlmVRyuQlKaUoZfDNTI6Ukmw2SyaTYWZmxkun08H8/Ly5trYmAIQQnmVZjzzPG5VS/gpMAL+zy1y+W+OfALef63uP4gwfpnjaEt9UzLKsJsuymiiewAillKmUKrUmoDRN8zclNU3zKZ62ZPP5/B++76f56ySmpKfsImruFzeASeAc0AMkgS9fdRGVoIPixlfCBN6vUC174k9W91yZvo4rsAAAAABJRU5ErkJggg==)

![](data:image/png;base64,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)![](data:image/png;base64,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)PCI Express Link

|  |
| --- |
| TX |

|  |
| --- |
| RX |

Egress

|  |
| --- |
| TX |

|  |
| --- |
| RX |

Egress

|  |  |  |
| --- | --- | --- |
| Egress |  | Ingress |

|  |
| --- |
| TX |

|  |
| --- |
| RX |

Express Express

Ingress

PCI

PCI Link

Ingress

Link

3-Port Switch

OM13830

Figure 6-6 An Example of Traffic Flow Illustrating Ingress and Egress

[**6.3.3.1**](6.3.3.1) **Traffic Flow and Switch Arbitration Model**

The following set of figures ([Figure 6-7](#bookmark66)and [Figure 6-8)](#bookmark67) illustrates traffic flow through the Switch and summarizes the key aspects of the arbitration.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKgAAADfCAYAAABibJjNAAAQrklEQVR4nO3dfbBdVXnH8W9u3iRUAhQILzFAsEQtWDuWl0YEkcRE4FFpoViSUaSIkGZCq4zSiEIFFTpojECVYogKxAIVSp5EUqItAgF5M4QEBUwmQBCGl9CQYLgkuff2j7VPeu6++9x79j5r77X3Oc9n5g7hZu+1HobfrHP2y1prGCY4Ve0C9gLGAXsCo4CR0U8f8BawLfp5DVgnItvCVFusYaEL6ASqOh74U+DdwP64IO4b/XMcsDcwPEWTPcBzwNMJP8+KSJ+34gNr+4Cq6mHAh4F3AX8C7IELQw+wHvgNsBJYJiLdLfa1Py6I9T/vAca20m5KrwBLgMXAXSKytcC+vWvLgKrqWGAOcCYwscnTNgG3At8VkTVN9jMRmApMAT6E+5gukzeBn+PCqiLyUuB6UmurgKrqMOB84BKyj1o7gKuBi0Vkc6z90cBJwHRcKA/OXGzxeoEVwL+IyJLQxTSrbQKqqrsDP8GFx4fngY+LyK9V9UjgM8DpuK8IVfdr4DLgP8v+fbUtAqqqY4DlwGTPTf8eWAcc67ndslgNfB24VUR6QxeTpCt0AZ78K/7DCXAA7RtOgMOBfwfWqOpHQheTpPIjqKoeDdxPG/y3BNYHfAuYKyLbQxdT0w4j6OewcPowDLgAuF9V3xm6mJrS/o9V1T1xV+KjcXVuB14VkU2x414A9iu+wrb2BjBLRG4IXUjwgEa3ho4ATsDdTJ+Eu6G+Z4NT3sBdYa/DXY1+pYAyO9UPgbNFpCdUAUECGj17ngZ8AjgZ9/jPlNNC4O9C3Y4aUWRnqjoCmAHMBQ4tsm+T2WdwT9k+H6LzwkZQVZ0BfI3mHz2acvmqiFxadKe5BzR6Ln4t7imMqbbZInJNkR3mGlBVPQp3I/igPPsxhekDponI8qI6zC2gqvqXuMePu+bVhwliLXCYiLxVRGe53KhX1cOBpVg429E7gQuL6sz7CKqq44DHcG+Mm/bUjRtF1+XdUR4j6DexcLa7t+H+P+fO6wiqqkcAD/pu15TSDmCiiGzIsxPfI+jlWDg7xQhgVt6deAuoqu4BHOerPVMJM/PuwOcIOpV0U2dN9Y2PZs3mxmdAp3hsy1THR/Ns3GdAx3tsy1THX+TZuM+AjvbYlqmOXN++9xnQ1z22ZaqjMgFd7bEtUx27qerIvBr3GdAHPLZlqiW3F999BnQFbr6Q6Sw7ROTNvBr3FlAR2YKbZGU6S67XHr4fdc7HTQ82neOhPBv3GlARWQsUPm/FBLU0z8bzet3uwRzaNeWU61KO3gMqIjsAAZ7y3bYpnTUi8myeHXgPqKruh1vSrzTr+5jc5L4Qrrf7V9ESNucBVwB/5KtdU1rbgO/l3YmXgKrqIcAC7H3QTrJQRJ7Lu5OWP+JVdTbwOBbOTrIN9zUud5lHUFUdBXwft3aP6SwL8p6LVJMpoKq6N3A78AG/5ZgK6Aa+UVRnqQOqqocCdwEH+i/HVMBFIvJ8UZ2lCqiqHojbGOod+ZRjSu6XwLwiO2x6inB0f/Ne4JD8yjEltgV4r4g8U2SnTV3FR1OKl2Ph7GT/UHQ4ofnbTAtwG6OazrRIRK4P0fGQAVXV84BTCqjFlNO9wFmhOh/0O2g0Kf9h3GJRpjOtxWVgdfTzeBFPkGoaBjR6tv4QOc97NpW0Efhv4E5gmYi8mFdHgwX0NOCWvDo2baMPuBu4CrjD96a0iQGNtot5AtsqxqTzDG6b7+t97avU6CLpTCycJr2DgB8A96iql7s+jQKa+7qPpq0dA6xU1TNbbWhAQFV1EvDnrTZsOt5IYKGqXtRKI0kj6CdbadCYmEtVdW7Wk5MCajvCGd++pqrHZzmx31V8tG3hpgbHGtOKl4B3iUiqfMVH0FyXczYdbRwZLr7jAbUXQkyezlfVVI/NLaCmSPsAH0tzQjygf+yvFmMSTU5zcDygts68ydtRaQ6OB3Srx0KMSZLqQjweUFtn3uQt1Rbt8YD+BPD6upQxMd1pDu4XUBH5PfA/Xssxpr+X0hyc9KjzMk+FGJPkvjQHDwioiNyNbYZg8rMszcGN3ge9AHi19VqM6acXt2xS0xIDKiIbgS/4qMiYOjeJyCtpTmg4L15Efgz8rOWSjHG6gS+nPWmohRtOx82JNqZV87KsKTpoQEXkDeBEbMcO05q7gIuznNjU6naqOgG3F+f4LJ2YjvYIcHw02KXW1OJh0VIn04DXsnRiOtYK4MSs4YQU64MCqOrRwC+AMVk7NB3jdeBYEXm8lUZSBRRAVacDi3HTSo0ZTDfwT8D8rCuNpA4ogKqeAdyY9XzTcZYDZ4rIC2lPzLRPkogsAs4FerKcbzrOVGC1qv512hNbGgFVdSZwQyttmI6zADg32nR4SFk/4scAV+IWGdslSxumo90OfFJEtg11YJaLpInAbcCfZSjMmJolwKki8tZgB6W9zbQb7qnSvi0UZkzNfwGfEJGGb9mnvUi6CAun8WcasCT6ypgozUZeewIvAqM8FGZMvbuBj4jI9vhfpBlBj8LCafLxIeDSpL9IE9AjvJRiTLIvquoJ8V+mCegEj8UYEzcMuEFV96r/ZZqAZnrqZEwK+wH/Vv+LNKFL/Ta0MRmcoqo790hIE9A7cyjGmCRfrP0hTUAfBJ71X4sxA5wWPbFsPqDR+3yfz60kY/7fcGAmpLzwEZHbgEV5VGRMzHTI9rLIcOB64FO+KzKmTi+wW+pbRyLSg3vN7hLPBRlTrws4cETas1R1d+BCYI73kozpb0KqgKrqcbg95PfJpx5j+hnZ9Ee8qs4Bfo6F0xRn05AjaLTx0rXYRZEp3sZBr+JVdQ/clNH3F1OPMTttBcY2/IhX1S7gJiycJowVIrJjsO+gFwMfLaoaY2KWQ4MnSao6DfhKoeUY019yQKMnRfOxZW1MOC8DqyB5BD0LmFRoOcb0t7i22FhSQGcXXIwxcdfV/tDvY1xVD8P26zRhPSYiDd+oP6ngYoyJu67+X+IBPbzAQoyJ24pbd3aneEDfU1wtxgxws4hsrv9FPKC7FViMMfX6gKviv4wHdMj1Go3JyS0isjL+y3hAbQNZE8J23MqJA8QD+kj+tRgzwA9EZG3SX8QDmmqzeWM8eIVBtklMCmim/WyMyeizg23R3S+gIvIyoLmXZIyzUETuGOyApGfxV+RUjDH11gPnD3XQgICKyP3AvXlUZEzkNdwms1uGOrDRG/XnAH/wWpIxzpvAySLyZDMHJwY0OvnvfVZlDG7rzNNF5IFmT2g4J0lEfgR830dVxuBeBDlNRFJdhA81L34WbhGnWVmrMga3fZGIyKNpTxxy3pGqDsNdNH0gQ2HGrMJ953w+y8nNLH1zBjA5S+Omo/UA84DJWcMJQ4ygqjodd+M+9Sp4pqOtAs4WkZbf7WgYUFXdG3gC2LvVTkzH2AJ8A7iy2f3ghzLYyHgNFk7TnB5cMOeJyP/6bLjRyiKnAqf57Mi0teHAONwI6tWAj/hoK7onsHVATXoKnBItE+9F0gh6JRZOk43glk3yJr5ww77Ac8BIn52YjjNHRAZMgMsiPoJ+Dgunad08VT3RR0M7R1BVHYnb6nA/Hw2bjrcFeK+IPNNKI/Uj6F9h4TT+vB24rNVG6gN6XquNGRNzhqq+r5UGugBUdRfsZRDj3zDg8lYaqI2g78eet5t8TFPVD2c9uRbQIz0VY0ySzHtsWUBNEU7IemItoEd5KsSYJONV9dAsJ3ap6q7AQX7rMWaATKNoFzDWcyHGJDk+y0lduBuqxuQt00OgLmCU50KMSbJrlpO6cCs9GJO3TC8hWUBNUbqznNSFW0DU1qY3eduY5aQuEdkGPOa5GGPiHs5yUu1G/YMeCzEmSaaM1QL6K4+FGJOkpYDaCGrytHqwdegH0wUgIutwm8gbk4ers55Y/0b9jzwUYkzcRuCGrCfXB/QqwMt6OsbUuVZEMt9r3xlQEdkA3OalJGOcV4DvtNJAfF78vFYaMybmvKwXRzXxjbx+hd1yMn4sEpGfttpI0tpMX8KtS29MVhuA2T4aStrI6x5a/N5gOtrLwFRf64Q2WqP+y8BvfHRgOsprwBQRecpXg4028urGTRW1206mWZuBaSKy2mejg23k9SjwdZ+dmbb1W+BoH5smxA21Dc2lwH/47tS0lZuBI0Xkt3k03sxGXiOB24GT8ijAVFY3cKGIeF1ROW7IgAKo6mhgCTAlz2JMZfwUuKDVtT+b0VRAAVR1DLAM+GB+5ZiSWwWcLyK/LKrDpgMKoKpvB+4g4yR8U1n34fbNukVECn2IkyqgAKo6HLdy7peynG8qYytwE3CNiKwKVUTmgKmqAD8GdvdXjglsM7AcWAwsFpFNgetpbQRU1YOBW3EL4Jpq2wHMFJGbQxdSr5ntuBsSkfW4pcO/DWz3UpEJZQRwo6oeE7qQet6+Q6rqJOBb2P3SqnsBeF+r73H60tIIWk9EnhKRk4FpuL0+TTXtD8wNXURNLlfh0ZX+OcAl2L6fVbQVOKgMo6i3EbSeiPSIyPeAdwAzcPfRTHWMAU4JXQQUeB9TVQ/HbRY2E1s0twoWiciM0EUUfqM9eho1A/gb4Bhs89qyelpEJoUuIuiTIFUdi7uo+iYwMWQtZoCXRWRc6CJy+Q7aLBF5XURuwZYhL6O3QhcAgQMKO59GjQ9dhxlgTegCoAQBBY4LXYBJtCx0AVCOgB4bugAzQC+wNHQRYAE1yRZES3IGFzSgqro/cEjIGswAm3DrIpRC6BHUvn+Wyw7g02V4xFkTOqD28V4efcBZIrI4dCH1LKAG4A3cy8qZV0LOS7AnSaq6F26hKZvXFNYjwN+KyNrQhSQJOYJ+EAtnSOtxr0ROLms4wb3mH8qBAfvuVD3ACmAhcKOIlH5xuJABzbS5qBmgl8afhK8DTwNPAr8AlorIq0UV5kPIgD4XsO92ch1wEW7mwkjc16ZtwKsiUvm9r0IGtLTfeypmQzQqVmpkbFbIi6T12DbgPjwUuoA8BQuoiGzH5iq1qoc235Ul9I36UrzSVWGPiMiW0EXkKXRANXD/VffD0AXkLfSUjyeBu0PWUGF/ABaFLiJvoUdQgO+GLqCibhWRzaGLyFsZAroY25MprV5a2IO9SoIHVER6gFmh66iY+dE2QW0veEABojXPbwxdR0X8jhK98Z63UgQ0cgFuuoFprBf3UvGboQspSmkCKiIvAefi3uw2ya4SkY56uFGagAJEy0/PCV1HSa2kROt2FqVUAQUQkauBr4auo2QeBU4Qka2hCylaad9oV9VvA/8Yuo4SeAi3i3BHfj8v3Qha5wt0wKO8ITwATO3UcEKJAyoifcDZuGXEe8JWE8R9uJGz7Z8WDaa0H/H1oq1RbgImhK6lAD3A5cA/R68kdrRKBBRAVXfHTW84NXQtOXoSt7JHW7+EnEZlAlqjqucA83AL/beLPuA7wFwRscmEdSoXUNi56O1c4NNUf437NcDsIre4rpJKBrRGVScAFwJnAaMDl5PWPcAVIvKz0IWUWaUDWqOqB+C2B/8s8LbA5QymD7gDF8y2nkvkS1sEtEZV9wU+BXwcOJry3EZ7ERfM+dEsAtOktgpoPVXdBzgZ+BgwlWIvqnqBh3HLaC8FVkb3dU1KbRvQeqq6CzAFmA68GzgUOMBjF1txC1E8gZupemeZFoGtso4IaBJV3RUX1Pqfg4FdcPs2jcLdIegBtuMWmegGNuDC+Lvon2tF5IWi6+8U/wcPcti+Xlt1gwAAAABJRU5ErkJggg==)

|  |
| --- |
| 2.1b |

|  |
| --- |
| 2 |

|  |
| --- |
| 2.1b |

Ingress Ports

Egress Ports

|  |  |  |
| --- | --- | --- |
| 2.1a |  | 3.1 |
|  |

|  |
| --- |
| 3 |

|  |
| --- |
| 1 |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |
| --- |
| 2.0b |

|  |  |  |  |
| --- | --- | --- | --- |
|  | 2.0 |  | 3.0 |
|  |  |

|  |
| --- |
| 2.0a |

|  |
| --- |
| 0 |

|  |  |  |
| --- | --- | --- |
| 3.1b |  | 3.1a |
|  |

|  |  |  |  |
| --- | --- | --- | --- |
|  | 2.0 |  | 2.0b |
|  |  |

|  |  |  |
| --- | --- | --- |
| 2.1a |  | 2.0a |
|  |

|  |
| --- |
| 3.0 |

|  |
| --- |
| 3.1b |

|  |  |  |
| --- | --- | --- |
| 3.1a |  | 3.1 |
|  |

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| |  | | --- | |  |  |  | | --- | | 3.0 | |  | Priority Order |
| Ingress  Port Number  Egress  Port Number | |

OM14284

Figure 6-7 An Example of Differentiated Traffic Flow Through a Switch

At eachIngress Port an incoming traffic stream is represented in [Figure 6-7](#bookmark66)by small boxes. These boxes represent

packets that are carried within different VCs that are distinguished using different levels of gray. Each of the boxes that represents a packet belonging to different VC includes designation of Ingress and Egress Ports to indicate where the

packet is coming from and where it is going to. For example, designation “3.0” means that this packet is arriving at

Port #0 (Ingress) and is destined to Port #3 (Egress). Within the Switch, packets are routed and serviced based on Switch internal arbitration mechanisms.

Switch arbitration model defines a required arbitration infrastructure and functionality within a Switch. This

functionality is needed to support a set of arbitration policies that control traffic contention for an Egress Port from multiple Ingress Ports.

[Figure 6-8](#bookmark68)shows a conceptual model of a Switch highlighting resources and associated functionality in ingress to egress direction. Note that each Port in the Switch can have the role of an Ingress or Egress Port. Therefore, this figure only

shows one particular scenario where the 4-Port Switch in this example has ingress traffic on Port #0 and Port #1, that

targets Port #2 as an Egress Port. A different example mayshow different flow of traffic implying different roles for Ports on the Switch. The PCI Express architecture enables peer-to-peer communication through the Switch and, therefore,

possible scenarios using the same example may include multiple separate and simultaneous ingress to egress flows (e.g., Port 0 to Port 2 and Port 1 to Port 3).

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Port Arbitration

within a VC in Egress Port

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFYAAAATCAYAAAAKw/ooAAAFhUlEQVRYhdWYa0wUVxiGn1FnARfk0ooCxdlmjNWmVUmwscZqKiqEJjXakljTmCZtQvASSZXgJdZgbavGmkbapDZqqD9qvKXRtJp4Ia0NS+sdVoRAR2cQrMCKuOwOhV2c/lh3YVsQWIS1TzLZ5Pu+c877vTl75mQEgsQwjARg0rx5896x2WxzAGJjY+uqq6t3+WpkWV7vcDjGA6SkpBSfOXPmJIDVah2zaNGirb66FStWfFtQUFAFkJOTk3rs2LH3fTlVVdeazeZOgFmzZi2rqal5DSA+Pv7PioqKr311kiQV6LoeHR4WFjvu+bGPWltbV1bfUk4F299gEYIZlJ+fP2H79u0XAKmmpob6+noAIiMjSU1N9dddvHgRXdcBSE5ORpZlADo6OrBarf66qVOnEhcXB0BDQwOVlZX+3Ny5cxEEr8yqqiru3bsHQExMDNOnT/fXlZaWUltby47PPidn1Uq+2VP4wOl0Jiia2h5Mj6FgTFRUVKvb7TaeNa5dvWocP3rUMAzDsNvtDsMwxFCbNRCWzJ492xFaC/vNnFCZNGKgA6Kjo99evHhx1FCIGQxOp5Pbt28HxBbMS/teliyRodAzYGPz8vLOL126dCi0DIorly5T8MmWgFibrj8HJIdCz4CN3bRpU2diYuJQaBkUdXV1JCYF6kpITHgETAiFngEbS4iE9sXdu/UkJSUFxJKTJ4j8X4zduHHj7KEQMlicLheRUVEYhkFzczMAaQvmC0B1KPQIsmR5D4gA/ur2NCma+qinASaTydPe3j5yGDX2C3tTE6NEkcaGBjLTM5jy8hRMpjCj7Pr1vUCeoqnO4dQjyJJlClAKRHeLe4BGAs22Age1+jq32+0O5ggZFtxuN2XXr2MtKeHQD4eMpsZGA+gEfgfOP37+UDTVPZQ6BABZsswHTgOjeqixATuAw4qmekwmU4fT6RRF8dm6e1++dAmPp5OZr8/0x/LWrmv78fjxDXiPgzRgPjANcAIX6DLa1ts/NFh8RhYD94Fx3XK/ATsUTf25+wCn05ktiuKBpyniaXDDZkNV1QBjNVXtAKoVTT2Nd+MgS5axwJt4jV4JfAk0yZKlmMdGK5p6q7d1ZMmSomjqtb70+IxNw2uqAfwEbFc01drTAFEUe100lCQmvYDVWhoQy3wrs/LqlSsBJiia2gQcefwgSxYL3v7TgG3Ad7JkUenazcWKpjZ0myJXlixxwFpFU3t9MfqOgoN4Td2paGrFkxowDCMJqOuz02HmZsVNctes4cy5s93DXwiCsLG/c8iSRQBeocvouUAU3uPQZ/RY4ADgBgqBTxVNbfn3XL4du07R1Mb+LC4IQvyqVaseFBYWxvZX8HAw6aVJhIeF4XK5MJvN1NbWYi0pqex7ZBeKphp4TbQBX8mSRQRm0GX0SsB3IxKBj4HlsmTZBOxXNLXTN1cwnw3jIyIi7tjtdtPo0aODGD48bNm82X308JFtlTXVW/uu7h+yZIkGTgI9fdwpA3IVTf0FutwfCC6z2ZzqcDheXLhw4SiAzs5O7t+/j67r6LqOKIqMHOmduq2tjZaWFn/ObDb7J3I4HDgcDnRdx+12Ex4e7s/Z7XZcLhe6riMIAr5biMfjCVjLZDL519J1nfq6em7csLFrx8729vb2jx48bHEE0eN/eLx7i4DMXkrGAx/ExcS8GhcTc6mn61WfPHz48MPy8vIcoBkQrFZrXEZGRr4vv3v37r3Z2dm3ANavXz9j37597wKMGDHiUWtr6wZfXXp6+rLy8vJpABMnTqwuKyvb78tNnjx5c1tbWyRAVlbWqaKiol8BTpw4kbB8+fJcX11RUdGerKyseoDVq1e/ce7s2SWxY6I9Ho8nW9HUO8H01wtRwG5gJ957secJv3//A0ONaWIShiY8AAAAAElFTkSuQmCC)VC Arbitration

TC/VC

Mapping

of the

Egress

Port

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAJYAAACpCAYAAADJLcSaAAAZFUlEQVR4nO2de3hcVbmH30xCml5Ih0hBW2CtssDekqYXCkJVOCi12FJBhQICilBFz1GOoB7gHBQVlcMRAVEUlVspFFS0YBHKVe2NS9GWXgBh6960qIDtzOSetM2cP74VMkmTzGQykz2TrPd59pM+zWTvb9b8Zq+1v/VdShgmGKVLgYOBQ+1xCDABGAtU9nJUABGg1P5MAu3AXns0AHW9HDuB7cCOjp9e4Cfy/04Lg5KwDcglRukSRCzTgGr7cxIioncBu+j8sHcArwMxehdHMyKkjgM6RVYGjEYE2JM4x9nrHkKnmNvtdX1gG7DVHtu8wG/I9XiESdEKyygdQUQzFzgaEdJUoAX5sLbYny8BrwF/9wK/LRxr3xZ9JSKwiYjoO47JwBuIvS8A64B1XuDvCsfagVM0wjJKjwTmIEKaCxwLJIC1wDPIB7LVC/ydoRmZJXaaPhwR2UzgOOAY5O62FhHaWuAVL/CTYdnZHwpaWEbpicACe7wXmT46BnmtF/j/CNG8vGKULgNq6PwizUU+r4fs8YQX+E3hWdg3BSUs+809DlhojwOBh5GBfHQ4LX67Y6fSSci4LABmA2uQsXnQC/ztIZq3DwUhLKP0FOA84Bxkgf0AMmDPeYHf3tffDleM0lFgHiKyhcAmYClwvxf49WHaBiEKyyg9DjgTEdQEYBlwlxf4m8OyqVgxSo9ABHYecAKwErgLeNwL/L1h2DTowjJK1wKXAB9BBmApsl4IZQCGGvYLuxj4JHAQcCNw62AvIwZFWNY1MB8R1BTgJuAWL/Bjg3H94YpReg4y5vOAO4AfeIEfDMa18yosuxg/G7gcaAOuA+4L0580HDFKHwZ8ETgfeAz4hhf4L+bzmnkRln2CmQ9cAzQCX0Omu6LwwQxVjNKVwEXAV4DfAFd5gf/3fFwr58IySh8FXAuMR+5UK5ygCguj9AHIZ3MB8BPg2lyvwXImLKN0FfB9ZD7/BrJg3JOr8ztyj50ivwmcDHwZWJarm0BOhGWUPg34EfAr4IqhtqE61DFKzwZuR/ZUL/ICf8dAzzkgYRmlD0Ke8GYCF3iBv3qgBjnCwShdjkyP/wFcBtw2kLtX1sIySn8Q69QEvuYFfnO253IUDkbp6cBtSLTFOdm6hPotLPvEdwkyJ5/tBf5T2VzYUbgYpfdDHsAWAqd6gb+1v+co7ecFRyGOthOBk7zA39jfCzoKn1gi3h5LxFdVRaNxYHlVNOrFEvF++b0yvmMZpQ9GIg22Ap9xU1/hYDekZ0UikTljx449sb293bQn2yuSSUpLI5HWSCRS19raur6pqWkN8CwS15XR5r51H90P/By4OtN1V0bCsqJ6Ennqu8r5pcLHxmstqqysvLylpaXWHGGa5sw5emTtzBnlEydOpGLkSMpKS2lpaSWRiLNlyxaee+bZho0bN5Y0NjQQiURubW5uvt4LfD+Dax0MPI44Vb+eyeefVlgpovqlF/hXpXu9I78YpUeWl5dfWlpa+qXDDz+8fMlnPztm3vwPUV5envE5giBg6R13tv3yvvuSZWVlq+vq6q70Av/pNNc9CHiCfoirr5MdbJTeapS+KuuTOHKGUfqY6VOnbb/w/E83bdm8JTlQGhoaknfftSw5s2Z60/Sp024ySlekuf5BRunNRulvDeRNlBul1xulr876JI6cYJQeUT15ynW11TVNK3/72wELqjs7d+5MfuaCC5umT50W2DVVX7aMM0q/aJS+INs3c5NReoUNeXGEhFG6ora65g/nnv2JprfefDPnouqgvb09+eCKB5I1U6Y2GqXnp7FpslH6Teux79ebOcco/Rej9NgBjYpjQFhR/fGzFy5pamtry5uoUnl+w/PJ6VOnNRmlP5TGto8Zpf9mlH5Hpm9milH6LaN0TU5Gx5EVRuny2uqaP160ZEnT7t27B0VUHWx47rkOcZ2UxsZrjdK/s07zPl9YYpR+zCj9xZyOkqPfTJs0+TtnL17cONii6uCZp59OVk+eUm+UfldvNhqly4zSLxilP9r9d10871XR6CLgo8AFsUTcZceEhFH6qIqKip8uW758ZGVlZSg2TDjkEJqaGkteeunl2WNGjrorlojv85pYIt5eFY3+BfhhVTR6SywR3zdMyig9wij9Srq51ZFfjNIV06dOCx5c8UAod6pUWlpakie+//jGIycefm4am1cYpS9L/b/UJ74Lgb94gb8qHwPmyIyysrLPz5o9+8CFi04J2xRGjBjBjT+8aVR5efnNtsRBb3wZ+IrdWgK6CmsJkuzgCAmjdKSiouKrX7j44lElJQWRS0x1TQ0zZs4EyQHtES/wX0V2ZxZ3/F8EwCg9EynF8/u8WulIx8kHv/Pg0TNnzQzbji5cuGTJmP0r9788zdPf7UgWENB5xzofuNOls4dLZWXl5Z/93OfGFMrdqoP3n3A8FSMqxiMVcHrjUeBQWy6BiFXhmUhGsiMkjNIVzc3Nx5z84Q+Hbco+RCIRFp911qiKiorTe3uNTZy5BzgL5I51KLDHC/y/Do6Zjl6oHT9+fNPIkX2tkcOjdkZtSUVFxfvSvGwNUgWHCDADcJGg4TPnqKPnZB77MshUV9fQ3NxcnWadtRHRkxNWoTB27NgTZ82e3WfYSpiMO2gcFRUVSaTMZW+8BowySh8UQWp3utJBIROJRCYedthhYZvRJ0rr3YDp7fc2+G8zUB1BCq66qi8hk0wmR1VUFOb6qoOKigqAEWleFgP2L7MvdNVfQiaZTEZKSws79K2srKwEKUPeF4uAWATYQz/TwBy5JxKJtLW1Ffb3u6W5OQmkK6j7PPDHCFIkf3TerXKk419vvfVW2Db0ya5YrAQpgd4X/wL+GQE84Mi8W+Xok4aGhtVbNm8u2HKZra2tvL5jxyjSP+i9G3g1QorvwREeu3fvfmbDcxsaw7ajN1568UVGjRq1va/a8ja6YRzgOWEVDs+/9OKLI5LJwswF3rRpE+3J9nVpXjYd2OwF/t4I8CIw0Sg9Jv/mOXrDC/y/l5SUxF/YtClsU3rkqSeebKyvq38szctmI/XmidhCs08iIcmOEGlra7vxjttvL7iaGDu27+C5Z58tQUos9MUZSIn1t8NmusTSOMKhra3tp48+sqpk167Cavp119I7d5eWlt7uBX6va0AbLqOBVdAprJVAtVH68Lxb6egVL/B3lo8of/C+5fcWTFxcU1MT996zvL2xsfH7aV76KaSzyB6wwvICvxVYjoQnO0Kkvq7+az/+0Y9at28vjJ5L/3fN/7aWRCK/6yusysbDn4fUTtvnl4cZpXcapQ/Nn5mOTJj67kmXfezUUxv27t0bapbO+nXrk9WTp8TSZTsbpf/HKN1l/fX2Vk4sEU9URaNjgMWxRPz+PI2ZIwMqx+y/vqGxcfHoMaPH1c6YEUqcckNDA2ctXtxUV1d3lhf4vT6qGqUnINHHp8cS8X2TD+2LRhultxulj8uTvY4MMUpPqp48pf7xxx4b9DtVc3Nz8qwzFjfWVtekDVc3Si81Sn8nkzf0CVsDaVRORsiRNUbpOdWTp9Q/8fjjgyqqM08/o7F2WvUKWzWwL/vmGaV3GKX3z+TNlFgV3pW22IMj7xilj66ePKVh1cOP5F1U9fX1ycUfP72xdlr1rzMQlTZK/9Mo/f7+vJlRRulNRunPD3hkHAPGKD2nZsrUN798yaXNdXV1eRHV2jVrknNmzW6sra65w0jXtr7sqTBKbzBKX5LNmznCFteam/WIOHKGUXr/2mnVy46efVTjmtWrcyao+vr65BX/dVlL9eQpO43SJ2dgR4lR+laj9C+yntGM0vON0m8YaajoKACM0gumT532xvyT5tX/5te/Tra0tGQlKO/VV5Nf/58rW2umTG2pnVa9PLXuQh/XLjFKX2eUfj7duiqTqsmnIDW+F3qB/1zmQ+DIF3aqWlBZWXlFkmTtKYsWRWbNnl0+ffp09MSJRCL7hjjX19WxZctWtmzZzGOPrKrftm0bwC0tLS03eYH/WgbXLAG+h/Sc/mC6ViiZ1nl34ipQjNJTI5HIgsrKyhP37Nlz1J49eyrfNX5888iRFZSWltHa2ko8FiuNx+MjRo8e/Upra+uapqamJ4AH7I5LJtfol6igf50pTgFuBT7tBf7KTP/OMbgYqceugJFI4kMLEEdKVPW7f6SREt03I7FWJ2XatKlfiy+j9LHAL5GunN9xRUSGNkbpQ5B2J68B5/enD2W/8o28wF8PHA18GPhVRo4xR1FilH4v8AzSieKM/jY3zepx0Sg9AmmA+V7gk27dNXSwjtFLgEuRz/aRbM6TVT5hLBHfG0vEf1sVjcaApVXR6IFV0eiaHoubOooGo3Q18CBwCPARL/A3ZHuuAaXeeoF/D7KoM8BGt3ldnBil9zNKXwk8BfwMWaT/bSDnzGUX+48j0+ODSOu5f+Tq3I78YZSeh7gSXkf6UOYkwjCnm8xG6SrgCiR+/kfA/3mBX5/Lazhyg1F6FvC/iGviCuD+XPahzEv0glFaAd8C5gFXAz+12UCOkDFKT0Q+kxOBbwI/9wJ/d66vk9ewGKN0LXANUoPrJkRgPUcZOvKKvUNdCswHfgBc118XQn8YlHgrW+77EmABEsZ640AXh470GGkJuAAZe4MI6mde4Kcr7DFgBjWQz3py/wPpgvF74Dbg0Wy2Ghy9Y6Td8lnARUAD0hjiV/mY8nojlAhRm85/LpIyNBEp47wU2OQamWeHTcFahIzpXOABZG93dRhjGnrosVH63YjIzgXqgWWIy+IlJ7K+sRvEJwAfR0okbEC+oL/pK2t5MAhdWB3Y9cD7kFv4AqR85UNIlvYfMg3xGOrYdKsPAwuBf0PqVT0A3OMF/o4wbUulYISVio3/mY4IbCEwDfEKPwWsAzYO5nohTGyy6HHI9DaPzvoIK4FHvMDfGZ51vVOQwuqOUfpA4EPIHW0uMrgbgLX2eMYL/MKqpJEF9q59JJ1CmgtMQKIM1iJVgdYVw8NOUQirOzY++z10Dv4coA7YAmxNObZ5gV8Xlp29Ye/IhyL+vWkpxxSkhuc6Or80W4pBSN0pSmF1x37TD6PzA+r4wCYj0ZOvATuA7d1+vo7UJW/MVdCiUXo/pHb+OCRK4NAefirEDdDxBej4QmwbDB/TYDAkhNUbNungELp+sKn/noD0aRyFfNB13Y5moN0ee5HxKkWiQkqBMYiIxtqflcB+SGXhXYiAu4t5BxBkGuJbrAxpYWWKFeAYugpkLNJcoUNEpXQVWTviHtlHjM5N4nA4HA6Hw+FwOIqGYfNUaJ2SUXp2N6Q+CVamHBV0PhVGgCSdT4V76dlFUYe4G3bSzWc2nPY7h5yw7N5aqkd7Ep3+q7307CDtSRzd/VgdDtQOkZUhXdN6EmRPDtLx9lrbgQDYRqeD9OWhFrpdtMKydyCFbOkcTaeYRtJ1W+clrOc9zO0d6ys7CBHaRGAqnTYr4G+IvS8gWzrP5DN0ON8UjbDsVskMOvcHj0PuHmuBp5HwkS3IlFNUDkqbWT4JEdlM5P3NQL4Ua7F7h7lKzRoMClpYRul3IbFHC4APIFNI6gbt34pNRJlixTabrl+kOBKj9hDwx0KePgtKWHZ6m43EYC1EEgAeRQbyYS/wC7sFaR6xYzMDGZcFyAb7E9hgSC/w3wzRvH0oCGHZHj7nIPHa7Uho8krk9j8sAvr6i62DdTIitJOQO/hS4EEv8EPvIBaasIzSY4HTETFNAe5FBmbDUJ3e8oVRejRwGjKWRwG/Bu5Evpih1DAbdGEZpScBXwLORG7lS5FprmDXC8WEjYk/G/gkUA5cD9zZV8vdfDBYCaslwPFIJu4xwI+Bm73Af2Mwrj8csWP+XmTMjwN+CvzQC/x/Dsb1851iXwJ8DLgccSZ+H+lpF/oaYDhhU+wuRjKgVgBX99UmLhfkTVhG6eOBa5GIyq8DD7mapeFidyW+YI9liMDy8qSdc2HZqnDXIM6+/wbudYIqLOwT5ZXIHex64IZcJ7jmsvBaJVJv6aPAd4EfD6dN12LEKH0E8G1kLXaxF/jpmolnTE6EZZSejywOVwFfcaWKigvbL+lWZFvs33PhbB2QsIzSByAL8hOAJV7gPz5QgxzhYOtAXIVUY/wSsHwg/sSshWXrgN+L1AG/vJh34h2d2IZctwEvI00Dsir12W9hWRfCRYi6s64D7ihc7Ab4D5C116le4L/S33P0q867veBPkAX6PC/wn+3vBR2Fj63jv7IqGt0LLKuKRrfGEvF+iStjYVkfyKPAHuCUwfLgOsIjlog/XxWNrgPuqopGI7FEfF2mf5uRsKyonkDKCH3GuRGGD7FEfHtVNPoL4IaqaLQyloivzuTv0gorRVSPAJe5yIPhRywRr6uKRu8Hrs9UXOmaSqeK6nInquFLLBFvSBHX2HTi6lVYNsb8IWAN8F9OVI4Ucf2gKhrdFUvEX+jttX01afou0Ah81YnK0YHtkXQacL1Renq//tgofbpR+q+2N47DsQ9G6bOM0q/a6or7sI+D1MburEX8VH/Ot4GO4sUofSOSE3la91mtp6nwBuAaJypHBnwFeDeS0NGFLsIySp+MpFzdNDh2OYoZm6dwCXCdUbo89XdvC8s+BX4fuNQlNjgyxe4Vv4L0SHqb1DvWp5GCFQ8Nol2OocGlwBU22BPoKqzPAN9zrgVHf/EC/yVgNXBGx/9FAKw/4iDEy+5wZMPtSJAg0HnH+hSS1Lg3DIscQ4KHAWPdVURs4N7ZSEq2w5EVtsbGPUjmDxGk2hzZRAk6HN1YjfQ1IgLUAhtDNccxVNiI6IkIUnPJCcuRC3xgf6P0gRGgBsknczgGhHVVbQZqIkjF34Ls0ukoSnYBlWVIhyu3hePIFYuAf0WQrJt+pYE5HH2wGXg6ArQgjSAdjlzwOvB6BPgrcETIxjiGDkcCf40groYZIRvjGALY6IZ3Aq84YTlyyXRgixf4eyNIsyBjSzo7HANhFrAJIGLT5f8AnBqqSY6hwBnYQNGOsJk7kNAZhyMrjNJHIgv3h6FTWA8AM43Sh4VlmKPo+RSwrKNFTQTAC/wW4D5gSXh2OYoVWzftk8jMB3SNeb8O+JxRevwg2+Uofv4TeN4L/LeDGd7eyokl4rGqaPQA4LRYIr4iDOscxYdR+p3A3cDiWCK+q+P/u2dCfwc4yRY4dTgy4Wrg9u4RyF2EZSvk/jdwiy3P7HD0ilH6BKQp59Xdf9dT7YY7kMxWl2bv6BWj9CFI8sS5XuAnuv9+n3CZWCJOVTS6CvhmVTTaGkvE/zQIdjqKCFun4XdIJ7elPb2mx8Jrdkr8KPBdt95ypGLTBW8A3kB6J/VIrwF+sUT8X1XR6MvA8qpo9LFYIu6aVg5zrKi+hfSgXmT9nz3SZ+RoLBF/uSoa9XHiGvakiGoR8AEv8Hf19fq0IcmxRHybE9fwpgdRpW2emVGse4q47q2KRjfFEvG8tn11FA52oX4TMv1lJCroRxKFFdcG4O6qaLSkKhpdH0u4toRDGaP0wUgYzAikzU2f018qfZXj3gcv8H8PvAcpInK3UdolYQxRrDfgOeBJ4CM9+ar6Iqt+hUbpkUhH1RrgPC/wey0k7ygujNIR4N+BryHNTbPaN84qnzCWiO+pikZXIDmJS6ui0VF2anT1tYoYG6y3ArlhfMQL/LXZnmvAPaGta/8WpBzSp73Af36g53QMLkbpUiT05XLk6e+HAy3CN+AMaNsZajlQj9y9JlRFoxtiiXjzQM/tyD9G6fcBvwAmIk7Ph2OJ+IDr0Oaki30H9ini60hQ/XXAjV7gN+XyGo7cYJSeClyDpGxdCdztBX57rs6fU2F1YOtQfhs4FukdfYcX+HvycS1H/7BLl28ApyDCurmvrZlsyYuwOjBKHwNci6y/bkACwly3+xCwd6hLgI8ha+JrvMDPmyMyr8KCt7cDjkWKzB8P/AxZHL6e72sPd+zYfwAR1CzgZuDHmXrPB0LehZWKUdoAFwPnIB7d24A/5HJud4BR+gBknft5oAxpZXN3Pqa83hhUYXVg3/j5wHnAAcAyYKkX+C+HYc9QwPZCOhk4F5gHrAJuBR4No9tIKMJKxShdiwzGJ4DXEJE96AV+EKphRYBRugw4Dvg4cCbwMnAX8Esv8GNh2ha6sDqwg/RBpAD9ycCbwEpkylzvnioFo/SBwHwkieFDSKXiB5AsZC9E07pQMMJKxXqC5yCDtxA4DHgUeApYB2wbLusyo/T+wDHAXGSKq0bGYSXwOy/w/x6ieb1SkMLqjlF6AnIXex8ywO8A1iMthtcBz3qB3xiehbnBPsUdikxvc+0xCfgz8l6fBH5vKwQVNEUhrO7Y7Ntj6Rz8GUjtyy3A1pTj5cF8EuoPRulxyN1nWrdjD/JlWWuPPxWDkLpTlMLqjn0iOoLOD6fjAzsc2IE8FOxAGn2m/nwdiHdUSMmRLSXASGAc4hg+tIefGtiPrl+Cji/Fm0OhZ+SQEFZv2LDaw+n6wab+ewLSQKENqOvhaAba7bEXGa9SJECyFBgDVNpzVKYcbUgh/e3sK+YdQAD8YygIqDeGtLAyIeUO010gY5GQ3A4RldJVZO1IRMc+gszlHbBY+X+eHvoqeqso8wAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABsAAAAJCAYAAADDylfFAAAAjElEQVQokb3QMQ4BQQCF4W9FQavgCord7AEkLkGj0OkcxwFoOIIT6DQmM63ECbRahWyyEeWsv3zNlzw6KMQ0/rX3usBwDDFtvscixDTFJDO2Q4U9tnVVvhrshFVmrN0Ny7oq713d2K7GAvq4YpgZmGOEJ9Z1VZ6hyIyAENMFA5/7Hs3e1Y0HzNrQ33sDXTMdj7+oI2gAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFYAAAATCAYAAAAKw/ooAAAFQElEQVRYhc2YW2wUVRzGf0u77apT2koXml31TDKA2mJpvVW81GgNbRRfSJPFgmKhqagQjOmDSIAHFYgQXuQSayrw0ARflBC5CHKHGospVomBslNmeuVSKaHdtrDbPT5sZ9li27QLvXzJPMz3/f/n/OfLmXOD6PBATk7OfCnlbCnl7AMHDryTkpLyj/Vs2LDhQ0srLi5ebfFOp/OcxUspZ2dnZ1dYWkZGxo+RmtvtrrI0j8ez3uJ37txZFNlXeXn5IkubN2/eWvHoY81Pz8xs0IT6epTf1i80oTo0oaZoQk3WhJqgCfVBTahxmlBj+ou3RdPJxIkTt3k8nnfLysoeAuju7qa6ujqsp6enk5iYCMCVK1fQdT3Umc3GrFmzwnG1tbW0trYCkJSURFpaWlirqqoiEAgAIITA7XYD4PP5qKmpCcdlZGSgKAoAzc3NeL1eGsx61q9d29bV1TVVN43r0Xzj3dCEmgDsB14aIKQHCAC/A8ujMTbR4XBca2xstE+aNCnKMkcey5cu696/b9/Ki5fqNt2vNnvNPQo80498Bfgc2KGbRnBCFO0/mZub6xtvpkopWfbRx/h8PgBKlixxFM6f336v7WpCTdWEWqgJtRw4x/9N9QNfA9N00/heN40gRDEVSCmdwNV7Lfh+w3vRy+KiIo6fOhlJr7bZbF8Mpx1NqBOBV4Hc3mcG0A4cAw4T+t0394bvBkp109Dvbid2uB8ATI8iZ8RRX28ybdrUPtyhgwdf1oSarJtG20B5mlDjgVmETHwDeI7QfFkJ/ACUAGd00wj0xm8F/gY+0U3jyEDtRmOsGkXOiKOpqQmXy92H27ZlazbwLHDI4npX8UzujMhXAAdQTWhErgFO6abROUBXe4Flumn0DFbPsI1NTU3d1NDQgN1uH27qiMLlcjHZObkPJ1Rh/6umRtWEOp07I/I1IBmoJWRkGXB0qLsH3TT2DiVuSHOsJlQb8AJwxmxqvOX3+6NZ9EYNV69epfL0abZ8szl4qa6uHUgEWggZ+StwRDeNhpGsYdARqwn1MWAh8D7wlW4av8XFxQWBcWdsMBhESknthQu8/eZbKAkJPJycbCO06KwAzuumIceswN4TRqEm1EOaUHs0oUpNqNss3ePxnJbjEGtWrZI7tm+XgUBA/nn2rPT7/fLo4SM+TajZY+FjeMRqQn0eWATMI/TrWKgEllsvu3bt2g+8OFoFDhXx8Q66OruIiYlhZmYmAPv27bUBWYROQ6OKWE2oDuBb4L1+9BagQDeN2xHciM5N0cLldlHn7budbKhvuA00jkU9E3TT6NZNYyGhM/CeCO02IVNbIhOOHTt24+bNm6NZ45DgdrtpaurrYXNz0wSgfizqCS9CumlUAgsitOW9XB/MnTu3sKKiYjRqGxaysrJYXFLSh+vq7AoyXv4wTag+TajfDRKyID8/v32sF6shIn/UjLsL/W2b9gBLB8n55cSJE3brSm884VJdHadOhu4K/H7/LeD4WNXS3z62SDeNW4PkXCsoKMiLjY3dDSTduHGDjo4OAOx2O1OmTAkHXr58OXynqigKSUlJAPT09NDScmfqTklJweFwAKH71ra2O0d7t9uNzRY6x1y/fp3OztBJMz4+HqfTGY5raWnB6/Wy8rMVfLluHatWruz4t7U1OGQnxguklFlSyuK8vLyfFUVpUxSlTdO0c1LKYusRQpy3tDlz5vxk8dXV1Z9avKIobRs3btxgaaWlpVsjte7u7hJLy8nJOWTxaWlpf0T2lZqaaiiK0vaIy9U1c8ZTHemPP/HBWPrzH6qqcQelDQXpAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAC0AAAAVCAYAAADSM2daAAABL0lEQVRIidXXP07DMBSA8S8vCZGjuNlpBqoiZaUsbFUv0K2w9RKMiI3TMPYGXdgYOUAQEXtTKYKGUgbEn63x9NLf5MHDJ8uSnz3+BMAFkNJtD97PKo7jO2vtdZ7njWbRPuPxePazzq21dVmWuwMwEoAoiq7m87nf7/f1jtCBACRJcjmdTo+0Y9rygCAIgreqqnxjjHZPG+cCHPd6vc2BBAPf1+Mky7KNdogLAbLBYOBrh7gQILbWinaICwH8MAy9vTs7RIBt0zQ77RAXAtSr1WqrHeJCgJeiKD61Q1wI8FyWZagd4kKA1/V6HdV1rd3SmgAfaZo+LZdL7ZbWBKCqqvvFYvGuHePqNEmSuigK7Vm5jdHvo2KMuTXG3AyHw07PIZPJZPb/JRTgjO7/ER+/AFgchr83ZdTuAAAAAElFTkSuQmCC)![](data:image/png;base64,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)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAC0AAAAVCAYAAADSM2daAAABK0lEQVRIidXXMU4CQRSH8Y/HrMubxgKSLdbEVkMwxILEljvAPay19QzcgVsQGyoaOYCJiQlQsyy6oIVB7Zit3vJVU0zxyzT/TI2/HHAHnFPtnmuHU6PReFLV+zRNPyxFx+p0OsMD+kpVZ6PRSJvNpikqoFsBcM4N+v2+OwEwAAKgqsNerxdZY0ITwK3X6+t2u21tCU6A1Hu/jePY2hKcAJetVuvTGlImAS6SJKlbQ8okgFdVsYaUSYC6c6529GaFEmBXFMWXNaRMAmRZlu2tIWUS4G25XJ4c+nW1Wp3MGsIP+j3P87M8z60twQmw896/zOdza0twArDZbMbT6XRrjQlNAIqiGE8mk/1isbD2BPU7KnEcP0RR9JgkSaVfvNvtDv4voQA3VP+POPsGyGpDB1OcR/wAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFYAAAAUCAYAAAAXxsqQAAAFdklEQVRYhc2Za0xTZxjHf6WtCIi9MLmYwTnzwKJRXGYcwwWzZYvfRhYnbibOuOwSky1uqPPDssTEkKBhfliyhJAYmGZEp4yLA4dAmI4o4uplMIyO5MA5szpELqVcLGtL96EtlgZFigX+yZs857m853+evpfnfath9lgFpPhkO3A5wJYFxPhkBfjbJ0cCbwT4XQN6ffJyID3AVg94fHK6zw7QD1gC/F4HFuv1+hiz0ahbEh1zVlaVkRC+55lAE2pgdXX1QWBTWVlZksViMQEkJCQ49u3b1+X3KSgoWNHb2xsJsGHDhr7Nmzf3ANhsNl1+fn6a32/nzp13Vq9ePQzQ0tJiqKio8CePQ4cO3dZqtR6A0tLS5W1tbQaA5OTk0d27d6t+v7y8vDS73a6P8LBEp9XidrvPOxyOTbKq+H+UOUUoidWkpqaeOHLkyDatVvvMCc0GN65f5+LvTez6/DOqKir+ab546UVZVcbmg8ukxEqCmCirSvc0MWtNJlPz8ePHYzSakAd8WODxeHA4HERFRflVKdnZ2Xfmg0tE0HOhJIhbnhSg1WrfzszM1C+0pAJoNJrApFJ79tevJEGcl2kVnNgBoEwSxAOPC0hMTIzPzMxcFF5aM4fVaqWqvGKSrunChU+BxPngE5zYe3iXh4OSIP4kCWJUcEBRUVHDunXr5oTcTHC/uxubzTZJt9Rg+I9HFcucYiKxkiBuAj4OsL0PNEmCuDwoRpgLYjNFf18/JrNpki4uLi6C+UqsJIiRkiB+B9QBSUH29YBFEsT1Abp5mVrTYchux2AwTNIZjcZFQMJ88NEODNrcZqOxHagFrgJdwDCwGIj1tR1mo1EeGLS1V1dXV+Xk5ETOB9knYWR0hOeWLSM6JoaqikpcLifmuDh3640b+QODNutc83ni1i4JogFYGdAq1bvW5srKyoVVwAag98EDTp86RZfcidPpBLACJ4BG4KKsKqNzwWPGNZNGo/GcOXOGhVZueTwe3G43Op0OAJfTyQ/Fxc6b7TfP4511GYAb75G70dcssqo4w8EnuCqYFhs3bqwaHx8PB5dZof5cHXW1tRPPOr0eDziAY7KqvAaYgS3An8B7wCWgTxLEGkkQ90iCuFYSxGlHy9P4QAiJ3b9//7GFdpQFMJlMDPQPTNI9HH04hnfPQFYVu6wqNbKq5Mqqko53E94FdANfAK1AtySIJyVB/EQSxBce86pvJUHMmI6PLoRvUEKICTtMZhP9A/2TdF/u3VORnZ3dMpW/rCr3gZO+hiSIK4C3fC0fWCYJYhePlo3fZFXpAWzAFUkQfwS+llXl7lT9z3jEHj58+F5nZ6djpnHhRlJSEvesd3G73YHqq08bL6tKp6wqR2VV2YZ3NL8EfI+3BD0K3JcEsQ3vNSnADqBDEsRvpjpIhbIDvRofH99QXFwcG0JsWHH71i1S09LQ6XS0XL5M/bm6A5br1/Jm268kiHrgFbyjOQdYG+RiBfYCP/uvKWc8YoGrg4ODrvb29tlwDQtWrlqFTqfD5XLR2NAw0t/X1/Ys+pVVxSmrSjPQBEhTuDwPnAYuSIL4MoS2xrrHxsY+LC8vL1izZk0MoLHZbNqSkpKlfoetW7cOJycnOwFaW1sjGxsbowEiIiLIzc2d2GFqampiOjo6FgGkpKQ4c3Jyhv22wsJCo8Ph0ABkZWU9zMjIcAD09PToSktLJ2bL9u3bhxISElwAFotl8R8tLYbRkVHNkH3IAvwSwvdNCUkQ4/FudvV4y7bHtY8kQSyZTTEaB/T55Fi8dwt+nAX+9ckr8f5FAzAOlAT4vQms8MlW4FyA7QO8pz+AK8BfPtkMvBvgVxnAIz06KvodQ2ysOzoqqkhWlcllwhzif91x2UCNBlKbAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAJCAYAAADHP4f4AAAAvElEQVQoka2NLQvCQABAn6c4HAxZceiCgk1uLFhl2I3+ALHbNQkG/RtiWvZfiO24q+IPEETtfiRhimDYvfjCe2ARpU3tlxc2J8BYabNW2lSystButpYdKUeu657yHpJ+P+glSR1QwDCO5OE9mW3SdOF5Xjnv5IsrMIojuRXARQhxtzwAqAITpU25BHT3u13R9/1b3motCJxGGDrAE1gB8ziSj7zdD5Q2U6XNWWkzyPqS1QtooBtH8mi5+58XmvMt56GdLoYAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFcAAAAUCAYAAAD4BKGuAAAFTklEQVRYhc2ZbUxTZxTHf7e8lJaiLa5bRLfbUeeWMc3UTCHzrYDbl5EtGCPxiyYkU8y2CFmWbJlLxESS+UGTmQyioCx+WOY2BXTiBixzg2jmEEXBl9ztXmHOrKVQipUWW/bhtlKIE71Q4J/c9OR5znme/z09ec55zhWYGAzAvbBsBNZEzZ0H3GH5WeCVsDwM1EfpvQrMDcsu4PeouRwgMSxfB/4My7OA16P0moH+sPx8kl6/YvasWYLJmHxCUuR7TBPiJ2C7csmSJftKS0tDAC6XK2Hv3r3pkcnCwsKuhQsX+gCam5vNtbW1zwDodDrKysquR/Sqq6vTOjo6UgDS09Pvbt26tTsyt2vXrgU+ny8OYN26dc7c3Fw3QFdXl/7AgQO2iN727dsVURQHAZqamlJbfmt+LuAfjAv4A8eBDRN4x1GwizYrsBMQgPtA8BG/ZwSN+wgGg6GruLh4XlZW1sRZxwB+v589pbt9Ho8nT1Lkpsla1y7a1gNf8/+BeRMokRT5pE7jHosNBoM5MzNTo3ns0N3dTSgUQq/XszbbYUg2mXIna227aBMBM+qRNxZe4EMgQ1Lkk6DxWEhLS3MVFRUhCFoDPzbw+Xx8sW8/u8v2kJiYyNrsbMGRk9ORl5enaT27aHsKcAC5qOe/HegBLkSpDQOHgE8lRf432l6TcysqKsxAshbbWOKf27eZm5ZGYqKaA8N/fiZw9HHs7aLNBKxCdWQOarK9C5wFvgQagcvADuBN4Bdgh6TIbQ9bT2tCs2m0iyl63W4sqZZRYwfLK962i7ZDD3OAXbQlAMsZicxM1GR1DqgBPgDOS4ocGGP3ErBBUuRvH8VHk3MrKyvXb9myhbi4OC3mMUNvby8WS+qosWAwOBt4AWizizYdsIiRyFwNmIBLqFFZBvwqKfLAOFsVSYocHI+PAGAXbcWAE7gIXBvPUBCE4Zqamhl35vr9foLBIEaj8cFY9eHDgYt/tH6P+q7ZgBW1Xm5AdejPkiI7Y8EnErmXgZ/CBO7ZRVs7qqMjT3t0Ma7T6YKCIMyssAX0ej2gRvCZ06e5cf0G7p6eROAtoA74GGiUFFmeCj7xAJIiN9pF236gGPXWtTz8RBC0i7ZzwCeSIp+daREbQfvldkwmE9anrfT397N6zRpgOHDi++PvSIrcONV8ouvcHx8yHwBOABuBHEmRzwIcO3bs8yng9sS4ce0aiixjMpl4d9s21mY76OvzDAMLpoNPdEL7KEpuRi1fvpEU2c0YxMfH34k1MS0wpZjwer2jxlxO5xBqgT/liAewi7aVwDzgM+CopMh/jWOnxJqYFqTOmUPn1Y5RYz09riBwazr4RCL3qqTILz6uUUlJyYrCwkIyMjJiREsbrFYrNxNGV5cejycB6JoOPnEAvZ6+wScx8nq9DqPRmLV06dIZVTGYLRYWLV48aszpdH7X3dX9Va+nLzTVfDQ1boaGhmpbWlr8k01mshAMjpTpBZs27ZQUeWg6eGjtil1ISkpqjX6JmYK21laOVFYRCoVobGi4teO996ctP2guWOvq6gTgIPBGQ0NDcltbmx7AarUGN2/e7InoVVVVmd1utw5g2bJlgw6HwwcwMDCgKy8vN0f08vPzB9LT0wMAV65c0dfX1z9oDJWUlPTqdLphgFOnTpk6OzsTAebPn3+/oKAg8gWC8vJyi9fr1bmdLsOslJSQx+O5NDg4+JqkyFN+JMAEnDsGmcDLYbkHtekRQT5qDxSgnZHPOEagIErvDPB3WF6Aeu+P4AgQcdAq1F4BwB3ghyi9jUBykl5vscw2xxsNhqpYXW0fB/8BLHXSnnLFtp4AAAAASUVORK5CYII=)ARB ![](data:image/png;base64,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)

for an Egress Port

|  |
| --- |
|  |
|  |
|  |

|  |
| --- |
|  |
| > 0 |
|  |
| > 1 |
|  |

|  |
| --- |
| 2 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAKCAYAAACALL/6AAAAr0lEQVQYlY2PMQrCUBBEn1GwMEjwAO6XD1ZKOrEQBCsrCwtL8RYeIa0X8Aw2XsEr2EggOYERC1ubRZIlYKZZmOXtzIKRFze1XllBjXf14kaNAC8uBIbAxYvrNUkY64yBsxfXskBbL8eDKEqAE9DR3QT4PF/FrZKgNTbAEuiag4kXty4bv0iNXwAHYAeEuiqAWZpnjwpQlj68VXgF3IF5mmfvWsDAAuyBPnD8C5jKwRd49RtldoyhhAAAAABJRU5ErkJggg==) VC 0 - ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAABv0lEQVRIicXUL2iVURzG8c/dhjgUHLOICOewgxgMkyHMCYKIohZFm1gEjWsKSyIGy0wzKBgMQ3TBZpAZpjCLYeCaCAfOKZbZFIM4NVwviDrdn3vvnvqe3/t9eb7n9zZsUlKI59HXswng/hTiPTzB3r4uw/djBjtxPNcy15UPSCE2cAVTeIFjuZYlaHQBvgP3cQ4TmMq1fGs972gDKcRDeIyvGMu1LPx+piOXMIXYk0KcwDxeYeRvcDrQQApxF6ZxGJdzLdP/Ot/bZvhJPMcyTuRa5v430xYFKcQtKcRJPNN0PpZrebea2Q0rSCEOae72EM7mWp6uZX5DDaQQL+ANPmN4rXDW+R9IIW7DHVzCTdzKtSyv511rVpBCHNasfDuO5lrm1wNuZdUKUoiNFOI4XuOtZuUbgrNKBSnEQTzAKVzF3VzL943CWYWCFOIRPMInjOZaFtsBbmVFBSnE3hTiDbzELA62G84KDaQQ9+AhRnAx1zLTbnArfzSQQjyDRfTjQCfh/HIJU4hbMYlx3Mb1XMuXTsL5qSCFuE9zt3fjdK5lttPgVnpSiKNYwJLmbncNDr2DAwMf8B7Xci0fuwmHH8d6gM5M6+M4AAAAAElFTkSuQmCC)

VC 0

ARB

Ingress Ports

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAJCAYAAAAGuM1UAAAApklEQVQYlYXOMWoCURDG8d8uS2Jpn2IXtgmpbMRGUpougVRBLLxETpEmZxC8gqUX8AwP3iutbSwi2Gxgecg6zfB985/5pnCn2ropscAEP9UA+Iw1VnjENKR4qTJojK8OnHX2H95CihGqXuQaHxhlYd8hxf2/KPGAJ7zcgDchxd++UWQvLbHt5AGvIcVznymzi7uuH/GZwzerrZtTWzfzu2Bv4X1ofgWJeSQ2wfgPbQAAAABJRU5ErkJggg==) VC 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAVCAYAAACKTPRDAAABkElEQVQokVXQwWoTURjF8f/95ubiTG00iRgq4gQjE21Ql4K6FdyIdOdLqKAP4Tv4AOLalS6EdteNi6qNOCWaiBCQ2MG0Zuhk7lw3mch82985HPgUy+uGnSvAeWB3OB4VALKEntb6UxAE7z2tH5cFAfB9/9XDrS3z9PmzU57Ii27YuQAg3bCzYa3t3757R9rtNpv9vgMelM37Ua+Xe54HwPWbN4JgLXgEIL7v37u6eW2t3ImiiEW2uAUgIhK1WudK4/T6Os65WjfsnBFr7cVms7FCpRT1ej0FQsmyrHW28R8BGs2mAy5JURTaGFNBY4wCfFFKOaVUBT1PALQ455RzroLWFgC5iEieZVkFs5OTAkjFGDNNkqSCSZII8EM8rX8mh4crcM4xm818YCyFtfHv6XSFx0dHKKUWw/Hoj6Rp+m6wPzguMf4aUzO13fLxbw/i2OR5DsDHvb35/O/8NYAMx6NfWusPO9vbdjKZ8GUwAHgDoAC6Yeeyp/VnT0TyPH9y8P3byxUuAxtAC9gfjkcO4B8SpI/fbaRrCwAAAABJRU5ErkJggg==)一

Egress Ports

![](data:image/png;base64,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)

ARB

TC/VC

Mapping

of the

Egress

Port

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABsAAAAICAYAAAAIloRgAAAAh0lEQVQokbXSIQoCURSG0aO4C7NF3uPhMsymMdncxKzDDQiuwSaILmCciYJZDGIyCRYVw8R5X/xvOOWSoapupm17LxN2wA2LFMPjh1V1M8ekY6/AEGfMUgynL7b5HHP1xDLFsO5nRL7dcYEBVth2DJQYYYcixXAl34PscUSZYnjlMP6xcdv+Bis/I7THguuNAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAICAYAAAAMY1RdAAAAtklEQVQoka2QsQnCQABFX4JNcoUjKGgaufMKgwTBzsIFxLiB6ABuYZdCsBC0SeUSthbHBdxAEOwFEbUKBLFLXvmK/+BDhRibDYzN6r/erTICDIGzsZkuSqfVaB4mcTwTQrzLFtpB4HakdIEHsNBK7vLIfJ+mayGEVzbyhy2wrPquIi/gopV81oDuJkk+nu/fy672wtDrR5EArsBUK3kCcMoOFzE2WwFjINZK3nJf9V1HYFQMAHwB4EknBpWjYLgAAAAASUVORK5CYII=)

VC 1

|  |
| --- |
| 3 |

These structures are replicated for each Egress Port

OM14493B

Figure 6-8 Switch Arbitration Structure

The following two steps conceptually describe routing of traffic received by the Switch on Port 0 and Port 1 and destined to Port 2. First, the target Egress Port is determined based on address/routing information in the TLP header. Secondly, the target VC of the Egress Port is determined based on the TC/VC map of the Egress Port. Transactions that target the

same VC in the Egress Port but are from different Ingress Ports must be arbitrated before they can be forwarded to the corresponding resource in the Egress Port. This arbitration is referred to as the Port Arbitration.

Once the traffic reaches the destination VC resource in the Egress Port, it is subject to arbitration for the shared Link. From the Egress Port point of view this arbitration can be conceptually defined as a simple form of multiplexing where the multiplexing control is based on arbitration policies that are either fixed or configurable/programmable. This stage of arbitration between different VCs at an Egress Port is called the VC Arbitration of the Egress Port.

Independent of VC arbitration policy, a management/control logic associated with each VC must observe transaction ordering and flow control rules before it can make pending traffic visible to the arbitration mechanism.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

VC Control Logic at the Egress Port

VC control logic at every Egress Port includes:

• VC Flow Control logic

• VC Ordering Control logic

Flow control credits are exchanged between two Ports connected to the same Link. Availability of flow control

credits is one of the qualifiers that VC control logic must use to decide when a VC is allowed to compete for the

shared Link resource (i.e., Data Link Layer transmit/retry buffer). If a candidate packet cannot be submitted due to the lack of an adequate number of flow control credits, VC control logic must mask the presence of pending

packet to prevent blockage of traffic from other VCs. Note that since each VC includes buffering resources for

Posted Requests, Non-Posted Requests, and Completion packets, the VC control logic must also take into account availability of flow control credits for the particular candidate packet. In addition, VC control logic must observe ordering rules (see Section 2.4for more details) for Posted/Non-Posted/Completion transactions to prevent

deadlocks and violation of producer/consumer ordering model.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAFSCAYAAADPbZ6uAAAAS0lEQVRoge3MsQ0AIAwDwYQlaRmNlinDBCg9Ord/ckSzjHXqWffM0T0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwMfgApUoBaKUFdEYAAAAAElFTkSuQmCC)

[**6.3.3.2**](6.3.3.2) **VC Arbitration-Arbitration Between VCs**

This specification defines a default VC prioritization via the VC Identification (VC ID) assignment, i.e., the VC IDs are

arranged in ascending order of relative priority in the Virtual Channel Capability structure or Multi-Function Virtual

Channel Capability structure. The example in [Figure 6-9](#bookmark70)illustrates a Port that supports eight VCs with VC0 treated as the lowest priority and VC7 as the highest priority.

VC VC ID

Resource

Relative Priority

VC Arbitration Usage

Example

Extended VC Count = 7

For isochronous traffic

|  |
| --- |
| VC 7 |
| VC 6 |
| VC 5 |
| VC 4 VC 3 |
| VC 2 |
| VC 1 |
| VC 0 |

High

8th VC 7th VC 6th VC 5th VC 4th VC 3rd VC 2nd VC 1st VC

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAACUCAYAAACnQMjJAAABiUlEQVRYhe3ZQUvCYBgH8P/cVovmpchKyPfN16g0MwpkqQNTMJc5WUL0CYJOHQI7+I06dOmTRF0D/QJCnWd22cTmlK7B8z/teZ/392y8221ASPZSOy+7IvUc1lOCC4Jx1SyXy0PXHbquq3z0e+5kPxIy5KrlOLAdRwZgB5tTIHd01N1KJPTtZFLPZLPduUAwflKzLOHXtXp9XzB+OBNsxuOPecPQ/Pq0WFxY39johALBeOysWrVlWR6vKYoilyuVtmB8dQpomnZnNRqj4DNfNJsjVVVvfwHBuFo0zftlXdeCIBqNLhVN80EwrkzewbEdRw1u9nPZai0CaI7BoXeUs0BSCD2dyXQBICIYPz63rNSszX5qlpUWjGcjwaOclUKptLAWi3WUvGHYAD4BfHu9FQCSdz0CMAAASZIiRqHQlgTj1x/93pM/6fXt/QtA1CsHuezB+B0Ixm/8SfgLAMK/1rkhQIAAAQIECBAgQIAAAQIECBAgQIAAAQIECBD4f2Dqjx+A3MSgYbD5AzsBR0su+4f4AAAAAElFTkSuQmCC)

Strict

Priority

Pr ior ity Order

Low Priority Extended VC Count = 3

Governed by VC Arbitration Capability field (e.g. WRR)

For QoS usage

Default VC (PCI Express/PCI)

Low

OM14287

Figure 6-9 VCID and Priority Order- An Example

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

The availability of default prioritization does not restrict the type of algorithms that may be implemented to support VC arbitration - either implementation-specific or one of the architecture-defined methods:

• Strict Priority - Based on inherent prioritization,i.e., VC0 = lowest, VC7 = highest

• Round Robin (RR) - Simplest form of arbitration where all VCs have equal priority

• Weighted RR - Programmable weight factor determines the level of service

If strict priority arbitration is supported by the hardware for a subset of the VC resources, software can configure the VCs into two priority groups - a lower and an upper group. The upper group is treated as a strict priority arbitration group

while the lower group is arbitrated to only when there are no packets to process in the upper group.[Figure 6-9](#bookmark70)

illustrates an example configuration that supports eight VCs separated into two groups -the lower group consisting of VC0-VC3 and the upper group consisting of VC4-VC7. The arbitration within the lower group can be configured to one of the supported arbitration methods. The Low Priority Extended VC Countfield in the Port VC Capability Register 1

indicates the size of this group. The arbitration methods are listed in the VC Arbitration Capabilityfield in the Port VC Capability Register 2. Refer toSection 7.9.1and Section 7.9.2for details. When the Low Priority Extended VC Countfield is set to zero, all VCs are governed by the strict-priority VC arbitration; when the field is equal to the Extended VC Count, all VCs are governed by the VC arbitration indicated by the VC Arbitration Capabilityfield.

**6.3.3.2.1 Strict Priority Arbitration Model**

Strict priority arbitration enables minimal latency for high-priority transactions. However, there is potential danger of bandwidth starvation should it not be applied correctly. Using strict priority requires all high-priority traffic to be

regulated in terms of maximum peak bandwidth and Link usage duration. Regulation must be applied either at the

transaction injection Port/Function or within subsequent Egress Ports where data flows contend for a common Link. System software must configure traffic such that lower priority transactions will be serviced at a sufficient rate to avoid transaction timeouts.

**6.3.3.2.2 Round Robin Arbitration Model**

Round Robin arbitration is used to provide, at the transaction level, equal112 opportunities to all traffic. Note that this scheme is used where different unordered streams need to be serviced with the same priority.

In the case where differentiation is required, a Weighted Round Robin scheme can be used. The WRR scheme is

commonly used in the case where bandwidth regulation is not enforced by the sources of traffic and therefore it is not possible to use the priority scheme without risking starvation of lower priority traffic. The key is that this scheme

provides fairness during traffic contention by allowing at least one arbitration win per arbitration loop. Assigned weights regulate both minimum allowed bandwidth and maximum burstiness for each VC during the contention. This means

that it bounds the arbitration latency for traffic from different VCs. Note that latencies are also dependent on the maximum packet sizes allowed for traffic that is mapped onto those VCs.

One of the key usage models of the WRR scheme is support for QoS policy where different QoS levels can be provided using different weights.

Although weights can be fixed (by hardware implementation) for certain applications, to provide more generic support for different applications, components that support the WRR scheme are recommended to implement programmable WRR. Programming of WRR is controlled using the software interface defined in Sections 7.9.1 and 7.9.2.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

112. Note that this does not imply equivalence and fairness in the terms of bandwidth usage.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[**6.3.3.3**](6.3.3.3) **Port Arbitration-Arbitration Within VC**

For Switches, Port Arbitration refers to the arbitration at an Egress Port between traffic coming from other Ingress Ports that is mapped to the same VC. For Root Ports, Port Arbitration refers to the arbitration at a Root Egress Port between peer-to-peer traffic coming from other Root Ingress Ports that is mapped to the same VC. ForRCRBs, Port Arbitration

refers to the arbitration at theRCRB (e.g., for host memory) between traffic coming from Root Ports that is mapped to the same VC. An inherent prioritization scheme for arbitration among VCs in this context is not applicable since it would imply strict arbitration priority for different Ports. Traffic from different Ports can be arbitrated using the following

supported schemes:

• Hardware-fixed arbitration scheme, e.g., Round Robin

• Programmable WRR arbitration scheme

• Programmable Time-based WRR arbitration scheme

Hardware-fixed RR or RR-like scheme is the simplest to implement since it does not require any programmability. It makes all Ports equal priority, which is acceptable for applications where no software-managed differentiation or per-Port-based bandwidth budgeting is required.

Programmable WRR allows flexibility since it can operate as flat RR or if differentiation is required, different weights can be applied to traffic coming from different Ports in the similar manner as described in [Section 6.3.3.2 .](#bookmark69) This scheme is used where different allocation of bandwidth needs to be provided for different Ports.

A Time-based WRR is used for applications where not only different allocation of bandwidth is required but also a tight control of usage of that bandwidth. This scheme allows control of the amount of traffic that can be injected from

different Ports within a certain fixed period of time. This is required for certain applications such as isochronous services, where traffic needs to meet a strict deadline requirement.[Section 6.3.4](#bookmark71)provides basic rules to support isochronous

applications. For more details on time-based arbitration and on the isochronous service as a usage model for this arbitration scheme refer to Appendix A.

[**6.3.3.4**](6.3.3.4)**Multi-Function Devicesand Function Arbitration**

The multi-Function arbitration model defines an optional arbitration infrastructure and functionality within a

Multi-Function Device. This functionality is needed to support a set of arbitration policies that control traffic contention for the device’s Upstream Egress Port from its multiple Functions.

[Figure 6-10](#bookmark72)shows a conceptual model of a Multi-Function Device highlighting resources and associated functionality. Note that each Function optionally contains a VC Capability structure, which if present manages TC/VC mapping,

optional Port Arbitration, and optional VC Arbitration, all within the Function. The MFVC Capability structure manages

TC/VC mapping, optional Function Arbitration, and optional VC Arbitration for the device’s Upstream Egress Port.

Together these resources enable enhanced QoS management for Upstream requests. However, unlike a complete Switch with devices on its Downstream Ports, theMulti-Function Devicemodel does not support full QoS management for

peer-to-peer requests between Functions or for Downstream requests.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

VC Capability Structure MFVC Capability Structure

Managed Resources Managed Resources

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQoAAAAECAYAAAB2tnENAAAAWUlEQVRYhe3OoQ2DUAAFwAvFN1VVhAGoZIEu0xGbLlGJAsEKJASNZoL/xbsJDr74iIi4emPDs8WIuewnIirUocGrwR2Psp+IqFCPBcMNO35YS44iojoHJvxP7IMKM0uSygMAAAAASUVORK5CYII=)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAhQAAAAICAYAAACh8WYsAAACbElEQVR4nO3bT4hNYRjH8c+dO8yEhoUpMyJmKBMLoUFKkp0kFmRthxVlY2WhZossNAsLIopYUaJkoYTGQkOibJAm+VMWwzUW7+XO3K6ua+4958yd91tPp/Oct/f8ztM57/O87zknL5I0y7AXb/E1ZS2RSKT5acMu9GE4ZS2RSKSOXMJ9nEpbSCQSmRbswD2MYFHKWiKRSJ3YhA/oxSesSFdOJBKZBlzDIZzD8ZS1RCKROjADr3CjuP8AT9CSmqJIJNLsrMZ3dOGo8Jp1fqqKIk1Lrmz/CGZiv5DwfqAwbluo4GvEsXr09XPy4akrV4XY7hS0zcRdvBDinUVyyFew1jr7GtFnJd9GnBVWhwbrGKckmIcDwurWGjwT7qPfVijbr2a1tJ+qff+t/ViNsZ+q9AqvOg7jStE3gG3YjG8p6UqLXNFaErSkz5eUdWAJLuC1kN/+FBRdwo22Wxhw2/HQxIF5/ABd7mvEscn2NSaZwqVa+3XCR1GrsBCflViAl3iPN3gqW8m6RWlQLr/Gar5a2ibl24C5wgdqg8KMbVT26ccZLMZFIREMKz3cef8+ENTSttHt09JCdoqbRvTdgbVYjkfYqkReWCltxzvcrjGmU9lyQl6oJa7/a0mdJy2bjZXowRacwECrwGV0olvz/HnQIpnCpdqxj0UtB00sJgiFRCeu44vw50eWknVBc83mzhe33RgSvmHZLlxnVmnDTdzCeuFhjkyOSrPGZiqcRoVVuGM4XXbtBSzFSWGSMyL95JSUjWmu8Swr9OGxkMP04DnmpKkoEkmYWbiDfWkLqcIeoeAsfz0ZiUQiWaEfQ78AIM0MiopGCCAAAAAASUVORK5CYII=)

Internal Link

Function 0

Multi-function Glue Logic

、

I I I I I I I I I I I I I I I I I I I I I I I I I I

![](data:image/png;base64,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)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAYCAYAAADH2bwQAAAAsElEQVQokYXQLW5CURRF4Y+fhLQVLwgEqgISDJ3BE7gOBIUgzIdJEGZQS1AkBNMEg0GQIAiBGlrBIwi4p9tscVfOOudyT1eQDIdnD+Wic8wioIevSDEvpoT+Wkpx8/+kgFHkrmKJSwR08BsB6/+ABurRHrnrPyTzgmPRDynjhDP6z4BK0ZnrNdOUpok93qJdvjGOgE/s0I6gIRZ4TQElbDCJpmRYYRBBLWzxEUHvKP0BadEbcLX5XJAAAAAASUVORK5CYII=) Optional Port ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAkAAAAcCAYAAACzipU4AAAA30lEQVQ4jYXSPyvFURgH8A+X4cYify8Ws4VSisRgs7ol3oUM3oIoL8GmeB2UFLOMIoPBchlYDKdbv56cc77bOefT83TOc1rKmcdwq4JO0KkYT1gvgSn8YGSwgPZxia9SpWdslcABesh2WsAHlnNgFK84yoE5POIm16aLNxxjIFflFg+5w37a0nuc1mBHuvZhPGgOuCdNfRFXTRRv8YLpWCmiWcxENBTWd5ioVdrAag0t4SKiZrbxiZUc2MEv9nLgHN/YLLUZx7306YsZkx5ytwbX8I7JGjwT5vZf2riOm3+3qCIXkiDXmwAAAABJRU5ErkJggg==)

TC/VC Mapping

TC[0:1] TC7

VC0 VC3

TC[0:1] TC7

Arbitration

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAUCAYAAABBECfmAAABI0lEQVQokbWQMU7DQBBFv21tsvaGZDepoIhTkBO4tkQXmcYSHQVnQD4EJUVu4YqCA7jCB0iFhYQQHU0UASHBRtGnwSEGWn43/41m5g/wrSGAEwA2fkgrpZ601pUx5qpBhBDncRy/rVYrdrvdNYDDLTTGPGRZRpJMkqRSSl3W7KDT6bxvNhuSZJ7n7Pf79zU8nUwmL/xSWZaUUlYAjN3r9aIoivbqzlarhSAI1gBCWwgxHI1GjQPH47EAsP8rEwBYlgX8FXhX/wlJNsy6tququiuKokFns9kHgEcAOA6C4Ln+0GKxoJSyBOACgNdut8v5fE6STNOUg8HgZjtGa309nU5JkmEYvjqOc7a75sj3/WVRFHRddwlA7kJLKXULgJ7nXdTmJyRRdvvcbgmwAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAAYCAYAAAA/OUfnAAAAbElEQVQYlY3PQQqCYBiE4Sd/kwohWroTvEBX8EZdrnsE4b5Ft0jQhb9giuLshvnmZT44o0aACh0uiYnWjVi84jAPVPhNaek2LcT7F5oFrcATp51DA464xd6/cjwM77ujRZqgxBftaD4jOsMbelkuDdClP6oyAAAAAElFTkSuQmCC) External Port

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAYCAYAAADH2bwQAAAAxUlEQVQokX3QMUpDURBG4c8XQlAQHmmMgk16sTBNShEhO0jhXlxBOnEJNlZB7GwkKzAbCEmRQgTtVAJBi5dXGO/c00wxZ+YfhoonHEpQbOozJjhNSTVjvEabaq7xkYqoWeAtmi7xhV4k3OAxag7xifZ2o77hAnd4T023sMJxtP5EdX2SAgPMckIHzZxwj91IgH38+P/VPyzQjSLgW/WsUHhAPxdRqp51lpNuMcVeJBSY4wVHkdTAaBN3mYs7xxJXOxnpAOtf9csegqAwiJcAAAAASUVORK5CYII=) and/or VC ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAANCAYAAABhPKSIAAAAZUlEQVQYlV3OsQ2CUBiF0fPecwEbOp2ChhUonICEwGAu4wRaEByBxE5jqx15+W958hUXVnTCRtyQaix44BLrHgsONSY8cY31hHvEjDeGUuEPLV451BvmEvCEYyw/+Ebc/9U7o/kDO3AOOtnGMe0AAAAASUVORK5CYII=)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAdCAYAAACXFC2jAAAA9UlEQVQokX3SLUtEQRTG8R97xbCKb2VBg4iaFyx20WYQBMNGq8Eo+BlMgsGvYLAYbYplQZOwmhREFF8Q3aDRMF65DHfmSYd5/vMc5pwpsItNvOBRpAK3mMIhtjCBN7zGcANLuMYHfrATQ6VWcYdWnTmEeyynbp/jNGW28Il2CtjDfsps41t48r8alXoFV2qGVeoEnZTZxBfGY6NssY1nYYK1wAgu66JLoIluDpj/a5EEFoUdJIEb9HLAHGZzQBejOeBJ+JdJLQhDGsxBZ1iLD4tKPYB1HKUSxoSfPJ1rc4GDHDCJ92pKEQF9YXEbOE6lDOMBM/ALOz4pCI9ePE8AAAAASUVORK5CYII=) Arbitration ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAATCAYAAACk9eypAAAAmUlEQVQokZXSsQpBcRQH4O8q1F0MrJJSymi+g8zewmLDk5hsZpv3oAySMigvwGB0N8N9AOd/5u93Oud0MvGaYFxLCMyQJ3hnFFHcRYlmdKQpHiijgQK76Dh1fDGMBuY4IovgBt4SrrNSLRuqDl4YRXCGCw5RvMUV/UjghDtaEbzAE70IXqpOOPgHc2zwwTrS+YY92hFMwo/ADzqAFx0a1jgtAAAAAElFTkSuQmCC)

TC/VC Mapping

Function 1

VC0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAUCAYAAABBECfmAAABUElEQVQokWXRQU7yQBiA4bfj2EmnmQZiiBpCaKIbXZD0AKzd/MQFRzDhCsYlR3DtRUyPIRsjXRAWiK6shL+tQMeF0hB5t8/km/ky8JMbBEFcq9Vi4JjdjDH33W43GwwG63q9/rhrl8aYbD6f2zRNrdY6B04ACILgYTgclva3fr+/BG4AhFLqIooiZzum0+lo13XPAcR6vW6HYVjdEYYhxphLAJFl2VGz2ayw3W7jOM4ZgLDWCillha1Wi6IoTgFQSuVpmm7fY/M8t1LKDXAg+JNSCt/3v4DjPdzJ7mFRFCyXSxd438PZbIbneR/ARjiOU65Wqwqn0ylKqVcAobV+n0wmFSZJQlmWzwBCCPGSJEmF4/F4s1gsngDwPO+u1+v93+4ZRdEn8G972DPGvMVxbEejkfV9/wM4rEZJKa+01kWj0ciMMbd7G0spr4EroPq+b3zUg8OuSV/aAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA4AAABACAYAAAAqGkbNAAAByElEQVRIib3Wy4uOcRTA8c/7vDNJr41cmo0poYkYCwusKM1CTXJpsuQvEOUfYGOvZEUWFpazZEGyQW7JJSmJhCHllvttcd63xnh65zm/he/y+T3fzvk9v3PO72nLsx9TWWkznmF+RlqMpxjPRpvEg6y0SUGKA/isIMUduJGV4AJ2Z6Vl+I7BmQvVLOJWnO7KKa5jb1YivuZIVpqHT2jVLfbb42q8xO+sOIq5DbP7i6V4UiLOwTe06xb7pfoVP7EyK8I10bxpJnCuROzgA4ZL5Ec4XiKOikLoTH9Y+6lnMIUNGMLlbNQx0VpDWREO46zZj/AfBnAVR7PiWtwXQ7kxZ/BeTIPa/qzjQDfK+kykE3gsWTnb8RHrMtI2vJVMr4XbOJWRiLvijji3xgyKNhrLRpvA3awEl7ArK+3EFw33Nr3Sx3EIPzLRVuAdFmYkOCYqvzG9VBfhSDZaC68UjMBVYgSmqMSIv/jfROLcikb8mxKJuAPTVKLTi/glCiBFGxvxAg8zYoUrXTlFhXtizqQZFg2c2mdb9OEIFojbKMUWUeiNL5QevfPckxVhDV5jeYm8D8/Ff1yKFm7ipIL9dnALB7MiLMH5fi/8ARlEUfZEVDqDAAAAAElFTkSuQmCC) TC/VC ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAKCAYAAAB8OZQwAAAAUUlEQVQImW3KIQ5AcBjG4QebOYBk/+4EkuQOZhOcVZUUxRF02abaN2983h8kPzsxRJywI/9ihg1LrHvcqOJxYI44Yo1Y4kJbfPBBjS4LdULzAtFuCYzSzzhQAAAAAElFTkSuQmCC)

Internal Link

TC[0:1]

TC[2:4]

TC[5:6]

TC7

Mapping ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAALCAYAAAC3ZUeVAAAAZ0lEQVQImV3OsQ2CUBAG4I/X2NFIZ2KrEzACHVMwAns4gL0rWOgqVq8kYQAKExpIjnfN5f9yf3KV41zQVAU+8I9QY8Y1BRzwQd7hhAVtrI74Rjhjwj3iG8/iCxm/CAm3bXfldY/XHla5zAzRV0mYUAAAAABJRU5ErkJggg==)

Optional Port i

I I

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAJCAYAAAAYcf3nAAAAOklEQVQImQXBsQmAMAAEwPMVsQi4QFI6ib3TOpBgWhewyt2Egh0u3EHFGzT04MQSfPhnHFiDjho82AYMPgdvY2oIWAAAAABJRU5ErkJggg==) VC1

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFMAAAAFCAYAAAA5ZdDqAAAATElEQVQ4je3QMRGAMBREwWWig5qSHhPRhI84QAsNSpBAkyhI8SdMtrn2zUFGMnVLKHXv4JZf2PFiiw4Z3VL3wYorsGV47cwDp3lmlw9OPgYK5dFJuQAAAABJRU5ErkJggg==)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAUCAYAAABBECfmAAABKElEQVQokcWQsUrDYBSFT/InzV8hSUMoZAkiuHXRDBniIESXLsWlu6vgk7j3FYodu7hmcOhDOCm4lEAq2qTWX46DJqR9Ac94vss9517gV5rruneaptEwjCvs6SIMw4/5fM5ut7sGcNAQz/MeJpMJSTJN03chxHXNpGVZn0VRkCRnsxl933+s4flgMHjjn5bLJaWUFQBDl1JeDofDJqPf7yMIgi8AJ7pt22dxHBvtdkmSCACnOkm90+nsVLcsSwOg6/s3tfUvkOR6tVrtmHmefwOoIIS4GY/HZf0hpRRt294ACAHg0HGcjVKKJLlYLNjr9V7qzGchxGuWZQCA6XS6VUrdNxmmad6ORqN1WZb1yqN2B0dKWUVRtPU8L6tNrTWQAjgGkAF4AoAfD5h1SlAQfIoAAAAASUVORK5CYII=)

Optional Function Arbitration

TC0,TC[2:4] ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABcAAAAMCAYAAACJOyb4AAAAc0lEQVQ4jdXSoQrCABSG0aPTYpjVZNKwYN4rrflUNsE3sBvGoq8wZGCyL4jC+o/g1245Fy63kG2PBV5QhPEzlrjBPIxP+l883QblTzalv+WCNVreP7nCIYRvUaHGfYYdTiG8whM9mpD57YrjZ0jffECHB4zFFAzwd1Vb2AAAAABJRU5ErkJggg==)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAICAYAAADTLS5CAAAAJUlEQVQImWNgYGB4zMDAIMvEAAUoDF4GBgY+FJHPDAwMnzAVAwBxsgMPgq17sgAAAABJRU5ErkJggg==) VC0

TC0,TC[2:4]

I I

Arbitration

VC2

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFMAAAAECAYAAADyOQNPAAAAQklEQVQ4je3OUQmAMBQAwBsuyb5NZgt/ZJ32tQYmsYGwEsLjgZfg4Mbu94kDEyU6kl3BhgcDV2wnt4oXHSdabCe3BQ60Boiwnej7AAAAAElFTkSuQmCC)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAUCAYAAABBECfmAAABJElEQVQokcWPv0rDcBSFv/wigYTQWxMotOIYsFBXl+gg7dDHcOxLdLRP4FBwcfANursVxC4NPoAUAoI4lVr801+vQ402fQHPds8H55wLfzryPO8KiNnRYRAEizRNv0QkA5xfEgTBZa/X+7DWar1eXwAnBXPCMHydTqeqqjoYDKyI3BQwieP4bb1eq6pqlmUqIs8AxnXd83a7jeNsalqtFtbafeDAiEi30+kERYwxhjRNP4EzY4yJarVaaXqj0dgDxOz+tK1/g9baklncZrlcPkwmkxIdj8cr4BHgNEmSuf4oz3P1ff8NcA1wn+e5O5vNABiNRvi+fwds0iqVynW/31+pqjabzTnQ3a45FpH34XCoYRi+AG5pYbVavY2i6MnzvIvC+wblc2lI0UoZ0wAAAABJRU5ErkJggg==)

I

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAUCAYAAABBECfmAAABHElEQVQokcWQsUrDUBSGP2IMt72UG1ooxKGDDgWhKCFLJl9AcAg+QV6hD1BHX6GT79DBd3DJ4O6SWAoigq21yO09Lk1pi7vfdv7vwPk5sCEIgttWq/UMXHDApTHmezgcitb6DTjaGmPMw2g0siIig8FgDlzX7lgptSzLUkRExuOxdDqdx1pe9fv9T9kwnU5FKbUEfE9rfZNlma43oyii1+tZIPUajUacJIm32y5NUx849wA8b89t5/30gH+Rzrn32Wy2F1ZVZYEPgDzLskX9ofV6LVrrFRABnLXb7aVzTkREiqIQY8xrffPFWrsoigKAyWTiRGT7eJRSd3mer6y10u12v4B4t8NJs9mcx3H8E4bh01/NT33fvwfCOvgFw4hyWTKSQI0AAAAASUVORK5CYII=)( and/or VC 、 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA0AAAAQCAYAAADNo/U5AAAAnklEQVQokZXRoQ6BYRQG4Of3/1GwiW7AbLgBN6AK3IBNU7kB0yTDbVBcgY2mqKYJihmCJPyS9H2nP+c9e0+KMjJ8BE6KJSrYhyJo4YxCDErwwCgGQRUv9GPhGDesRZ7awAU7NGNghi2eOGAobzloipjjhDs2mKAWuqCHKd4YhCJYYBUDOriiFAqSH5jFpLTlZQT/LpHX3o1JqeP4n/IFIpwax06aP48AAAAASUVORK5CYII=) Arbitration ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAZCAYAAAAFbs/PAAAAuUlEQVQ4jZXSsUrCYRTG4ScNBW0onKpVSAI3tyb/oDR1C3YNXkDRFQTdQKCbe1chDe7tDQ4GBUY0NNju+535+X3nDN+BfM7QOSwIKlzXCgJQErTQLAkGuCwJzvGQ4g6+cZJuqLDGJg36mKXnwAqjFHfxg3YaPOM+xT384jgNXjBN8QRvaKSnfOEuwWO8/2/YOxf4xGPJy7cJruxufkrwHBsMEwwfeE0xHGGLmwTX7T7WKa6wKNmyTOAf0Tccq5nHZ6gAAAAASUVORK5CYII=)

I

VC3

Optional

I I

VC

Arbitration

I

Internal Link

I

Function 2

I I

I I

|  |
| --- |
| TC0 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAUCAYAAABBECfmAAABTklEQVQokW3Qv07CUBTH8W//BNvbS6sDJAzEBNNFB+JETAgvwBM4+QDszM7uPoUzb8CCm4MxMaYUQowJDoj1eqWWOigNCf62k0/yOzkHfuP5vn/n+/4TcMx2hBCXnU7ns9frZUEQ3GzboRBCRVGUz+fz3HVdDRwAIKW87vf73/lfut3uO3ABYDqOc9put61NTavVko7jnACYaZo2wjAsdoRhiJSyCWBqrfdrtVqBjUaD9Xp9BGACGIZRYL1eR2tdLXA71WqV1WrlAXs7aFkWQRBooLaDAEopG3jbweVySZZlBrDYwdlshhDiFchNy7JSpVSB0+kU27afAUzXdV8mk0mBcRyTZdkjgGkYRhTHcYHj8XidJMkDgKmUuh0MBl8bHA6HH2ma3m/mwPO8xWg0yqMoyoUQCeAUVaVS6VxKqSuViiqXy1f/3d4Ezth66Q8kRnoEVSUJPgAAAABJRU5ErkJggg==)

TC0

I

VC0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAFCAYAAABvsz2cAAAAJElEQVQImWNkYGDQZWBg4GZhYGCIYmBgkGdigAIUxj8GBoa/AB65Ari2tmV/AAAAAElFTkSuQmCC)

I

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAECAYAAACk7+45AAAAJElEQVQImS3BQQ0AMAgEsOYSDCBm1mcGHXvvQwsHNyh0rOBhPiLHAt21GApKAAAAAElFTkSuQmCC)

l

A-0411B

Figure 6-10 Multi-Function Arbitration Model

QoS for an Upstream request originating at a Function is managed as follows. First, a Function-specific mechanism applies a TC to the request. For example, a device driver might configure a Function to tag all its requests with TC7.

Next, if the Function contains a VC Capability structure, it specifies the TC/VC mapping to one of the Function’s VC

resources (perhaps the Function’s single VC resource). In addition, the VC Capability structure supports the enablement and configuration of the Function’s VC resources.

If the Function is a Switch and the target VC resource supports Port Arbitration, this mechanism governs how the

Switch’s multiple Downstream Ingress Ports arbitrate for that VC resource. If the Port Arbitration mechanism supports time-based WRR, this also governs the injection rate of requests from each Downstream Ingress Port.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

If the Function supports VC arbitration, this mechanism manages how the Function’s multiple VC resources arbitrate for the conceptual internal link to the MFVC resources.

Once a request packet conceptually arrives at MFVC resources, address/routing information in the TLP header

determines whether the request goes Upstream or peer-to-peer to another Function. For the case of peer-to-peer, QoS management is left to unarchitected device-specific mechanisms. For the case of Upstream, TC/VC mapping in the MFVC Capability structure determines which VC resource the request will target. The MFVC Capability structure also supports enablement and configuration of the VC resources in the multi-Function glue logic. If the target VC resource supports

Function Arbitration, this mechanism governs how the multiple Functions arbitrate for this VC resource. If the Function Arbitration mechanism supports time-based WRR, this governs the injection rate of requests for each Function into this VC resource.

Finally, if the MFVC Capability structure supports VC Arbitration, this mechanism governs how the MFVC’s multiple VCs compete for the device’s Upstream Egress Port. Independent of VC arbitration policy, management/control logic

associated with each VC must observe transaction ordering and flow control rules before it can make pending traffic visible to the arbitration mechanism.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAMWCAYAAADMO8f9AAAAd0lEQVR4nO3MsQ0AIAwDwYQlaRmNlinDBCg10rn9kyOaZaxTz7pnju4BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgI3AB+8UJKkPo3scAAAAASUVORK5CYII=)

**IMPLEMENTATION NOTE**

Multi-Function Arbitration Error Behavior

[Table 6-6](#bookmark73)shows the expected error behavior associated with the example topology shown in [Figure 6-10 .](#bookmark72)

Table 6-6 Multi-Function Arbitration Error Model Example

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Source | TC | Destination | | | |
| Function 0 | Function 1 | Function 2 | External Port |
| Function 0 | 0 | n/a | OK | OK | OK |
| 1 | MF @ F1 | MF @ F2 | OK |
| 2 - 6 | MF @ F0 | MF @ F0 | MF @ F0 |
| 7 | MF @ F1 | MF @ F2 | OK |
| Function 1 | 0 | OK | n/a | OK | OK |
| 1 | MF @ F1 | MF @ F1 | MF @ F1 |
| 2 - 4 | MF @ F0 | MF @ F2 | OK |
| 5 - 7 | MF @ F1 | MF @ F1 | MF @ F1 |
| Function 2 | 0 | OK | OK | n/a | OK |
| 1 - 7 | MF @ F2 | MF @ F2 | MF @ F2 |
| External Port | 0 | OK | OK | OK | n/a |
| 1 | OK | MF @ F1 | MF @ F2 |
| 2 - 4 | MF @ F0 | OK |
| 5 - 6 | MF @ F1 |
| 7 | OK |

**Legend:**

|  |  |
| --- | --- |
| OK | Success |
| MF @ F0 | Malformed TLP, reported at Function 0 |
| MF @ F1 | Malformed TLP, reported at Function 1 |
| MF @ F2 | Malformed TLP, reported at Function 2 |
| n/a | Not Applicable (Function/Port sending to itself) |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Multi-Function Devices without the MFVC Capability Structure

If a Multi-Function Device lacks an MFVC Capability structure, the arbitration of data flows from different

Functions of a Multi-Function Deviceis beyond the scope of this specification However, if a Multi-Function Device supports TCs other than TC0 and does not implement an MFVC Capability structure, it must implement a single VC Capability structure in Function 0 to provide architectedTC/VC mappings for the Link.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADGCAYAAADv7cFPAAAAPUlEQVRYhe3MMREAIAwEwQSTtEijRWVQwEQA++3tfESzjHXqWffM0T0AAAAAAAAAAAAAAAAAAAAAAAB8CC60sASKUWe2GAAAAABJRU5ErkJggg==)

**6.3.4 Isochronous Support**

Servicing isochronous data transfer requires a system to provide not only guaranteed data bandwidth but also

deterministic service latency. The isochronous support mechanisms are defined to ensure that isochronous traffic

receives its allocated bandwidth over a relevant period of time while also preventing starvation of the other traffic in the system. Isochronous support mechanisms apply to communication between Endpoint and Root Complex as well as to peer-to-peer communication.

Isochronous service is realized through proper use of mechanisms such as TC transaction labeling, VC data-transfer

protocol, and TC-to-VC mapping. End-to-end isochronous service requires software to set up proper configuration along the path between the Requester and the Completer. This section describes the rules for software configuration and the rules hardware components must follow to provide end-to-end isochronous services. More information and background material regarding isochronous applications and isochronous service design guidelines can be found in Appendix A.

[**6.3.4.1**](6.3.4.1) **Rules for Software Configuration**

System software must obey the following rules to configure PCI Express fabric for isochronous traffic:

• Software must designate one or more TCs for isochronous transactions.

• Software must ensure that the Attribute fields of all isochronous requests targeting the same Completer are fixed and identical.

• Software must configure all VC resources used to support isochronous traffic to be serviced (arbitrated) at the requisite bandwidth and latency to meet the application objectives. This may be accomplished using strict

priority, WRR, or hardware-fixed arbitration.

• Software should not intermix isochronous traffic with non-isochronous traffic on a given VC.

• Software must observe the Maximum TimeSlots capability reported by the Port or RCRB.

• Software must not assign all Link capacity to isochronous traffic. This is required to ensure the requisite forward progress of other non-isochronous transactions to avoid false transaction timeouts.

• Software must limit the Max\_Payload\_Size for each path that supports isochronous to meet the isochronous latency. For example, all traffic flowing on a path from an isochronous capable device to the Root Complex should be limited to packets that do not exceed the Max\_Payload\_Size required to meet the isochronous

latency requirements.

• Software must set Max\_Read\_Request\_Size of an isochronous-configured device with a value that does not exceed the Max\_Payload\_Size set for the device.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[**6.3.4.2**](6.3.4.2) **Rules for Requesters**

A Requester requiring isochronous services must obey the following rules:

• The value in the Length field of read requests must never exceed Max\_Payload\_Size.

• If isochronous traffic targets the Root Complex and the RCRBindicates it cannot meet the isochronous

bandwidth and latency requirements without requiring all transactions to set theNo Snoopattribute bit,

indicated by setting the Reject Snoop Transactions bit, then this bit must be set within the TLP header else the transaction will be rejected.

[**6.3.4.3**](6.3.4.3) **Rules for Completers**

A Completer providing isochronous services must obey the following rules:

• A Completer should not apply flow control induced backpressure to uniformly injected isochronous requests under normal operating conditions.

• A Completer must report its isochronous bandwidth capability in the Maximum TimeSlots field in the VC Resource Capability register. Note that a Completer must account for partial writes.

• A Completer must observe the maximum isochronous transaction latency.

• A Root Complex as a Completer must implement at least one RCRBand support time-based Port Arbitration for the associated VCs. Note that time-based Port Arbitration only applies to request transactions.

[**6.3.4.4**](6.3.4.4) **Rules for Switches and Root Complexes**

A Switch providing isochronous services must obey the following rules. The same rules apply to Root Complexes that support isochronous data flows peer-to-peer between Root Ports, abbreviated in this section as “P2P-RC”

• An isochronous-configured Switch or P2P-RC Port should not apply flow control induced backpressure to uniformly injected isochronous requests under normal operating conditions.

• An isochronous-configured Switch or P2P-RC Port must observe the maximum isochronous transaction latency.

• A Switch or P2P-RC component must support time-based Port Arbitration for each Port that supports one or more VCs capable of supporting isochronous traffic. Note that time-based Port Arbitration applies to request

transactions but not to completion transactions.

[**6.3.4.5**](6.3.4.5) **Rules forMulti-Function Devices**

A Multi-Function Devicethat includes an MFVC Capability structure providing isochronous services must obey the following rules:

• MFVC glue logic configured for isochronous operation should not apply backpressure to uniformly injected isochronous requests from its Functions under normal operating conditions.

• The MFVC Capability structure must support time-based Function Arbitration for each VC capable of

supporting isochronous traffic. Note that time-based Function Arbitration applies only to Upstream request

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

transactions; it does not apply to any Downstream or peer-to-peer request transactions, nor to any completion transactions.

A Multi-Function Devicethat lacks an MFVC Capability structure has no architected mechanism to provide isochronous services for its multiple Functions concurrently.

**6.4 Device Synchronization**

System software requires a “stop” mechanism for ensuring that there are no outstanding transactions for a particular

device in a system. For example, without such a mechanism renumbering Bus Numbers during system operation may cause the Requester ID (which includes the Bus Number) for a given device to change while Requests or Completions for that device are still in flight, and may thus be rendered invalid due to the change in the Requester ID. It is also desirable to be able to ensure that there are no outstanding transactions during a Hot-Plug orderly removal.

The details of stop mechanism implementation depend on the device hardware, device driver software, and system

software. However, the fundamental requirements which must be supported to allow system software management of the fabric include the abilities to:

• Block the device from generating new Requests

• Block the generation of Requests issued to the device

• Determine that all Requests being serviced by the device have been completed

• Determine that all non-posted Requests initiated by the device have completed

• Determine that all posted Requests initiated by the device have reached their destination

The ability of the driver and/or system software to block new Requests from the device is supported by the Bus Master Enable,SERR# Enable, and Interrupt Disable bits in the Command register (Section7.5.1.1.3) of each device Function, and other such control bits.

Requests issued to the device are generally under the direct control of the driver, so system software can block these Requests by directing the driver to stop generating them (the details of this communication are system software

specific). Similarly, Requests serviced by the device are normally under the device driver ’s control, so determining the completion of such requests is usually trivial.

The Transactions Pending bit provides a consistent way on a per-Function basis for software to determine that all non-posted Requests issued by the device have been completed (see Section 7.5.3.5).

Determining that posted Requests have reached their destination is handled by generating a transaction to “flush” any outstanding Requests. Writes to system memory using TC0 will be flushed by host reads of the device, and so require no explicit flush protocol. Writes using TCs other than TC0 require some type of flush synchronization mechanism. The

mechanism itself is implementation specific to the device and its driver software. However, in all cases the device

hardware and software implementers should thoroughly understand the ordering rules described in Section 2.4 . This is especially true if the Relaxed Orderingor ID-Based Orderingattributes are set for any Requests initiated by the device.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Flush Mechanisms

In a simple case such as that of an Endpoint communicating only with host memory through TC0, “flush” can be implemented simply by reading from the Endpoint. If the Endpoint issues writes to main memory using TCs other than TC0, “flush” can be implemented with a memory read on the corresponding TCs directed to main memory. The memory read needs to be performed on all TCs that the Endpoint is using.

If a memory read is used to “flush” outstanding transactions, but no actual read is required, it may be desirable to use the zero-length read semantic described in Section 2.2.5 .

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADTCAYAAAC89lJnAAAAP0lEQVRYhe3MoREAIAwEwYQmsZSGpcpQAROL2Le38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAD+DC2fgBKRr/31wAAAAAElFTkSuQmCC)

Peer-to-peer interaction between devices requires an explicit synchronization protocol between the involved devices,

even if all communication is through TC0. For a given system, the model for managing peer-to-peer interaction must be established. System software, and device hardware and software must then conform to this model. The requirements for blocking Request generation and determining completion of Requests match the requirements for non-peer interaction, however the determination that Posted Requests have reached peer destination device(s) requires an explicit

synchronization mechanism. The mechanism itself is implementation specific to the device, its driver software, and the model used for the establishment and disestablishment of peer communications.

**6.5 Locked Transactions**

**6.5.1 Introduction**

Locked Transaction support is required to prevent deadlock in systems that use legacy software which causes the

accesses to I/O devices. Note that some CPUs may generate locked accesses as a result of executing instructions that implicitly trigger lock. Some legacy software misuses these transactions and generates locked sequences even when exclusive access is not required. Since locked accesses to I/O devices introduce potential deadlocks apart from those mentioned above, as well as serious performance degradation, PCI Express Endpoints are prohibited from supporting locked accesses, and new software must not use instructions which will cause locked accesses to I/O devices. Legacy Endpoints support locked accesses only for compatibility with existing software.

Only the Root Complex is allowed to initiate Locked Requests on PCI Express. Locked Requests initiated by Endpoints

and Bridges are not supported. This is consistent with limitations for locked transaction use outlined in [PCI] (Appendix F - Exclusive Accesses).

This section specifies the rules associated with supporting locked accesses from the Host CPU to Legacy Endpoints, including the propagation of those transactions through Switches and PCI Express/PCI Bridges.

**6.5.2 Initiation and Propagation of Locked Transactions- Rules**

Locked transaction sequences are generated by the Host CPU(s) as one or more reads followed by a number of writes to the same location(s). When a lock is established, all other traffic is blocked from using the path between the Root

Complex and the locked Legacy Endpoint or Bridge.

• A locked transaction sequence or attempted locked transaction sequence is initiated on PCI Express using the “lock”-type Read Request/Completion (MRdLk/CplDLk) and terminated with the Unlock Message

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

。 Locked Requests which are completed with a status other than Successful Completion do not establish lock (explained in detail in the following sections)

。 Regardless of the status of any of the Completions associated with a locked sequence, all locked sequences and attempted locked sequences must be terminated by the transmission of an Unlock Message.

。 MRdLk, CplDLk, and Unlock semantics are allowed only for the default Traffic Class (TC0)

。 Only one locked transaction sequence attempt may be in progress at a given time within a single hierarchy domain

• The Unlock Message is sent from the Root Complex down the locked transaction path to the Completer, and may be broadcast from the Root Complex to all Endpoints and Bridges

。 Any device which is not involved in the locked sequence must ignore this Message

• Any violation of the rules for initiation and propagation of locked transactions can result in undefined device and/or system behavior

。 The initiation and propagation of a locked transaction sequence through PCI Express is performed as follows:

• A locked transaction sequence is started with a MRdLk Request

。 Any successive reads for the locked transaction sequence must also use MRdLk Requests

。 The Completions for any MRdLk Request use the CplDLk Completion type for successful Requests, and the CplLk Completion type for unsuccessful Requests

• If any read associated with a locked sequence is completed unsuccessfully, the Requester must assume that the atomicity of the lock is no longer assured, and that the path between the Requester and Completer is no longer locked

• All writes for the locked sequence use MWr Requests

• The Unlock Message is used to indicate the end of a locked sequence 。 A Switch propagates Unlock Messages to the locked Egress Port

• Upon receiving an Unlock Message, a Legacy Endpoint or Bridge must unlock itself if it is in a locked state 。 If not locked, or if the Receiver is a PCI Express Endpoint or Bridge which does not support lock, the

Unlock Message is ignored and discarded

**6.5.3 Switches and Lock- Rules**

Switches must distinguish transactions associated with locked sequences from other transactions to prevent other

transactions from interfering with the lock and potentially causing deadlock. The following rules cover how this is done. Note that locked accesses are limited to TC0, which is always mapped to VC0.

• When a Switch propagates a MRdLk Request from the Ingress Port (closest to the Root Complex) to the Egress Port, it must block all Requests which map to the default Virtual Channel (VC0) from being propagated to the Egress Port

。 If a subsequent MRdLk Request is Received at this Ingress Port addressing a different Egress Port, the behavior of the Switch is undefined

Note: This sort of split-lock access is not supported by PCI Express and software must not cause such a locked access. System deadlock may result from such accesses.

• When the CplDLk for the first MRdLk Request is returned, if the Completion indicates a Successful Completion status, the Switch must block all Requests from all other Ports from being propagated to either of the Ports involved in the locked access, except for Requests which map to non-VC0 on the Egress Port

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• The two Ports involved in the locked sequence must remain blocked as described above until the Switch receives the Unlock Message (at the Ingress Port for the initial MRdLk Request)

。 The Unlock Message must be forwarded to the locked Egress Port 。 The Unlock Message may be broadcast to all other Ports

。 The Ingress Port is unblocked once the Unlock Message arrives, and the Egress Port(s) which were blocked are unblocked following the Transmission of the Unlock Message out of the Egress Ports

▪ Ports which were not involved in the locked access are unaffected by the Unlock Message

**6.5.4 PCI Express/PCI Bridges and Lock- Rules**

The requirements for PCI Express/PCI Bridges are similar to those for Switches, except that, because PCI Express/PCI Bridges use only the default Virtual Channel and Traffic Class, all other traffic is blocked during the locked access. The requirements on the PCI bus side of the PCI Express/PCI Bridge match the requirements for a PCI/PCI Bridge (see

[PCI-to-PCI-Bridge-1.2] and [PCIe-to-PCI-PCI-X-Bridge-1.0]).

**6.5.5 Root Complex and Lock- Rules**

A Root Complex is permitted to support locked transactions as a Requester. If locked transactions are supported, a Root Complex must follow the sequence described in[Section 6.5.2](#bookmark74)to perform a locked access. The mechanisms used by the Root Complex to interface PCI Express to the Host CPU(s) are outside the scope of this document.

**6.5.6 Legacy Endpoints**

Legacy Endpoints are permitted to support locked accesses, although their use is discouraged. If locked accesses are supported, Legacy Endpoints must handle them as follows:

• The Legacy Endpoint becomes locked when it Transmits the first Completion for the first Read Request of the locked access with a Successful Completion status

。 If the completion status is not Successful Completion, the Legacy Endpoint does not become locked 。 Once locked, the Legacy Endpoint must remain locked until it receives the Unlock Message

• While locked, a Legacy Endpoint must not issue any Requests using TCs which map to the default Virtual Channel (VC0)

Note that this requirement applies to all possible sources of Requests within the Endpoint, in the case where there is more than one possible source of Requests.

。 Requests may be issued using TCs which map to VCs other than the default Virtual Channel

**6.5.7 PCI Express Endpoints**

PCI Express Endpoints do not support lock. A PCI Express Endpoint must treat a MRdLk Request as an Unsupported Request (seeChapter 2).

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.6 PCI Express Reset - Rules**

This section specifies the PCI Express Reset mechanisms. This section covers the relationship between the architectural mechanisms defined in this document and the reset mechanisms defined in this document. Any relationship between the PCI Express Conventional Reset and component or platform reset is component or platform specific (except as

explicitly noted).

**6.6.1 Conventional Reset**

Conventional Reset includes all reset mechanisms other than Function Level Reset. There are two categories of

Conventional Resets: Fundamental Reset and resets that are not Fundamental Reset. This section applies to all types of Conventional Reset.

In all form factors and system hardware configurations, there must, at some level, be a hardware mechanism for setting or returning all Port states to the initial conditions specified in this document -this mechanism is called “Fundamental Reset” This mechanism can take the form of an auxiliary signal provided by the system to a component or adapter card, in which case the signal must be called PERST#, and must conform to the rules specified in Section 4.2.4.9.1 . When

PERST# is provided to a component or adapter, this signal must be used by the component or adapter as Fundamental Reset. When PERST# is not provided to a component or adapter, Fundamental Reset is generated autonomously by the component or adapter, and the details of how this is done are outside the scope of this document. If a Fundamental

Reset is generated autonomously by the component or adapter, and if power is supplied by the platform to the

component/adapter, the component/adapter must generate a Fundamental Reset to itself if the supplied power goes outside of the limits specified for the form factor or system.

• There are three distinct types of Conventional Reset: cold, warm, and hot:

。 A Fundamental Reset must occur following the application of power to the component. This is called a cold reset.

。 In some cases, it may be possible for the Fundamental Reset mechanism to be triggered by hardware without the removal and re-application of power to the component. This is called a warm reset. This document does not specify a means for generating a warm reset.

。 There is an in-band mechanism for propagating Conventional Reset across a Link. This is called a hot reset and is described in Section 4.2.4.9.2 .

There is an in-band mechanism for software to force a Link into Electrical Idle, “disabling” the Link. The Disabled LTSSM state is described in Section 4.2.5.9 , the Link Disable control bit is described in Section 7.5.3.7 , and the Downstream Port Containment mechanism is described in [Section 6.2.10 .](#bookmark44) Disabling a Link causes Downstream components to undergo a hot reset.

Note also that the Data Link Layer reporting DL\_Down status is in some ways identical to a hot reset - see Section 2.9 .

• On exit from any type of Conventional Reset (cold, warm, or hot), all Port registers and state machines must be set to their initialization values as specified in this document, except for sticky registers (seeSection 7.4).

。 Note that, from a device point of view, any type of Conventional Reset (cold, warm, hot, or DL\_Down) has the same effect at the Transaction Layer and above as would RST# assertion and deassertion in conventional PCI.

• On exit from a Fundamental Reset, the Physical Layer will attempt to bring up the Link (seeSection 4.2.5).

Once both components on a Link have entered the initial Link Training state, they will proceed through Link initialization for the Physical Layer and then through Flow Control initialization for VC0, making the Data Link and Transaction Layers ready to use the Link.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

。 Following Flow Control initialization for VC0, it is possible for TLPs and DLLPs to be transferred across the Link.

Following a Conventional Reset, some devices may require additional time before they are able to respond to Requests

they receive. Particularly for Configuration Requests it is necessary that components and devices behave in a deterministic way, which the following rules address.

The first set of rules addresses requirements for components and devices:

• A component must enter the LTSSM Detect state within 20 ms of the end of Fundamental Reset (Link Training is described in Section 4.2.4).

。 Note: In some systems, it is possible that the two components on a Link may exit Fundamental Reset at different times. Each component must observe the requirement to enter the initial active Link

Training state within 20 ms of the end of Fundamental Reset from its own point of view.

• On the completion of Link Training (entering the DL\_Active state, seeSection 3.2), a component must be able to receive and process TLPs and DLLPs.

The second set of rules addresses requirements placed on the system:

• To allow components to perform internal initialization, system software must wait a specified minimum period following the end of a Conventional Reset of one or more devices before it is permitted to issue Configuration Requests to those devices, unless Readiness Notifications mechanisms are used (see Section 6.23.).

。 With a Downstream Port that does not support Link speeds greater than 5.0 GT/s, software must wait a minimum of 100 ms before sending a Configuration Request to the device immediately below that Port.

。 With a Downstream Port that supports Link speeds greater than 5.0 GT/s, software must wait a

minimum of 100 ms after Link training completes before sending a Configuration Request to the

device immediately below that Port. Software can determine when Link training completes by polling the Data Link Layer Link Active bit or by setting up an associated interrupt (see[Section 6.7.3.3)](#bookmark77).

。 A system must guarantee that all components intended to be software visible at boot time are ready to receive Configuration Requests within the applicable minimum period based on the end of

Conventional Reset at the Root Complex - how this is done is beyond the scope of this specification.

。 Note: Software should use 100 ms wait periods only if software enables CRS Software Visibility. Otherwise, Completion timeouts, platform timeouts, or lengthy processor instruction stalls may result. See the Configuration Request Retry Status Implementation Note in Section 2.3.1 .

• Following a Conventional Reset of a device, within 1.0 s the device must be able to receive a Configuration

Request and return a Successful Completion if the Request is valid. This period is independent of how quickly Link training completes. If Readiness Notifications mechanisms are used (see Section 6.23), this period may be shorter.

• Unless Readiness Notifications mechanisms are used, the Root Complex and/or system software must allow at least 1.0 s after a Conventional Reset of a device, before determining that the device is broken if it fails to return a Successful Completion status for a valid Configuration Request. This period is independent of how quickly

Link training completes.

Note: This delay is analogous to the Trhfa parameter specified for PCI/PCI-X, and is intended to allow an adequate amount of time for devices which require self initialization.

• When attempting a Configuration access to devices on a PCI or PCI-X bus segment behind a PCI Express/PCI(-X) Bridge, the timing parameter Trhfa must be respected.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

For this second set of rules, if system software does not have direct visibility into the state of Fundamental Reset (e.g., Hot-Plug; see[Section 6.7](#bookmark78)), software must base these timing parameters on an event known to occur after the end of Fundamental Reset.

When a Link is in normal operation, the following rules apply:

• If, for whatever reason, a normally operating Link goes down, the Transaction and Data Link Layers will enter the DL\_Inactive state (see Sections 2.9 and 3.2.1).

• For any Root or Switch Downstream Port, setting the Secondary Bus Reset bit of the Bridge Control register associated with the Port must cause a hot reset to be sent (seeSection 4.2.4.9.2).

• For a Switch, the following must cause a hot reset to be sent on all Downstream Ports:

。 Setting the Secondary Bus Reset bit of the Bridge Control register associated with the Upstream Port

。 The Data Link Layer of the Upstream Port reporting DL\_Down status. In Switches that support Link speeds greater than 5.0 GT/s, the Upstream Port must direct the LTSSM of each Downstream Port to the Hot Reset state, but not hold the LTSSMs in that state. This permits each Downstream Port to

begin Link training immediately after its hot reset completes. This behavior is recommended for all Switches.

。 Receiving a hot reset on the Upstream Port

Certain aspects of Fundamental Reset are specified in this document and others are specific to a platform, form factor and/or implementation. Specific platforms, form factors or application spaces may require the additional specification of the timing and/or sequencing relationships between the components of the system for Fundamental Reset. For

example, it might be required that all PCI Express components within a chassis observe the assertion and deassertion of Fundamental Reset at the same time (to within some tolerance). In a multi-chassis environment, it might be necessary to specify that the chassis containing the Root Complex be the last to exit Fundamental Reset.

In all cases where power and PERST# are supplied, the following parameters must be defined:

• Tpvperl - PERST# must remain active at least this long after power becomes valid

• Tperst - When asserted, PERST# must remain asserted at least this long

• T fail - When power becomes invalid, PERST# must be asserted within this time

Additional parameters may be specified.

In all cases where a reference clock is supplied, the following parameter must be defined:

• Tperst-clk - PERST# must remain active at least this long after any supplied reference clock is stable Additional parameters may be specified.

**6.6.2 Function Level Reset (FLR)**

The FLR mechanism enables software to quiesce and reset Endpoint hardware with Function-level granularity. Three example usage models illustrate the benefits of this feature:

• In some systems, it is possible that the software entity that controls a Function will cease to operate normally. To prevent data corruption, it is necessary to stop all PCI Express and external I/O (not PCI Express) operations being performed by the Function. Other defined reset operations do not guarantee that external I/O operations will be stopped.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• In a partitioned environment where hardware is migrated from one partition to another, it is necessary to

ensure that no residual “knowledge” of the prior partition be retained by hardware, for example, a user ’s secret information entrusted to the first partition but not to the second. Further, due to the wide range of Functions, it is necessary that this be done in a Function-independent way.

• When system software is taking down the software stack for a Function and then rebuilding that stack, it is sometimes necessary to return the state to an uninitialized state before rebuilding the Function’s software stack.

Implementation of FLR is optional (not required), but is strongly recommended.

FLR applies on a per Function basis. Only the targeted Function is affected by the FLR operation. The Link state must not be affected by an FLR.

FLR modifies the Function state described by this specification as follows:

• Function registers and Function-specific state machines must be set to their initialization values as specified in this document, except for the following:

。 sticky-type registers (ROS, RWS, RW1CS) 。 registers defined as type HwInit

。 these other fields or registers:

▪ Captured Slot Power Limit Valuein the Device Capabilities Register

▪ Captured Slot Power Limit Scalein the Device Capabilities Register

▪ Max\_Payload\_Sizein the Device Control Register

▪ Active State Power Management (ASPM) Controlin the Link Control Register

▪ Read Completion Boundary (RCB) in the Link Control Register

▪ Common Clock Configurationin the Link Control Register

▪ Extended Synchin the Link Control Register

▪ Enable Clock Power Managementin the Link Control Register

▪ Hardware Autonomous Width Disablein Link Control Register

▪ Hardware Autonomous Speed Disablein the Link Control 2 Register

▪ Link Equalization Request 8.0 GT/sin the Link Status 2 Register

▪ Link Equalization Request 16.0 GT/sin the16.0 GT/s Status Register

▪ Enable Lower SKP OS Generation Vectorin the Link Control 3 register

▪ Lane Equalization Control Registerin the Secondary PCI Express Extended Capability structure

▪ 16.0 GT/s Lane Equalization Control Registerin the Physical Layer 16.0 GT/s Extended Capabilitystructure

▪ All registers in theVirtual Channel Extended Capabilitystructure

▪ All registers in theMulti-Function Virtual Channel Extended Capabilitystructure

▪ All registers in the Data Link Feature Extended Capabilitystructure

▪ All registers in thePhysical Layer 16.0 GT/s Extended Capabilitystructure

▪ All registers in thePhysical Layer 32.0 GT/s Extended Capabilitystructure

▪ All registers in theLane Margining at the Receiver Extended Capabilitystructure

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• It is strongly recommended that the following registers are also not reset to their initialization values:

。 ARI Control Register in the ARI Extended CapabilityStructure

。 All registers in the L1 PM Substates Extended Capability structure 。 All registers in the Latency Tolerance Reporting Capability structure 。 All registers in the Precision Time Management Capability structure

Future revisions of this specification may change this recommendation to a requirement.

Note that the controls that enable the Function to initiate requests on PCI Express are cleared, including Bus Master Enable, MSI Enable, and the like, effectively causing the Function to become quiescent on the Link.

Note that Port state machines associated with Link functionality including those in the Physical and Data Link Layers are not reset by FLR, and VC0 remains initialized following an FLR.

• Any outstanding INTx interrupt asserted by the Function must bedeasserted by sending the corresponding Deassert\_INTx Message prior to starting the FLR.

Note that when the FLR is initiated to a Function of a Multi-Function Device, if another Function continues to assert a matching INTx, no Deassert\_INTx Message will be transmitted.

After an FLR has been initiated by writing a 1b to the Initiate Function Level Reset bit, the Function must complete the

FLR within 100 ms. If software initiates an FLR when the Transactions Pending bit is 1b, then software must not initialize the Function until allowing adequate time for any associated Completions to arrive, or to achieve reasonable certainty that any remaining Completions will never arrive. For this purpose, it is recommended that software allow as much time as provided by the pre-FLR value for Completion Timeout on the device. If Completion Timeouts were disabled on the

Function when FLR was issued, then the delay is system dependent but must be no less than 100 ms. If Function

Readiness Status (FRS - seeSection 6.23.2) is implemented, then system software is permitted to issue Configuration

Requests to the Function immediately following receipt of an FRS Message indicating Configuration-Ready, however, this does not necessarily indicate that outstanding Requests initiated by the Function have completed.

Note that upon receipt of an FLR, a device Function may either clear all transaction status including Transactions Pending or set the Completion Timeout to its default value so that all pending transactions will time out during FLR execution. Regardless, the Transactions Pending bit must be clear upon completion of the FLR.

Since FLR modifies Function state not described by this specification (in addition to state that is described by this

specification), it is necessary to specify the behavior of FLR using a set of criteria that, when applied to the Function,

show that the Function has satisfied the requirements of FLR. The following criteria must be applied using Function-specific knowledge to evaluate the Function’s behavior in response to an FLR:

• The Function must not give the appearance of an initialized adapter with an active host on any external interfaces controlled by that Function. The steps needed to terminate activity on external interfaces are outside of the scope of this specification.

。 For example, a network adapter must not respond to queries that would require adapter initialization by the host system or interaction with an active host system, but is permitted to perform actions that it is designed to perform without requiring host initialization or interaction. If the network adapter

includes multiple Functions that operate on the same external network interface, this rule affects only those aspects associated with the particular Function reset by FLR.

• The Function must not retain within itself software readable state that potentially includes secret information associated with any preceding use of the Function. Main host memory assigned to the Function must not be modified by the Function.

。 For example, a Function with internal memory readable directly or indirectly by host software must clear or randomize that memory.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• The Function must return to a state such that normal configuration of the Function’s PCI Express interface will

cause it to be useable by drivers normally associated with the Function When an FLR is initiated, the targeted Function must behave as follows:

• The Function must return the Completion for the configuration write that initiated the FLR operation and then initiate the FLR.

• While an FLR is in progress:

。 If a Request arrives, the Request is permitted to be silently discarded (following update of flow control credits) without logging or signaling it as an error.

。 If a Completion arrives, the Completion is permitted to be handled as an Unexpected Completion or to be silently discarded (following update of flow control credits) without logging or signaling it as an error.

。 While a Function is required to complete the FLR operation within the time limit described above, the subsequent Function-specific initialization sequence may require additional time. If additional time is required, the Function must return a Configuration Request Retry Status (CRS) Completion Status when a Configuration Request is received after the time limit above. After the Function responds to a Configuration Request with a Completion status other than CRS, it is not permitted to return CRS

until it is reset again.

**IMPLEMENTATION NOTE**

Avoiding Data Corruption From Stale Completions

An FLR causes a Function to lose track of any outstanding non-posted Requests. Any corresponding Completions that later arrive are referred to as being "stale". If software issues an FLR while there are outstanding Requests,

and then re-enables the Function for operation without waiting for potential stale Completions, any stale

Completions that arrive afterwards may cause data corruption by being mistaken by the Function as belonging to Requests issued since the FLR.

Software can avoid data corruption from stale Completions in a variety of ways. Here's a possible algorithm:

1. Software that's performing the FLR synchronizes with other software that might potentially access the Function directly, and ensures such accesses do not occur during this algorithm.

2. Software clears the entire Command register, disabling the Function from issuing any new Requests.

3. Software polls the Transactions Pending bit in the Device Status register either until it is clear or until it has been long enough that software is reasonably certain that Completions associated with any

remaining outstanding Transactions will never arrive. On many platforms, the Transactions Pending bit will usually clear within a few milliseconds, so software might choose to poll during this initial period

using a tight software loop. On rare cases when the Transactions Pending bit does not clear by this time, software will need to poll for a much longer platform-specific period (potentially seconds), so software might choose to conduct this polling using a timer-based interrupt polling mechanism.

4. Software initiates the FLR.

5. Software waits 100 ms.

6. Software reconfigures the Function and enables it for normal operation.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAHhCAYAAABTM/91AAAAWUlEQVRoge3MMREAIAwEwQSTtEijRWVQwAQB++3tfESzjHXqWffM0T0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP+ACz4QGwGGaYhUAAAAASUVORK5CYII=)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.7 PCI Express Native Hot-Plug**

The PCI Express architecture is designed to natively support both hot-add and hot-removal (“hot-plug”) of cables, add-in cards, and modules. PCI Express native hot-plug provides a “toolbox” of mechanisms that allow different user/operator models to be supported using a self-consistent infrastructure. These mechanisms may be used to implement orderly

addition/removal that relies on coordination with the operating system (e.g., traditional PCI hot-plug), as well as async removal, which proceeds without lock-step synchronization with the operating system. This section defines the set of hot-plug mechanisms and specifies how the elements of hot-plug, such as indicators and push buttons, must behave if implemented in a system.

**6.7.1 Elements of Hot-Plug**

[Table 6-7](#bookmark79)lists the physical elements comprehended in this specification for support of hot-plug models. A form factor specification must define how these elements are used in that form factor. For a given form factor specification, it is

possible that only some of the available hot-plug elements are required, or even that none of these elements are

required. In all cases, the form factor specification must define all assumptions and limitations placed on the system or the user by the choice of elements included. Silicon component implementations that are intended to be used only with selected form factors are permitted to support only those elements that are required by the associated form factor(s).

Table 6-7 Elements of Hot-Plug

|  |  |
| --- | --- |
| Element | Purpose |
| Indicators | Show the power and attention state of the slot |
| Manually-operated Retention Latch (MRL) | Holds adapter in place |
| MRL Sensor | Allows the Port and system software to detect the MRL being opened |
| Electromechanical Interlock | Prevents removal of adapter from slot |
| Attention Button | Allows user to request hot-plug operations |
| Software User Interface | Allows user to request hot-plug operations |
| Slot Numbering | Provides visual identification of slots |
| Power Controller | Software-controlled electronic component or components that control power to a slot or adapter and monitor that power for fault conditions |
| Out-of-band Presence Detect | Method of determining physical presence of an adapter in a slot that does not rely on the Physical Layer |

[**6.7.1.1**](6.7.1.1) **Indicators**

Two indicators are defined: the Power Indicator and the Attention Indicator. Each indicator is in one of three states: on, off, or blinking. Hot-plug system software has exclusive control of the indicator states by writing the command registers associated with the indicator (with one exception noted below). The indicator requirements must be included in all form factor specifications. For a given form factor, the indicators may be required or optional or not applicable at all.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

The hot-plug capable Port controls blink frequency, duty cycle, and phase of the indicators. Blinking indicators must operate at a frequency of between 1 and 2 Hz, with a 50% (+/- 5%) duty cycle. Blinking indicators are not required to be synchronous or in-phase between Ports.

Indicators may be physically located on the chassis or on the adapter (see the associated form factor specification for Indicator location requirements). Regardless of the physical location, logical control of the indicators is by the

Downstream Port of the Upstream component on the Link.

The Downstream Port must not change the state of an indicator unless commanded to do so by software, except for

platforms capable of detecting stuck-on power faults (relevant only when a power controller is implemented). In the

case of a stuck-on power fault, the platform is permitted to override the Downstream Port and force the Power Indicator to be on (as an indication that the adapter should not be removed). The handling by system software of stuck-on faults is

optional and not described in this specification. Therefore, the platform vendor must ensure that this feature, if implemented, is addressed via other software, platform documentation, or by other means.

**6.7.1.1.1 Attention Indicator**

The Attention Indicator, which must be yellow or amber in color, indicates that an operational problem exists or that the hot-plugslot is being identified so that a human operator can locate it easily.

Table 6-8 Attention Indicator States

|  |  |
| --- | --- |
| Indicator Appearance | Meaning |
| Off | Normal - Normal operation |
| On | Attention - Operational problem at this slot |
| Blinking | Locate - Slot is being identified at the user’s request |

**Attention Indicator Off**

The Attention Indicator in the Off state indicates that neither the adapter (if one is present) nor the hot-plugslot requires attention.

**Attention Indicator On**

The Attention Indicator in the On state indicates that an operational problem exists at the adapter or slot.

An operational problem is a condition that prevents continued operation of an adapter. The operating system or

other system software determines whether a specific condition prevents continued operation of an adapter and

whether lighting the Attention Indicator is appropriate. Examples of operational problems include problems related to external cabling, adapter, software drivers, and power faults. In general, the Attention Indicator in the On state

indicates that an operation was attempted and failed or that an unexpected event occurred.

The Attention Indicator is not used to report problems detected while validating the request for a hot-plug

operation. Validation is a term applied to any check that system software performs to assure that the requested

operation is viable, permitted, and will not cause problems. Examples of validation failures include denial of

permission to perform a hot-plug operation, insufficient power budget, and other conditions that may be detected before a hot-plug request is accepted.

**Attention Indicator Blinking**

A blinking Attention Indicator indicates that system software is identifying this slot for a human operator to find. This behavior is controlled by a user (for example, from a software user interface or management tool).

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.7.1.1.2 Power Indicator**

The Power Indicator, which must be green in color, indicates the power state of the slot.[Table 6-9](#bookmark80)lists the Power Indicator states.

Table 6-9 Power Indicator States

|  |  |
| --- | --- |
| Indicator Appearance | Meaning |
| Off | Power Off - Insertion or removal of the adapter is permitted. |
| On | Power On - Insertion or removal of the adapter is not permitted. |
| Blinking | Power Transition - Hot-plug operation is in progress and insertion or removal of the adapter is not permitted. |

**Power Indicator Off**

The Power Indicator in the Off state indicates that insertion or removal of the adapter is permitted. Main power to the slot is off if required by the form factor. Note that, depending on the form factor, other power/signals may

remain on, even when main power is off and the Power Indicator is off. In an example using the [CEM] form factor, if the platform provides Vaux to hot-plugslots and the MRL is closed, any signals switched by the MRL are connected to the slot even when the Power Indicator is off. Signals switched by the MRL are disconnected when the MRL is

opened. System software must cause a slot’s Power Indicator to be turned off when the slot is not powered and/or it is permissible to insert or remove an adapter. Refer to the appropriate form factor specification for details.

**Power Indicator On**

The Power Indicator in the On state indicates that the hot-plug operation is complete and that main power to the slot is On and that insertion or removal of the adapter is not permitted.

**Power Indicator Blinking**

A blinking Power Indicator indicates that the slot is powering up or powering down and that insertion or removal of the adapter is not permitted.

The blinking Power Indicator also provides visual feedback to the operator when the Attention Button is pressed or when hot-plug operation is initiated through the hot-plug software interface.

[**6.7.1.2**](6.7.1.2) **Manually-operated Retention Latch (MRL)**

An MRL is a manually-operated retention mechanism that holds an adapter in the slot and prevents the user from

removing the device. The MRL rigidly holds the adapter in the slot so that cables may be attached without the risk of creating intermittent contact. MRLs that hold down two or more adapters simultaneously are permitted in platforms

that do not provide MRL Sensors.

[**6.7.1.3**](6.7.1.3) **MRL Sensor**

The MRL Sensor is a switch, optical device, or other type of sensor that reports the position of a slot’s MRL to the

Downstream Port. The MRL Sensor reports closed when the MRL is fully closed and open at all other times (that is, if the MRL fully open or in an intermediate position).

If a power controller is implemented for the slot, the slot main power must be automatically removed from the slot when the MRL Sensor indicates that the MRL is open. If signals such as Vaux and SMBus are switched by the MRL, then these

signals must be automatically removed from the slot when the MRL Sensor indicates that the MRL is open and must be

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

restored to the slot when the MRL Sensor indicates that MRL has closed again. Refer to the appropriate form factor specification to identify the signals, if any, switched by the MRL.

Note that the Hot-Plug Controller does not autonomously change the state of either the Power Indicator or the Attention Indicator based on MRL sensor changes.

**IMPLEMENTATION NOTE**

MRL Sensor Handling

In the absence of an MRL sensor, for some form factors, out-of-band presence detect may be used to handle the switched signals. In this case, when out-of-band presence detect indicates the absence of an adapter in a slot, the switched signals will be automatically removed from the slot.

If an MRL Sensor is implemented without a corresponding MRL Sensor input on the Hot-Plug Controller, it is recommended that the MRL Sensor be routed to power fault input of the Hot-Plug Controller. This allows an active adapter to be powered off when the MRL is opened.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADTCAYAAAC89lJnAAAAP0lEQVRYhe3MoREAIAwEwYQmsZSGpcpQAROL2Le38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAD+DC2fgBKRr/31wAAAAAElFTkSuQmCC)

[**6.7.1.4**](6.7.1.4) **Electromechanical Interlock**

An electromechanical interlock is a mechanism for physically locking the adapter or MRL in place until system software releases it. The state of the electromechanical interlock is set by software and must not change except in response to a subsequent software command. In particular, the state of the electromechanical interlock must be maintained even

when power to the hot-plugslot is removed.

The current state of the electromechanical interlock must be reflected at all times in the Electromechanical Interlock Status bit in the Slot Status register, which must be updated within 200 ms of any commanded change. Software must wait at least 1 second after issuing a command to toggle the state of the Electromechanical Interlock before another command to toggle the state can be issued. Systems may optionally expand control of interlocks to provide physical security of the adapter.

[**6.7.1.5**](6.7.1.5) **Attention Button**

The Attention Button is a momentary-contact push button switch, located adjacent to each hot-plugslot or on the

adapter that is pressed by the user to initiate a hot-plug operation at that slot. Regardless of the physical location of the button, the signal is processed and indicated to software by hot-plug hardware associated with the Downstream Port corresponding to the slot.

The Attention Button must allow the user to initiate both hot add and hot remove operations regardless of the physical location of the button.

If present, the Power Indicator provides visual feedback to the human operator (if the system software accepts the request initiated by the Attention Button) by blinking. Once the Power Indicator begins blinking, a 5-second abort interval exists during which a second depression of the Attention Button cancels the operation.

If an operation initiated by an Attention Button fails for any reason, it is recommended that system software present an error message explaining the failure via a software user interface or add the error message to a system log.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[**6.7.1.6**](6.7.1.6) **Software User Interface**

System software provides a user interface that allows hot insertions and hot removals to be initiated and that allows occupied slots to be monitored. A detailed discussion of hot-plug user interfaces is operating system specific and is therefore beyond the scope of this document.

On systems with multiple hot-plugslots, the system software must allow the user to initiate operations at each slot

independent of the states of all otherslots. Therefore, the user is permitted to initiate a hot-plug operation on one slot using either the software user interface or the Attention Button while a hot-plug operation on another slot is in process, regardless of which interface was used to start the first operation.

[**6.7.1.7**](6.7.1.7) **Slot Numbering**

A Physical Slot Identifier (as defined in [PCI-Hot-Plug-1.1],Section 1.5 ) consists of an optional chassis number and the physical slot number of the slot. The physical slot number is a chassis unique identifier for a slot. System software

determines the physical slot number from registers in the Port. Chassis number 0 is reserved for the main chassis. The chassis number for other chassis must be a non-zero value obtained from a PCI-to-PCI Bridge’s Chassis Number register (see [PCI-to-PCI-Bridge-1.2], Section 13.4).

Regardless of the form factor associated with each slot, each physical slot number must be unique within a chassis.

[**6.7.1.8**](6.7.1.8) **Power Controller**

The power controller is an element composed of one or more discrete components that acts under control of software to set the power state of the hot-plugslot as appropriate for the specific form factor. The power controller must also

monitor the slot for power fault conditions (as defined in the associated form factor specification) that occur on the slot’s main power rails and, if supported, auxiliary power rail.

If a power controller is not present, the power state of the hot-plugslot must be set automatically by the hot-plug controller in response to changes in the presence of an adapter in the slot.

The power controller monitors main and auxiliary power faults independently. If a power controller detects a main

power fault on the hot-plugslot, it must automatically set its internal main power fault latch and remove main power

from the hot-plugslot (without affecting auxiliary power). Similarly, if a power controller detects an auxiliary power fault on the hot-plugslot, it must automatically set its internal auxiliary power fault latch and remove auxiliary power from

the hot-plugslot (without affecting main power). Power must remain off to the slot as long as the power fault condition remains latched, regardless of any writes by software to turn on power to the hot-plugslot. The main power fault latch is cleared when software turns off power to the hot-plugslot. The mechanism by which the auxiliary power fault latch is

cleared is form factor specific but generally requires auxiliary power to be removed from the hot-plugslot. For example, one form factor may remove auxiliary power when the MRL for the slot is opened while another may require the adapter to be physically removed from the slot. Refer to the associated form factor specifications for specific requirements.

Since the Power Controller Control bit in the Slot Control register reflects the last value written and not the actual state of the power controller, this means there may be an inconsistency between the value of the Power Controller Control bit and the state of the power to the slot in a power fault condition. To determine whether slot is off due to a power fault,

software must use the power fault software notification to detect power faults. To determine that a requested power-up operation has otherwise failed, software must use the hot-plugslot power-up time out mechanism described in [Section](#bookmark81) [6.7.3.3 .](#bookmark82)

Software must not assume that writing to the Slot Control register to change the power state of a hot-plugslot causes an immediate power state transition. After turning power on, software must wait for a Data Link Layer State Changed event, as described in [Section 6.7.3.3](#bookmark83). After turning power off, software must wait for at least 1 second before taking any action

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

that relies on power having been removed from the hot-plugslot. For example, software is not permitted to turn off the power indicator (if present) or attempt to turn on the power controller before completing the 1 second wait period.

**6.7.2 Registers Grouped by Hot-Plug Element Association**

The registers described in this section are grouped by hot-plug element to convey all registers associated with

implementing each element. Register fields associated with each Downstream Port implementing a hot-plug capable slot are located in the Device Capabilities,Slot Capabilities,Slot Control,Slot Status, andSlot Capabilities 2 registers in the PCI Express Capability structure (seeSection 7.5.3). Registers reporting the presence of hot-plug elements

associated with the device Function on an adapter are located in the Device Capabilities register (also in the PCI Express Capability structure).

[**6.7.2.1**](6.7.2.1) **Attention Button Registers**

Attention Button Present (Slot Capabilities Registerand Device Capabilities Register) - This bit indicates if an Attention Button is electrically controlled by the chassis (Slot Capabilities Register) or by the adapter (Device Capabilities Register).

Attention Button Pressed (Slot Status Register - This bit is set when an Attention Button electrically controlled by the chassis is pressed.

Attention Button Pressed Enable (Slot Control Register - When Set, this bit enables software notification on an Attention Button Pressedevent (see[Section 6.7.3.4)](#bookmark85).

[**6.7.2.2**](6.7.2.2) **Attention Indicator Registers**

Attention Indicator Present (Slot Capabilities Registerand Device Capabilities Register) - This bit indicates if an Attention Indicator is electrically controlled by the chassis (Slot Capabilities Register) or by the adapter (Device Capabilities

REgister).

Attention Indicator Control (Slot Control Register) - When written, sets an Attention Indicator electrically controlled by the chassis to the written state.

[**6.7.2.3**](6.7.2.3) **Power Indicator Registers**

Power Indicator Present (Slot Capabilities Registerand Device Capabilities Register) - This bit indicates if a Power Indicator is electrically controlled by the chassis (Slot Capabilities Register) or by the adapter (Device Capabilities Register).

Power Indicator Control (Slot Control Register) - When written, sets a Power Indicator electrically controlled by the chassis to the written state.

[**6.7.2.4**](6.7.2.4) **Power Controller Registers**

Power Controller Present (Slot Capabilities Register) - This bit indicates if a Power Controller is implemented.

Power Controller Control (Slot Control Register) - Turns the Power Controller on or off according to the value written. Power Fault Detected (Slot Status Register) - This bit is set when a power fault is detected at the slot or the adapter.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Power Fault Detected Enable (Slot Control Register) - When Set, this bit enables software notification on a power fault event (see[Section 6.7.3.4)](#bookmark86).

[**6.7.2.5**](6.7.2.5) **Presence Detect Registers**

In-Band PD Disable Supported (Slot Capabilities 2 Register) - This bit indicates if the slot supports the disabling of in-band presence detect, which allows the out-of-band presence detect state to be reported independently of the in-band presence detect state.

In-Band PD Disable (Slot Control Register) - When Set, this bit disables the in-band presence detect mechanism from affecting the Presence Detect State bit, allowing that bit to be dedicated to reporting out-of-band presence detect.

Presence Detect State (Slot Status Register) - This bit indicates the presence of an adapter in the slot.

Presence Detect Changed (Slot Status Register) - This bit is set when a presence detect state change is detected.

Presence Detect Changed Enable (Slot Control Register) - When Set, this bit enables software notification on a presence detect changed event (see[Section 6.7.3.4)](#bookmark87).

[**6.7.2.6**](6.7.2.6) **MRL Sensor Registers**

MRL Sensor Present (Slot Capabilities Register) - This bit indicates if an MRL Sensor is implemented.

MRL Sensor Changed (Slot Status Register) - This bit is set when the value of the MRL Sensor state changes.

MRL Sensor Changed Enable (Slot Control Register) - When Set, this bit enables software notification on a MRL Sensor changed event (see[Section 6.7.3.4)](#bookmark88).

MRL Sensor State (Slot Status Register) - This register reports the status of the MRL Sensor if one is implemented.

[**6.7.2.7**](6.7.2.7) **Electromechanical Interlock Registers**

Electromechanical Interlock Present (Slot Capabilities Register) - This bit indicates if an Electromechanical Interlock is implemented.

Electromechanical Interlock Status (Slot Status Register) - This bit reflects the current state of the Electromechanical Interlock.

Electromechanical Interlock Control (Slot Control Register) - This bit when set to 1b toggles the state of the Electromechanical Interlock.

[**6.7.2.8**](6.7.2.8) **Command Completed Registers**

No Command Completed Support (Slot Capabilities Register) - This bit when set to 1b indicates that this slot does not generate software notification when an issued command is completed by the Hot-Plug Controller.

Command Completed(Slot Status Register) - This bit is set when the Hot-Plug Controller completes an issued command and is ready to accept the next command.

Command Completed Interrupt Enable (Slot Control Register) - When Set, this bit enables software notification (see [Section 6.7.3.4](#bookmark89)) when a command is completed by the hot-plug control logic.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[**6.7.2.9**](6.7.2.9) **Port Capabilities and Slot Information Registers**

Slot Implemented (PCI Express Capabilities Register) - When Set, this bit indicates that the Link associated with this Downstream Port is connected to a slot.

Physical Slot Number (Slot Capabilities Register) - This hardware initialized field indicates the physical slot number attached to the Port.

Hot-Plug Capable (Slot Capabilities Register) - When Set, this bit indicates this slot is capable of supporting hot-plug. Hot-Plug Surprise (Slot Capabilities Register) - When Set, this bit indicates that the Hot-Plug Surprise mechanism for handling async removal is enabled for this slot. See [Section 6.7.6 .](#bookmark90)

[**6.7.2.10**](6.7.2.10) **Hot-Plug Interrupt Control Register**

Hot-Plug Interrupt Enable (Slot Control Register) - When Set, this bit enables generation of the hot-plug interrupt on enabled hot-plug events.

**6.7.3 PCI Express Hot-Plug Events**

A Downstream Port with hot-plug capabilities supports the following hot-plug events:

• Slot Events:

。Attention Button Pressed 。Power Fault Detected

。MRL Sensor Changed

。Presence Detect Changed

• Command Completed Events

• Data Link Layer State Changed Events

Each of these events has a status field, which indicates that an event has occurred but has not yet been processed by software, and an enable field, which indicates whether the event is enabled for software notification. Some events also have a capability field,which indicates whether the event type is supported on the Port. The grouping of these fields by event type is listed in [Section 6.7.2 ,](#bookmark84) and each individual field is described in Section 7.5.3 .

[**6.7.3.1**](6.7.3.1) **Slot Events**

A Downstream Port with hot-plug capabilities monitors the slot it controls for the slot events listed above. When one of these slot events is detected, the Port indicates that the event has occurred by setting the status field associated with the event. At that point, the event is pending until software clears the status field.

Once a slot event is pending on a particular slot, all subsequent events of that type are ignored on that slot until the

event is cleared. The Port must continue to monitor the slot for all otherslot event types and report them as they occur.

If enabled through the associated enable field, slot events must generate a software notification. If the event is not

supported on the Port as indicated by the associated capability field, software must not enable software notification for the event. The mechanism by which this notification is reported to software is described in [Section 6.7.3.4 .](#bookmark92)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[**6.7.3.2**](6.7.3.2) **Command Completed Events**

Since changing the state of some hot-plug elements may not happen instantaneously, PCI Express supports hot-plug commands and command completed events. All hot-plug capable Ports are required to support hot-plug commands and, if the capability is reported, command completed events.

Software issues a command to a hot-plug capable Downstream Port by issuing a write transaction that targets any

portion of the Port’s Slot Control register. A single write to the Slot Control register is considered to be a single

command, even if the write affects more than one field in the Slot Control register. In response to this transaction, the Port must carry out the requested actions and then set the associated status field for the command completed event. The Port must process the command normally even if the status field is already set when the command is issued. If a single command results in more than one action being initiated, the order in which the actions are executed is

unspecified. All actions associated with a single command execution must not take longer than 1 second.

If command completed events are not supported as indicated by a value of 1b in the No Command Completed Support field of the Slot Capabilities register, a hot-plug capable Port must process a write transaction that targets any portion of the Port’s Slot Control register without any dependency on previous Slot Control writes. Software is permitted to issue multipleSlot Control writes in sequence without any delay between the writes.

If command completed events are supported, then software must wait for a command to complete before issuing the next command. However, if the status field is not set after the 1 second limit on command execution, software is

permitted to repeat the command or to issue the next command. If software issues a write before the Port has

completed processing of the previous command and before the 1 second time limit has expired, the Port is permitted to either accept or discard the write. Such a write is considered a programming error, and could result in a discrepancy

between the Slot Control register and the hot plug element state. To recover from such a programming error and return the controller to a consistent state, software must issue a write to the Slot Control register which conforms to the

command completion rules.

If enabled through the associated enable field, the completion of a commands must generate a software notification.

The exception to this rule is a command that occurs as a result of a write to the Slot Control register that disables

software notification of command completed events. Such a command must be processed as described above, but must not generate a software notification.

[**6.7.3.3**](6.7.3.3) **Data Link Layer State Changed Events**

The Data Link Layer State Changed event provides an indication that the state of theData Link Layer Link Active bit in the Link Status Register has changed. Support for Data Link Layer State Changed events and software notification of these events are required for hot-plug capable Downstream Ports. If this event is supported, the Port sets the status field

associated with the event when the value in theData Link Layer Link Active bit changes.

This event allows software to indirectly determine when power has been applied to a newly hot-plugged adapter.

Software must wait for 100 ms after the Data Link Layer Link Active bit reads 1b before initiating a configuration access to the hot added device (see [Section 6.6)](#bookmark75). Software must allow 1 second after the Data Link Layer Link Active bit reads 1b before it is permitted to determine that a hot plugged device which fails to return a Successful Completion for a Valid

Configuration Request is a broken device (see [Section 6.6)](#bookmark75).

The Data Link Layer State Changed event must occur within 1 second of the event that initiates the hot-insertion. If a

power controller is supported, the time out interval is measured from when software initiated a write to the Slot Control register to turn on the power. If a power controller is not supported, the time out interval is measured from presence

detect slot event. Software is allowed to time out on a hot add operation if the Data Link Layer State Changed event does not occur within 1 second. The action taken by software after such a timeout is implementation specific.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[**6.7.3.4**](6.7.3.4) **Software Notification of Hot-Plug Events**

A hot-plug capable Downstream Port must support generation of an interrupt on a hot-plug event. As described in Sections <6.7.3.1> and <6.7.3.2>, each hot-plug event has both an enable bit for interrupt generation and a status bit that indicates when an event has occurred but has not yet been processed by software. There is also a Hot-Plug Interrupt Enable bit in the Slot Control register that serves as a master enable/disable bit for all hot-plug events.

If the Port is enabled for level-triggered interrupt signaling using the INTx messages, the virtual INTx wire must be asserted whenever and as long as the following conditions are satisfied:

• The Interrupt Disable bit in the Command register is set to 0b.

• The Hot-Plug Interrupt Enable bit in the Slot Control register is set to 1b.

• At least one hot-plug event status bit in the Slot Status register and its associated enable bit in the Slot Control register are both set to 1b.

Note that all other interrupt sources within the same Function will assert the same virtual INTx wire when requesting service.

If the Port is enabled for edge-triggered interrupt signaling using MSI or MSI-X, an interrupt message must be sent every time the logical AND of the following conditions transitions from FALSE to TRUE:

• The associated vector is unmasked (not applicable if MSI does not support PVM).

• The Hot-Plug Interrupt Enable bit in the Slot Control register is set to 1b.

• At least one hot-plug event status bit in the Slot Status register and its associated enable bit in the Slot Control register are both set to 1b.

Note that PME and Hot-Plug Event interrupts (when both are implemented) always share the same MSI or MSI-X vector, as indicated by the Interrupt Message Number field in the PCI Express Capabilities register.

The Port may optionally send an MSI when there are hot-plug events that occur while interrupt generation is disabled, and interrupt generation is subsequently enabled.

If wake generation is required by the associated form factor specification, a hot-plug capable Downstream Port must

support generation of a wakeup event (using the PME mechanism) on hot-plug events that occur when the system is in a sleep state or the Port is in device stateD1,D2, or D3Hot.

Software enables a hot-plug event to generate a wakeup event by enabling software notification of the event as

described in [Section 6.7.3.1](#bookmark91). Note that in order for software to disable interrupt generation while keeping wakeup

generation enabled, the Hot-Plug Interrupt Enable bit must be cleared. For form factors that support wake generation, a wakeup event must be generated if all three of the following conditions occur:

• The status register for an enabled event transitions from Clearto Set

• The Port is in device stateD1,D2, or D3Hot, and

• The PME\_En bit in the Port’s Power Management Control/Status register is Set

Note that the Hot-Plug Controller generates the wakeup on behalf of the hot-plugged device, and it is not necessary for that device to have auxiliary (or main) power.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.7.4 System Firmware Intermediary (SFI) Support**

The System Firmware Intermediary (SFI) Capability is an optional normative feature of a Downstream Port. Some SFI functionality is focused on hot-pluggableslots, as indicated by the Hot-Plug Capable bit in the Slot Capabilities register being Set, while some SFI functionality is useful outside that context. If a Downstream Port supports an SFI Capability structure, the following bits must be Set:

• Data Link Layer Link Active Reporting Capable bit in the Link Capabilities register

• DRS Supported bit in the Link Capabilities 2 register

• ERR\_COR Subclass Capable bit in the Device Capabilities register

[**6.7.4.1**](6.7.4.1) **SFIERR\_COR Event Signaling**

The SFI Capability has no support for generating INTx or MSI/MSI-X interrupts, since the capability is intended for use by system firmware.

A Downstream Port with SFI must supportERR\_CORsignaling, regardless of whether it supports Advanced Error

Reporting(AER) or not. SFI ERR\_COR event signaling is enabled independently by the SFI OOB PD Changed Enable,SFI DLL State Changed Enable, and SFI DRS Signaling Enable bits in the SFI Control Register. These events are indicated by the SFI OOB PD Changed,SFI DLL State Changed, and SFI DRS Received bits in the SFI Status Register.

If the Correctable Error Reporting Enable bit in the Device Control Registeris Set, the Port must send an ERR\_COR Message each time one of the enabled conditions becomes satisfied. SFI ERR\_COR event signaling must not Set the Correctable Error Detected bit in the Device Status Register, since this event is not handled as an error.

**IMPLEMENTATION NOTE**

ERR\_COR Signaling for DPC DL\_Active vs. SFI DLL State Changed

DPC implements ERR\_CORsignaling for DL\_Active, whereas SFI implements ERR\_CORsignaling for SFI DLL State Changed, which are related but non-identical conditions. The DL\_Active condition occurs when the Data Link

Layer Link Active bit in the Link Status register changes from 0b to 1b, and this bit can be masked by the SFI DLL State Mask bit in the SFI Control register. The SFI DLL State Changedcondition occurs when the SFI DLL State bit in the SFI Status Registerchanges its value either by becoming Set or becoming Clear, and this condition is always based on the actual Data Link Layer state.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADTCAYAAAC89lJnAAAAPUlEQVRYhe3KoREAIAwAsZYlsYyGZUow2B4WkbefjLF2VM2erZw3AAAAAAAAAAAAAAAAAAAAAAAAAPgZPDsA8gSknSIPwAAAAABJRU5ErkJggg==)

[**6.7.4.2**](6.7.4.2) **SFI Downstream Port Filtering (DPF)**

Downstream Port Filtering (DPF) is a mechanism where a Downstream Port can handle specified Request TLPs that target Components below it as if the Link is in DL\_Down. See Section 2.9.1 .

DPF has two modes of filtering Request TLPs that target Components below the Downstream Port. The first mode filters all such Request TLPs; the second mode filters only Configuration Request TLPs. Other TLPs must not be filtered or

blocked by DPF.

One key use case for DPF is guaranteeing that asynchronous system software activities like bus scans do not

unintentionally send Configuration Requests to devices that are not yet ready following a Conventional Reset, since such accesses result in undefined hardware behavior. See [Section 6.6.1 .](#bookmark76)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Another key use case for DPF is supporting firmware first functionality, enabling system firmware, when notified of an async hot add, to configure the newly added device before making the device visible to the operating system. For this use case, the [SFI CAM](#bookmark94) mechanism enables the Downstream Port itself to generate Configuration Request TLPs targeting Downstream Components, and those TLPs are not filtered or blocked by the DPF mechanism. See [Section 6.7.4.3 ,](#bookmark95)

Section 7.9.21.5 , and Section 7.9.21.6 .

[**6.7.4.3**](6.7.4.3) **SFI CAM**

The SFI Configuration Access Method (CAM) provides a means for SFI-aware system firmware to have the Downstream Port proxy (pass through) Configuration Requests targeting Components below the Downstream Port when DPF is

enabled. The [SFI CAM](#bookmark95)is always enabled.

To use the[SFI CAM](#bookmark95), software first writes to theSFI CAM Address Register, specifying the target Configuration address. Software then reads or writes the SFI CAM Data Registerto cause a proxied Configuration Request to be generated and transmitted to the Downstream Component.

The following rules apply:

• All TLP fields used for the proxied Configuration Request are identical to those in the Configuration Request that targeted the SFI CAM Data Register, with the following exceptions:

。 The target Bus Number, Device Number, and Function Number come from the SFI CAM Address Register.

。 The Extended Register Number and Register Number come from the SFI CAM Address Register. 。 The LCRC is regenerated.

。 If present, the ECRC is regenerated.

• The [SFI CAM](#bookmark95)must not apply the Completion Timeout mechanism to the Request.

• System firmware must ensure that between the time it writes to theSFI CAM Address Registerand its

subsequent read or write of the SFI CAM Data Registercompletes, no other threads modify the SFI CAM Address Register; otherwise, the result is undefined.

• If there is a detected error associated with the proxied Configuration Request, this is a reported error associated with the Downstream Port implementing the[SFI CAM](#bookmark95) (see [Section 6.2)](#bookmark1).

• Completions flowing Upstream must be passed through the Downstream Port unmodified.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Serialized Use of the SFI CAM Address and Data Registers

As described above, system firmware must ensure that between the time it writes to theSFI CAM Address Register and its subsequent read or write of the SFI CAM Data Registercompletes, no other threads modify the SFI CAM

Address Register. For example, a semaphore or other synchronization mechanism can be used to ensure this serialization.

For platforms where a processor store instruction to Configuration Space is effectively posted, software must still ensure that the resulting Configuration Write completes before another software thread modifies the SFI CAM

Data Register. On such platforms, the mechanism for determining when a Configuration Write completes is platform specific.

Given appropriate serialization, the [SFI CAM](#bookmark95)works correctly with Configuration Requests that result in CRS

Completions, even when the Root Complex automatically re-issues the Configuration Request as a new Request. The re-issued Configuration Request will again be sent to the SFI CAM Data Register, and the associated

Downstream Port will again generate a Configuration Request targeting the Downstream Component. As long as the SFI CAM Address Registerisn’t modified by other software until the Configuration Request completes, the

sequence can repeat indefinitely until a non-CRS Completion is returned or a Completion Timeout occurs.

When CRS Software Visibility is enabled, the[SFI CAM](#bookmark95)still works correctly with Configuration Requests that result in CRS Completions. Any Completions with a CRS Completion Status flow back to the original Requester, which handles them as required by CRS Software Visibility semantics. See Section 2.3.2 .

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAGfCAYAAABiG5PEAAAAU0lEQVRoge3MsQ0AIAwDwYQlaRmNlinDBCg10rn9kyOaZaxTz7pnju4BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgR3ABh80GPGObo84AAAAASUVORK5CYII=)

**IMPLEMENTATION NOTE**

Use of Assigned Bus Numbers with the SFI CAM

When a Downstream Port has DPF enabled, the [SFI CAM](#bookmark95)can be used by SFI-aware system firmware to configure and access the sub-hierarchy below the Port without other software being able to do so. While the Bus Number configuration below the Port is generally not visible to other software, Bus Numbers configured for use below the Port should be limited to those already assigned to the Port since TLPs coming Upstream through the Port may contain IDs with the configured Bus Numbers. If any errors are detected and logged with those TLPs, the Bus

Numbers can become visible to other software, creating confusion if they overlap with Bus Numbers used elsewhere in the system.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADaCAYAAACb+QOvAAAAPklEQVRYhe3KoREAIAwAsZYlsYyGZUow2B4Sk7efjLF2VM2erZw3AAAAAAAAAAAAAAAAAAAAAAAAAAC+g2cHOjAEslO7ItUAAAAASUVORK5CYII=)

[**6.7.4.4**](6.7.4.4) **SFI Interactions with Readiness Notifications**

The SFI Capability is able to mask the reporting of received Device Readiness Status (DRS) Messages as well as emulate them being received. This functionality is useful when SFI’s Downstream Port Filtering (DPF) mechanism is being used to block operating system visibility of a device or sub-hierarchy below the Downstream Port.

Rules:

• When the SFI DRS Mask bit is Set, the DRS Message Received bit in the Link Status 2 Registervalue must be 0b.

• The SFI DRS Received bit must always indicate the actual state of the DRS Message Received condition.

• When the SFI DRS Mask bit is Clear and a 1b is written to the SFI DRS Trigger bit, the Downstream Port must behave as if a DRS Message was received.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

SFI Transparent Optimizations for Device Readiness

Certain devices may need more time to become Configuration-Ready following a hot-add operation than permitted. See [Section 6.6.1 .](#bookmark76)

If system firmware is aware of such devices, it can use the SFI DPF mechanism to block operating system visibility of a newly added device, wait the necessary amount of time for the device to become Configuration-Ready, and then expose the device to the operating system.

To avoid the operating system from unnecessarily waiting additional time for the newly exposed device to

become Configuration-Ready, system firmware can use the SFI DRS Trigger bit to have the Downstream Port

emulate the reception of a DRS Message. An operating system that supports DRS can then immediately discover and configure the newly exposed device.

The newly exposed device doesn’t necessarily need to be DRS capable itself. Since an Upstream Port is expressly permitted to send DRS Messages even when its DRS Supportedbit is Clear, the Downstream Port above it can

legitimately emulate receiving a DRS Message from it even if it is incapable of sending DRS Messages.

It should also be noted that in cases where system firmware is aware of a device becomingConfiguration-Ready early, system firmware can expose this to the operating system using the SFI DRS Trigger mechanism.

Although SFI is not intended to be used by operating system software, it is recommended that operating systems used in platforms supporting SFI implement support for DRS, so that the system as a whole can have the benefits of this optimized Device Readiness timing.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAGzCAYAAAASdVaJAAAAVElEQVRoge3MoREAIAwEwYQmsZSGpcpQAROB3be38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMA/uNGRBmTBeaoPAAAAAElFTkSuQmCC)

**IMPLEMENTATION NOTE**

SFI DPF and Function Readiness Status (FRS) Messages

[Downstream Port Filtering](#bookmark93) [(DPF) does not aff](#bookmark93)ect the generation or propagation ofFRS Messages. No FRS Messages are generated by a device when it becomes ready as part of an async hot-add operation. However, if system

firmware performs operations on a device that result in FRS events, the resultingFRS Messages may be visible to the operating system. See Section 2.2.8.6.4and Section 6.23.2 .

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAACoCAYAAADdE69lAAAAN0lEQVRYhe3KoQEAIAzAsI0nsZyG5cphsFPY1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAADgpwskJwROWh0xhAAAAABJRU5ErkJggg==)

[**6.7.4.5**](6.7.4.5) **SFI Suppression of Hot-Plug Surprise Functionality**

If a slot supports Hot-Plug Surprise (HPS) functionality as indicated by the Hot-Plug Surprise bit in the Slot Capabilities Register being Set, the SFI HPS Suppress bit in the SFI Control Registercan be used to force the Hot-Plug Surprise bit to be Clear, and disable the associated Hot-Plug Surprise functionality.

HPS suppression is useful when a Downstream Port / slot combination supports both HPS and Downstream Port

Containment (DPC). DPC is not recommended for concurrent use with HPS, so if a slot has HPS capability enabled, DPC should not be enabled. If software wishes to use DPC, software should first Set theSFI HPS Suppress bit in order to

disable HPS functionality, allowing DPC to function properly.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Software Negotiation of Hot-Plug Surprise Functionality

Assuming that system firmware owns the SFI Capability structure, it is recommended that for backward

compatibility with older operating systems, Hot-Plug Surprise functionality be enabled by default on slots

supporting async removal. Then, if the slot also supports DPC and the operating system wishes to use it instead, the operating system will request that HPS be suppressed by system firmware, and system firmware will

determine whether to Set or Clear theSFI HPS Suppress bit.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAC5CAYAAAAVmX5bAAAAPUlEQVRYhe3MoREAIAwEwYQmsZSGpcpQAROD3Le38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAMAvcAEtIQRwxqu4vAAAAABJRU5ErkJggg==)

**6.7.5 Firmware Support for Hot-Plug**

Some systems that include hot-plug capable Root Ports and Switches that are released before ACPI-compliant operating systems with native hot-plug support are available, can use ACPI firmware for propagating hot-plug events. Firmware

control of the hot-plug registers must be disabled if an operating system with native support is used. Platforms that

provide ACPI firmware to propagate hot-plug events must also provide a mechanism to transfer control to the operating system. The details of this method are described in the PCI Firmware Specification.

**6.7.6 Async Removal**

Async removal refers to the removal of an adapter or disabling of a Downstream Port Link due to error containment

without prior warning to the operating system. This is in contrast toorderly removal, where removal operations are

performed in a lock-step manner with the operating system through a well defined sequence of user actions and system management facilities. For example, the user presses the Attention Button to request permission from the operating

system to remove the adapter, but the user doesn’t actually remove the adapter from the slot until the operating system has quiesced activity to the adapter and granted permission for removal.

Since async removal proceeds before the rest of the PCI Express hierarchy or operating system necessarily becomes

aware of the event, special consideration is required beyond that needed for standard PCI hot-plug. This section outlines PCI Express events that may occur as a side effect of async removal and mechanisms for handling async removal.

Since async removal may be unexpected to both the Physical and Data Link Layers of the Downstream Port associated with the slot, Correctable Errors may be reported as a side effect of the event (i.e. Receiver Error, Bad TLP, and Bad

DLLP). If these errors are reported, software should handle them as an expected part of this event.

Requesters may experience Completion Timeouts associated with Requests that were accepted, but will never be

completed by removed Completers. Any resulting Completion Timeout errors in this context should be handled as an expected part of this event.

Async removal may result in a transition from DL\_Active to DL\_Down in the Downstream port. This transition may result

in a Surprise Down error. In addition, Requesters in the PCI Express hierarchy domain may not become immediately aware of this transition and continue to issue Requests to removed Completers that must be handled by the

Downstream Port associated with the slot.

Either Downstream Port Containment (DPC) or the Hot-Plug Surprise (HPS) mechanism may be used to support async removal as part of an overall async hot-plug architecture. See Appendix Ifor the associated reference model.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Hot-Plug Surprise Mechanism Deprecated for Async Hot-Plug

The Hot-Plug Surprise (HPS) mechanism, as indicated by the Hot-Plug Surprise bit in the Slot Capabilities Register being Set, is deprecated for use with async hot-plug. DPC is the recommended mechanism for supporting async hot-plug. See[Section 6.7.4.4f](#bookmark96)or guidance on slots supporting both mechanisms.

With async removal, using HPS has serious downsides. Uncorrectable errors other than those that inherently

bring down the Link need to be configured either to crash the system, be handled asynchronously by software, or be ignored. These include uncorrectable errors associated with Posted Memory Writes,TLPs with poisoned data, and Completion Timeouts. Uncorrectable errors ignored or handled asynchronously by software may make it

impossible for the driver to determine which high-level operations complete successfully versus those that do not.

DPC provides a robust mechanism for supporting async removal. The TLP stream cleanly stops upon an

uncorrectable error that triggers DPC. Operating System / driver stacks that support Containment Error Recovery (CER) can fully and transparently recover from many transient PCIe uncorrectable errors. DPC can support async removal andCERconcurrently

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAFwCAYAAACFCTqTAAAATklEQVRoge3MsQ0AIAwDwYQlaRmNlinDBCg10rn9kyOaZaxTz7pnju4BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAL4DF9bQBd7HI1DDAAAAAElFTkSuQmCC)

**6.8 Power Budgeting Capability**

With the addition of a hot-plug capability for adapters, the need arises for the system to be capable of properly

allocating power to any new devices added to the system. This capability is a separate and distinct function from power management and a basic level of support is required to ensure proper operation of the system. The power budgeting concept puts in place the building blocks that allow devices to interact with systems to achieve these goals. There are many ways in which the system can implement the actual power budgeting capabilities, and as such, they are beyond the scope of this specification.

Implementation of the Power Budgeting Capability is optional for devices that are implemented either in a form factor which does not require hot-plug support, or that are integrated on the system board. Form factor specifications may

require support for power budgeting. The devices and/or adapters are required to remain under the configuration power limit specified in the corresponding electromechanical specification until they have been configured and enabled by the system. The system should guarantee that power has been properly budgeted prior to enabling an adapter.

**6.8.1 System Power Budgeting Process Recommendations**

It is recommended that system firmware provide the power budget management agent the following information:

• Total system power budget (power supply information).

• Total power allocated by system firmware (system board devices).

• Total number of slots and the types of slots.

System firmware is responsible for allocating power for all devices on the system board that do not have power

budgeting capabilities. The firmware may or may not include devices that are connected to the standard power rails. When the firmware allocates the power for a device that implements the Power Budgeting Capability it must set the System Allocated bit to 1b in the Power Budget Capability register to indicate that it has been properly allocated. The

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

power budget manager is responsible for allocating all PCI Express devices including system board devices that have the Power Budgeting Capability and have the System Allocated bit Clear. The power budget manager is responsible for

determining if hot-plugged devices can be budgeted and enabled in the system.

There are alternate methods which may provide the same functionality, and it is not required that the power budgeting process be implemented in this manner.

**6.9 Slot Power Limit Control**

PCI Express provides a mechanism for software controlled limiting of the maximum power per slot that an adapter (associated with that slot) can consume. If supported, the Emergency Power Reduction State, over-rides the

mechanisms listed here (see Section 6.25). The key elements of this mechanism are:

• Slot Power Limit Value and Scale fields of the Slot Capabilities register implemented in the Downstream Ports of a Root Complex or a Switch

• Captured Slot Power Limit Value and Scale fields of the Device Capabilities register implemented in Endpoint, Switch, or PCI Express-PCI Bridge Functions present in an Upstream Port

• Set\_Slot\_Power\_Limit Messagethat conveys the content of the Slot Power Limit Value and Scale fields of the Slot Capabilities register of the Downstream Port (of a Root Complex or a Switch) to the corresponding

Captured Slot Power Limit Value and Scale fields of the Device Capabilities register in the Upstream Port of the component connected to the same Link

Power limits on the platform are typically controlled by the software (for example, platform firmware) that comprehends the specifics of the platform such as:

• Partitioning of the platform, including slots for I/O expansion using adapters

• Power delivery capabilities

• Thermal capabilities

This software is responsible for correctly programming the Slot Power Limit Value and Scale fields of the Slot

Capabilities registers of the Downstream Ports connected to slots. After the value has been written into the register

within the Downstream Port, it is conveyed to the adapter using theSet\_Slot\_Power\_Limit Message (see Section 2.2.8.5 ). The recipient of the Message must use the value in the Message data payload to limit usage of the power for the entire adapter, unless the adapter will never exceed the lowest value specified in the corresponding form factor specification. It is required that device driver software associated with the adapter be able (by reading the values of the Captured Slot

Power Limit Value and Scale fields of the Device Capabilities register) to configure hardware of the adapter to guarantee that the adapter will not exceed the imposed limit. In the case where the platform imposes a limit that is below the

minimum needed for adequate operation, the device driver will be able to communicate this discrepancy to higher level configuration software. Configuration software is required to set the Slot Power Limit to one of the maximum values

specified for the corresponding form factor based on the capability of the platform.

The following rules cover the Slot Power Limit control mechanism: For Adapters:

• Until and unless a Set\_Slot\_Power\_Limit Messageis received indicating a Slot Power Limit value greater than the lowest value specified in the form factor specification for the adapter's form factor, the adapter must not consume more than the lowest value specified.

• An adapter must never consume more power than what was specified in the most recently received

Set\_Slot\_Power\_Limit Messageor the minimum value specified in the corresponding form factor specification, whichever is higher.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• Components with Endpoint, Switch, or PCI Express-PCI Bridge Functions that are targeted for integration on an adapter where total consumed power is below the lowest limit defined for the targeted form factor are

permitted to ignore Set\_Slot\_Power\_Limit Messages, and to return a value of 0 in the Captured Slot Power Limit Value and Scale fields of the Device Capabilities register

。 Such components still must be able to receive the Set\_Slot\_Power\_Limit Messagewithout error but

simply discard the Message value

For Root Complex and Switches which source slots:

• Configuration software must not program a Set\_Slot\_Power\_Limit value that indicates a limit that is lower than the lowest value specified in the form factor specification for the slot’s form factor.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAANJCAYAAAAx433fAAAAe0lEQVR4nO3MsQ0AIAwDwYQlaRmNlinDBCiiP7d/ckSzjHXqWffM0T0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAPALLpRhCZATSCnGAAAAAElFTkSuQmCC)

**IMPLEMENTATION NOTE**

Example Adapter Behavior Based on the Slot Power Limit Control Capability

The following power limit scenarios are examples of how an adapter must behave based on the Slot Power Limit control capability. The form factor limits are representations, and should not be taken as actual requirements.

Note: Form factor #1 has a maximum power requirement of 40 W and 25 W; form factor #2 has a maximum power requirement of 15 W.

**Scenario 1: An Adapter Consuming 12 W**

• If the adapter is plugged into a form factor #1 40 W slot, the Slot Power Limit control mechanism is followed, and the adapter operates normally.

• If the adapter is plugged into a form factor #1 25 W slot, the Slot Power Limit control mechanism is followed, and the adapter operates normally.

• If the adapter is plugged into a form factor #2 15 W slot, the Slot Power Limit control mechanism is followed, and the adapter operates normally.

In all cases, since the adapter operates normally within all the form factors, it can ignore any of the slot power limit Messages.

**Scenario 2: An Adapter Consuming 18 W**

• If the adapter is plugged into a form factor #1 40 W slot, the Slot Power Limit control mechanism is followed, and the adapter operates normally.

• If the adapter is plugged into a form factor #1 25 W slot, the Slot Power Limit control mechanism is followed, and the adapter operates normally.

• If the adapter is plugged into a form factor #2 15 W slot, the Slot Power Limit control mechanism is

followed, and the adapter must scale down to 15 W or disable operation. An adapter that does not scale within any of the power limits for a given form factor will always be disabled in that form factor and

should not be used.

In this case, if the adapter is only to be used in form factor #1, it can ignore any of the slot power limit Messages. To be useful in form factor #2, the adapter should be capable of scaling to the power limit of form factor #2.

**Scenario 3: An Adapter Consuming 30 W**

• If the adapter is plugged into a form factor #1 40 W slot, the Slot Power Limit control mechanism is followed, and the device operates normally.

• If the adapter is plugged into a form factor #1 25 W slot, the Slot Power Limit control mechanism is followed, and the device must scale down to 25 W or disable operation.

• If the adapter is plugged into a form factor #2 15 W slot, the Slot Power Limit control mechanism is

followed, and the adapter must scale down to 15 W or disable operation. An adapter that does not scale within any of the power limits for a given form factor will always be disabled in that form factor and

should not be used.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

In this case, since the adapter consumes power above the lowest power limit for a slot, the adapter must be

capable of scaling or disabling to prevent system failures. Operation of adapters at power levels that exceed the capabilities of the slots in which they are plugged must be avoided.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAABbCAYAAABOFcTSAAAAM0lEQVRIiWNgIAAYGRJW/scpuyCckYmQCaMKRhWMKhhVMKpgVMGoglEFowpGFYwqoFwBAMv5A7RkjTsKAAAAAElFTkSuQmCC)

**IMPLEMENTATION NOTE**

Slot Power Limit Control Registers

Typically Slot Power Limit register fields within Downstream Ports of a Root Complex or a Switch will be

programmed by platform-specific software. Some implementations may use a hardware method for initializing the values of these registers and, therefore, do not require software support.

Components with Endpoint, Switch, or PCI Express-PCI Bridge Functions that are targeted for integration on the adapter where total consumed power is below the lowest limit defined for that form factor are allowed to ignore Set\_Slot\_Power\_Limit Messages. Note that components that take this implementation approach may not be

compatible with potential future defined form factors. Such form factors may impose lower power limits that are below the minimum required by a new adapter based on the existing component.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAD0CAYAAACmX2fpAAAAPklEQVRYhe3KoQEAIAzAsI0nsZyG5cphsLuA1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAAAAAAAAAAAA+BNcWSgE6KDAJNsAAAAASUVORK5CYII=)

**IMPLEMENTATION NOTE**

Auto Slot Power Limit Disable

In some environments host software may wish to directly manage the transmission of a Set\_Slot\_Power\_Limit

message by performing a Configuration Write to the Slot Capabilities register rather than have the transmission automatically occur when the Link transitions from a non-DL\_Up to a DL\_Up status. This allows host software to limit power supply surge current by staggering the transition of Endpoints to a higher power state following a Link Down or when multiple Endpoints are simultaneously hot-added due to cable or adapter insertion.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAC5CAYAAAAVmX5bAAAAPUlEQVRYhe3MoREAIAwEwYQmsZSGpcpQAROD3Le38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAMAvcAEtIQRwxqu4vAAAAABJRU5ErkJggg==)

**6.10 Root Complex Topology Discovery**

A Root Complex may present one of the following topologies to configuration software:

• A single opaque Root Complex such that software has no visibility with respect to internal operation of the

Root Complex. All Root Ports are independent of each other from a software perspective; no mechanism exists to manage any arbitration among the various Root Ports for any differentiated services.

• A single Root Complex Component such that software has visibility and control with respect to internal

operation of the Root Complex Component. As shown in [Figure 6-11 ,](#bookmark97) software views the Root Ports as Ingress Ports for the component. The Root Complex internal Port for traffic aggregation to a system Egress Port or an internal sink unit (such as memory) is represented by an RCRBstructure. Controls for differentiated services are provided through a Virtual Channel Capability structure located in the RCRB.

Ingress

Ingress

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Root Complex**  Root Port 1   |  | | --- | | Port  Arbitration |  |  | | --- | | Sink |  |  | | --- | | Internal Port |   Egress  Root Port 2   |  | | --- | | VC  Arbitration |  |  | | --- | | RCRB A | |

A-0423

Figure 6-11 Root Complex Represented as a Single Component

• Multiple Root Complex Components such that software not only has visibility and control with respect to

internal operation of a given Root Complex Component but also has the ability to discover and control

arbitration between different Root Complex Components. As shown in [Figure 6-12 ,](#bookmark98) software views the Root Ports as Ingress Ports for a given component. AnRCRBstructure controls egress from the component to other Root Complex Components (RCRBC) or to an internal sink unit such as memory (RCRB A). In addition, an RCRB structure (RCRBB) may also be present in a given component to control traffic from other Root Complex

Components. Controls for differentiated services are provided through Virtual Channel Capability structures located appropriately in the RCRBs respectively.

More complex topologies are possible as well.

A Root Complex topology can be represented as a collection of logical Root Complex Components such that each logical component has:

• One or more Ingress Ports.

• An Egress Port.

• Optional associated Virtual Channel capabilities located either in the Configuration Space (for Root Ports) or in an RCRB (for internal Ingress/Egress Ports) if the Root Complex supports Virtual Channels.

• Optional devices/Functions integrated in the Root Complex.

In order for software to correctly program arbitration and other control parameters for PCI Express differentiated

services,software must be able to discover a Root Complex’s internal topology. Root Complex topology discovery is accomplished by means of the Root Complex Link Declaration Capability as described in Section 7.9.8 .

Ingress

Ingress

Ingress

Ingress

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| s  Egress   |  |  |  |  | | --- | --- | --- | --- | | Component 1  Root Port 1   |  | | --- | | VC  Arbitration |   Internal Port  Root Port 2   |  | | --- | | Port  Arbitration |  |  | | --- | | RCRB C | |   **Root Complex**   |  |  |  |  |  |  |  |  |  |  |  |  | | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | |  | | Ingres | | Component 2 | | | | | | | | | Internal Port | | |  | |  | | --- | | RCRB B |   VC  Arbitration |  | | | | | | |  |  | |  |  | | Root Port 1  Root Port 2 |  | | | Port  Arbitration | | | | |  | Internal Port | | Egress | Sink Unit |  | |  | |  |  |  | | |  | |  | | | RCRB A | | |  | | | | |  |  | |

A-0424

Figure 6-12 Root Complex Represented as Multiple Components

**6.11 Link Speed Management**

This section describeshow Link speed management is coordinated between the LTSSM (Section 4.2.6 ) and the software Link observation and control mechanisms (see Section 7.5.3.6 ,Section 7.5.3.7 ,Section 7.5.3.8 ,Section 7.5.3.18 ,

Section 7.5.3.19, and Section 7.5.3.20).

The Target Link Speed field in the Link Control 2 register in the Downstream Port sets the upper bound for the Link

speed. Except as described below, the Upstream component must attempt to maintain the Link at the Target Link Speed,

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

or at the highest speed supported by both components on the Link (as reported by the values in the training sets - see Section 4.2.4.1), whichever is lower.

Any Upstream Port or Downstream Port with the Hardware Autonomous Speed Disable bit in the Link Control 2 register clear is permitted to autonomously change the Link speed using implementation specific criteria.

If the reliability of the Link is unacceptably low, theneither component is permitted to lower the Link speed by removing the unreliable Link speed from the list of supported speeds advertised in the training sets the component transmits. The criteria for determination of acceptable Link reliability are implementation specific, and are not dependent on the

setting of the Hardware Autonomous Speed Disable bit.

During any given speed negotiation it is possible that one or both components will advertise a subset of all speeds supported, as a means to cap the post-negotiation Link speed. It is permitted for a component to change its set of advertised supported speeds without requesting a Link speed change by driving the Link through Recovery without setting the speed change bit.

When a component’s attempt to negotiate to a particular Link speed fails, that component is not permitted to attempt negotiation to that Link speed, or to any higher Link speed, until 200 ms has passed from the return to L0 following the failed attempt, or until the other component on the Link advertises support for the higher Link speed through its

transmitted training sets (with or without a request to change the Link speed), whichever comes first.

Software is permitted to restrict the maximum speed of Link operation and set the preferred Link speed by setting the value in the Target Link Speed field in the Upstream component. After modifying the value in the Target Link Speed field, software must trigger Link retraining by writing 1b to the Retrain Link bit. Software is notified of any Link speed changes (as well as any Link width changes) through the Link Bandwidth Notification Mechanism.

Software is permitted to cause a Link to transition to the Polling.Compliance LTSSM state at a particular speed by writing the Link Control 2 register in both components with the same value in the Target Link Speed field and Setting the Enter Compliance bit, and then initiating a Hot Reset on the Link (through the Downstream Port).

Note that this will take the Link to a DL\_Down state and therefore cannot be done transparently to other software that is using the Link. The Downstream Port will return to Polling.Active when the Enter Compliance bit is cleared.

**6.12 Access Control Services (ACS)**

ACS defines a set of control points within a PCI Express topology to determine whether a TLP is to be routed normally, blocked, or redirected. ACS is applicable to RCs, Switches, and Multi-Function Devices.113 For ACS requirements,

single-Function devices that are SR-IOV capable must be handled as if they wereMulti-Function Devices, since they essentially behave as Multi-Function Devicesafter their Virtual Functions (VFs) are enabled.

Implementation of ACS in RCiEPs is permitted but not required. It is explicitly permitted that, within a single Root Complex, some RCiEPs implement ACS and some do not. It is strongly recommended that Root Complex

implementations ensure that all accesses originating from RCiEPs (PFs and VFs) without ACS capability are first

subjected to processing by the Translation Agent (TA) in the Root Complex before further decoding and processing. The details of such Root Complex handling are outside the scope of this specification.

ACS provides the following types of access control:

• ACS Source Validation

• ACS Translation Blocking

• ACS P2P Request Redirect

• ACS P2P Completion Redirect

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

113. Applicable Functions within Multi-Function Devicesspecifically include PCI Express Endpoints, Switch Upstream Ports, Legacy PCI Express Endpoints, and Root Complex Integrated Endpoints.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• ACS Upstream Forwarding

• ACS P2P Egress Control

• ACS Direct Translated P2P

• ACS I/O Request Blocking

• ACS DSP Memory Target Access

• ACS USP Memory Target Access

• ACS Unclaimed Request Redirect

The specific requirements for each of these are discussed in the following section.

ACS hardware functionality is disabled by default, and is enabled only by ACS-aware software. With the exception of ACS Source Validation, ACS access controls are not applicable to Multicast TLPs (see[Section 6.14](#bookmark99)), and have no effect on

them.

**6.12.1 ACS Component Capability Requirements**

ACS functionality is reported and managed via ACS Extended Capability structures. PCI Express components are

permitted to implement ACS Extended Capability structures in some, none, or all of their applicable Functions. The extent of what is implemented is communicated through capability bits in each ACS Extended Capability structure. A given Function with an ACS Extended Capability structure may be required or forbidden to implement certain

capabilities, depending upon the specific type of the Function and whether it is part of a Multi-Function Device.

ACS is never applicable to a PCI Express to PCI Bridge Function or a Root Complex Event Collector Function, and such

Functions must never implement an ACS Extended Capability structure.

[**6.12.1.1**](6.12.1.1) **ACS Downstream Ports**

This section applies to Root Ports and Switch Downstream Ports that implement an ACS Extended Capability structure. This section applies to Downstream Port Functions both for single-Function devices and Multi-Function Devices.

• ACS Source Validation: must be implemented.

When enabled, the Downstream Port tests the Bus Number from the Requester ID of each Upstream Request received by the Port to determine if it is associated with the Secondary side of the virtual bridge associated with the Downstream Port, by either or both of:

。 Determining that the Requester ID falls within the Bus Number “aperture” of the Port -the inclusive range specified by the Secondary Bus Number register and the Subordinate Bus Number register.

。 If FPB is implemented and enabled, determining that the Requester ID isassociated with the bridge’s Secondary Side by the application of the FPB Routing ID mechanism.

If the Bus Number from the Requester ID of the Request is not within this aperture, this is a reported error (ACS Violation) associated with the Receiving Port (see[Section 6.12.5](#bookmark100).)

Completions are never affected by ACS Source Validation.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAACXCAYAAAAoPxodAAAAOUlEQVRYhe3MMREAIAwEwQSTtEijRWVQwEQA++3tfESzjHXqWffM0T0AAAAAAAAAAAAAAAAAwG/gAknGBCzHRqDrAAAAAElFTkSuQmCC)

**IMPLEMENTATION NOTE**

Upstream Messages and ACS Source Validation

Functions are permitted to transmit Upstream Messages before they have been assigned a Bus Number. Such messages will have a Requester ID with a Bus Number of 00h. If the Downstream Port has ACS Source Validation enabled, these Messages (see Table F-1 and Section 6.23.1 ) will likely be detected as an ACS Violation error.

• ACS Translation Blocking: must be implemented.

When enabled, the Downstream Port checks the Address Type (AT) field of each Upstream Memory Request received by the Port. If the AT field is not the default value, this is a reported error (ACS Violation) associated with the Receiving Port (see[Section 6.12.5)](#bookmark101). This error must take precedence over ACS Upstream Forwarding and any applicable ACS P2P control mechanisms.

Completions are never affected by ACS Translation Blocking.

• ACS P2P Request Redirect: must be implemented by Root Ports that support peer-to-peer traffic with other Root Ports;114 must be implemented by Switch Downstream Ports.

ACS P2P Request Redirect is subject to interaction with the ACS P2P Egress Control and ACS Direct Translated P2P mechanisms (if implemented). Refer to[Section 6.12.3f](#bookmark102)or more information.

When ACS P2P Request Redirect is enabled in a Switch Downstream Port, peer-to-peer Requests must be redirected Upstream towards the RC.

When ACS P2P Request Redirect is enabled in a Root Port, peer-to-peer Requests must be sent to Redirected Request Validation logic within the RC that determines whether the Request is “reflected” back Downstream towards its original target, or blocked as an ACS Violation error. The algorithms and specific controls for

making this determination are not architected by this specification.

Downstream Ports never redirect Requests that are traveling Downstream. Completions are never affected by ACS P2P Request Redirect.

• ACS P2P Completion Redirect: must be implemented by Root Ports that implement ACS P2P Request Redirect; must be implemented by Switch Downstream Ports.

The intent of ACS P2P Completion Redirect is to avoid ordering rule violations between Completions and Requests when Requests are redirected. Refer to[Section 6.12.6f](#bookmark103)or more information.

ACS P2P Completion Redirect does not interact with ACS controls that govern Requests.

When ACS P2P Completion Redirect is enabled in a Switch Downstream Port, peer-to-peer Completions115 that do not have the Relaxed OrderingAttribute bit set (1b) must be redirected Upstream towards the RC.

Otherwise, peer-to-peer Completions must be routed normally.

When ACS P2P Completion Redirect is enabled in a Root Port, peer-to-peer Completions that do not have the Relaxed Ordering bit set must be handled such that they do not pass Requests that are sent to Redirected

Request Validation logic within the RC. Such Completions must eventually be sent Downstream towards their original peer-to-peer targets, without incurring additional ACS access control checks.

Downstream Ports never redirect Completions that are traveling Downstream. Requests are never affected by ACS P2P Completion Redirect.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

114. Root Port indication of ACS P2P Request Redirect or ACS P2P Completion Redirect support does not imply any particular level of peer-to-peer support by the Root Complex, or that peer-to-peer traffic is supported at all

115. This includes Read Completions, AtomicOp Completions, and other Completions with or without Data.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• ACS Upstream Forwarding: must be implemented by Root Ports if the RC supports Redirected Request Validation; must be implemented by Switch Downstream Ports.

When ACS Upstream Forwarding is enabled in a Switch Downstream Port, and its Ingress Port receives an

Upstream Request or Completion TLP targeting the Port’s own Egress Port, the Port must instead forward the TLP Upstream towards the RC.

When ACS Upstream Forwarding is enabled in a Root Port, and its Ingress Port receives an Upstream Request or

Completion TLP that targets the Port’s own Egress Port, the Port must handle the TLP as follows. For a

Request, the Root Port must handle it the same as a Request that the Port “redirects” with the ACS P2P

Request Redirect mechanism. For a Completion, the Root Port must handle it the same as a Completion that the Port “redirects” with the ACS P2P Completion Redirect mechanism.

When ACS Upstream Forwarding is not enabled on a Downstream Port, and its Ingress Port receives an Upstream Request or Completion TLP that targets the Port’s own Egress Port, the handling of the TLP is undefined.

• ACS P2P Egress Control: implementation is optional.

ACS P2P Egress Control is subject to interaction with the ACS P2P Request Redirect and ACS Direct Translated P2P mechanisms (if implemented). Refer to[Section 6.12.3f](#bookmark104)or more information.

A Switch that supports ACS P2P Egress Control can be selectively configured to block peer-to-peer Requests between its Downstream Ports. Software can configure the Switch to allow none or only a subset of its

Downstream Ports to send peer-to-peer Requests to other Downstream Ports. This is configured on a per Downstream Port basis.

An RC that supports ACS P2P Egress Control can be selectively configured to block peer-to-peer Requests

between its Root Ports. Software can configure the RC to allow none or only a subset of the Hierarchy Domains to send peer-to-peer Requests to other Hierarchy Domains. This is configured on a per Root Port basis.

With ACS P2P Egress Control in Downstream Ports, controls in the Ingress Port (“sending” Port) determine if the peer-to-peer Request is blocked, and if so, the Ingress Port handles the ACS Violation error per[Section](#bookmark105) [6.12.5 .](#bookmark106)

Completions are never affected by ACS P2P Egress Control.

• ACS Direct Translated P2P: must be implemented by Root Ports that support Address Translation Services (ATS) and also support peer-to-peer traffic with other Root Ports;116 must be implemented by Switch Downstream

Ports.

When ACS Direct Translated P2P is enabled in a Downstream Port, peer-to-peer Memory Requests whose

Address Type (AT) field indicates a Translated address must be routed normally (“directly”) to the peer Egress Port, regardless of ACS P2P Request Redirect and ACS P2P Egress Control settings. All other peer-to-peer

Requests must still be subject to ACS P2P Request Redirect and ACS P2P Egress Control settings.

Completions are never affected by ACS Direct Translated P2P.

• ACS I/O Request Blocking: must be implemented by Root Ports and Switch Downstream Ports that support ACS Enhanced Capability.

When enabled, the Port must handle an Upstream I/O Request received by the Port’s Ingress as an ACS Violation.

• ACS DSP Memory Target Access: must be implemented by Root Ports and Switch Downstream Ports that support ACS Enhanced Capability and that have applicable Memory BAR Space to protect.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

116. Root Port indication of ACS Direct Translated P2P support does not imply any particular level of peer-to-peer support by the Root Complex, or that peer-to-peer traffic is supported at all.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

ACS DSP Memory Target Access determineshow an Upstream Request received by the Downstream Port’s Ingress and targeting any Memory BAR Space117 associated with an applicable Downstream Port is handled. The Request can be blocked, redirected, or allowed to proceed directly to its target. In a Switch, all

Downstream Ports are applicable, including the one on which the Request was received. In a Root Complex, the set of applicable Root Ports is implementation specific, but always includes the one on which the Request was received.

• ACS USP Memory Target Access: must be implemented by Switch Downstream Ports that support ACS

Enhanced Capability and that have applicable Memory BAR Space in the Switch Upstream Port to protect; is not applicable to Root Ports.

ACS USP Memory Target Access determineshow an Upstream Request received by the Switch Downstream Port’s Ingress and targeting any Memory BAR Space118 associated with the Switch’s Upstream Port is handled. The Request can be blocked, redirected, or allowed to proceed directly to its target.

If any Functions other than the Switch Upstream Port are associated with the Upstream Port, this field has no effect on accesses to their Memory BAR Space119 . Such access is controlled by the ACS Extended Capability (if present) in the Switch Upstream Port.

• ACS Unclaimed Request Redirect: must be implemented by Switch Downstream Ports that support ACS Enhanced Capability; is not applicable to Root Ports.

When enabled, incoming Requests received by the Switch Downstream Port’s Ingress and targeting Memory Space within the memory window of a Switch Upstream Port that is not within a memory window or Memory BAR Target of any Downstream Port within the Switch are redirected Upstream out of the Switch.

When not enabled,such Requests are handled by the Switch Downstream Port as an Unsupported Request (UR).

[**6.12.1.2**](6.12.1.2) **ACS Functions in SR-IOV Capable andMulti-Function Devices**

This section applies toMulti-Function DeviceACS Functions, with the exception of Downstream Port Functions, which are covered in the preceding section. For ACS requirements, single-Function devices that are SR-IOV capable must be handled as if they wereMulti-Function Devices.

• ACS Source Validation: must not be implemented.

• ACS Translation Blocking: must not be implemented.

• ACS P2P Request Redirect: must be implemented by Functions that support peer-to-peer traffic with other Functions. This includes SR-IOVVirtual Functions (VFs).

ACS P2P Request Redirect is subject to interaction with the ACS P2P Egress Control and ACS Direct Translated P2P mechanisms (if implemented). Refer to[Section 6.12.3f](#bookmark107)or more information.

When ACS P2P Request Redirect is enabled in a Multi-Function Devicethat is not an RCiEP, peer-to-peer Requests (between Functions of the device) must be redirected Upstream towards the RC.

It is permitted but not required to implement ACS P2P Request Redirect in an RCiEP. When ACS P2P Request Redirect is enabled in an RCiEP, peer-to-peer Requests, defined as all Requests that do not target system

memory, must be sent to implementation-specific logic within the Root Complex that determines whether the

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

117. This also includes any Memory Space allocated by an Expansion ROM Base Address register (BAR). This also includes any Memory Space allocated by EA entries with a BEI value of 0, 1, 7, or 8. SeeSection 7.8.5.3 .

118. This also includes any Memory Space allocated by an Expansion ROM Base Address register (BAR). This also includes any Memory Space allocated by EA entries with a BEI value of 0, 1, 7, or 8. SeeSection 7.8.5.3 .

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)119. This also includes any Memory Space allocated by an Expansion ROM Base Address register (BAR). This also includes any Memory Space allocated by EA entries with a BEI value of 0, 1, 7, or 8. SeeSection 7.8.5.3 .

Page 584

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Request is directed towards its original target, or blocked as an ACS Violation error. The algorithms and specific controls for making this determination are not architected by this specification.

Completions are never affected by ACS P2P Request Redirect.

• ACS P2P Completion Redirect: must be implemented by Functions that implement ACS P2P Request Redirect. The intent of ACS P2P Completion Redirect is to avoid ordering rule violations between Completions and

Requests when Requests are redirected. Refer to[Section 6.12.6f](#bookmark108)or more information.

ACS P2P Completion Redirect does not interact with ACS controls that govern Requests.

When ACS P2P Completion Redirect is enabled in a Multi-Function Devicethat is not an RCiEP, peer-to-peer Completions that do not have the Relaxed Ordering bit set must be redirected Upstream towards the RC.

Otherwise, peer-to-peer Completions must be routed normally. Requests are never affected by ACS P2P Completion Redirect.

• ACS Upstream Forwarding: must not be implemented.

• ACS P2P Egress Control: implementation is optional; is based on Function Numbers or[Function Group](#bookmark109)

[Numbers](#bookmark110); controls peer-to-peer Requests between the different Functions within the multi-Function or SR-IOV capable device.

ACS P2P Egress Control is subject to interaction with the ACS P2P Request Redirect and ACS Direct Translated P2P mechanisms (if implemented). Refer to[Section 6.12.3f](#bookmark111)or more information.

Each Function within a Multi-Function Devicethat supports ACS P2P Egress Control can be selectively enabled to block peer-to-peer communication with other Functions or Function Groups120 within the device. This is

configured on a per Function basis.

With ACS P2P Egress Control in multi-Function or SR-IOV capable devices, controls in the "sending" Function determine if the Request is blocked, and if so, the "sending" Function handles the ACS Violation error per

[Section 6.12.5 .](#bookmark112)

When ACS Function Groups are enabled in an ARI Device (ACS Function Groups Enableis Set),ACS P2P Egress Controls are enforced on a per Function Group basis instead of a per Function basis. See [Section 6.13 .](#bookmark113)

Completions are never affected by ACS P2P Egress Control.

• ACS Direct Translated P2P: must be implemented if the Multi-Function Device Function supports Address Translation Services (ATS) and also peer-to-peer traffic with other Functions.

When ACS Direct Translated P2P is enabled in a Multi-Function Device, peer-to-peer Memory Requests whose Address Type (AT) field indicates a Translated address must be routed normally (“directly”) to the peer

Function, regardless of ACS P2P Request Redirect and ACS P2P Egress Control settings. All other peer-to-peer Requests must still be subject to ACS P2P Request Redirect and ACS P2P Egress Control settings.

Completions are never affected by ACS Direct Translated P2P.

[**6.12.1.3**](6.12.1.3) **Functions in Single-Function Devices**

This section applies to single-Function device Functions, with the exception of Downstream Port Functions and SR-IOV capable Functions, which are covered in a preceding section. For ACS requirements, single-Function devices that are SR-IOV capable must be handled as if they wereMulti-Function Devices.

No ACS capabilities are applicable, and the Function must not implement an ACS Extended Capability structure.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

120. ACS Function Groups capability is optional for ARI Devices that implement ACS P2P Egress Controls.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.12.2 Interoperability**

The following rules govern interoperability between ACS and non-ACS components:

• When ACS P2P Request Redirect and ACS P2P Completion Redirect are not being used, ACS and non-ACS

components may be intermixed within a topology and will interoperate fully. ACS can be enabled in a subset of the ACS components without impacting interoperability.

• When ACS P2P Request Redirect, ACS P2P Completion Redirect, or both are being used, certain components in the PCI Express hierarchy must support ACS Upstream Forwarding (of Upstream redirected Requests).

Specifically:

The associated Root Port121 must support ACS Upstream Forwarding. Otherwise, how the Root Port handles Upstream redirected Request or Completion TLPs is undefined. The RC must also implement Redirected

Request Validation.

Between each ACS component where P2PTLP redirection is enabled and its associated Root Port, any intermediate Switches must support ACS Upstream Forwarding. Otherwise, how such Switches handle Upstream redirected TLPs is undefined.

**6.12.3 ACS Peer-to-Peer Control Interactions**

With each peer-to-peer Request, multiple ACS control mechanisms may interact to determine whether the Request is routed directly towards its peer-to-peer target, blocked immediately as an ACS Violation, or redirected Upstream

towards the RC for access validation. Peer-to-peer Completion redirection is determined exclusively by the ACS P2P Completion Redirect mechanism.

If ACS Direct Translated P2P is enabled in a Port/Function, peer-to-peer Memory Requests whose Address Type (AT) field

indicates a Translated address must be routed normally (“directly”) to the peer Port/Function, regardless of ACS P2P Request Redirect and ACS P2P Egress Control settings. Otherwise such Requests, and unconditionally all other

peer-to-peer Requests, must be subject to ACS P2P Request Redirect and ACS P2P Egress Control settings. Specifically, the applicable Egress Control Vector bit, along with the ACS P2P Egress Control Enable bit (E) and the ACS P2P Request Redirect Enable bit (R), determine how the Request is handled. It must be noted that atomicity of accesses cannot be guaranteed if ACS peer-to-peer Request Redirect targets a legacy device location that can be the target of a locked

access. Refer toSection 7.7.8for descriptions of these control bits.[Table 6-10](#bookmark114)specifies the interactions.

Table 6-10 ACSP2P Request Redirect and ACSP2P Egress Control Interactions

|  |  |  |  |
| --- | --- | --- | --- |
| Control Bit E (b) | Control Bit R (b) | Egress Control Vector Bit for the Associated Egress Switch Port, Root Port, Function, or Function Group | Required Handling for Peer-to-Peer Requests |
| 0 | 0 | X - Don’t care | Route directly to peer-to-peer target |
| 0 | 1 | X - Don’t Care | Redirect Upstream |
| 1 | 0 | 1 | Handle as an ACS Violation |
| 1 | 0 | 0 | Route directly to peer-to-peer target |
| 1 | 1 | 1 | Redirect Upstream |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

121. Not applicable for ACS Redirect between Functions of a multi-Function Root Complex Integrated Endpoint.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |
| --- | --- | --- | --- |
| Control Bit E (b) | Control Bit R (b) | Egress Control Vector Bit for the Associated Egress Switch Port, Root Port, Function, or Function Group | Required Handling for Peer-to-Peer Requests |
| 1 | 1 | 0 | Route directly to peer-to-peer target |

**6.12.4 ACS Enhanced Capability**

ACS Enhanced Capability is an additional set of ACS control mechanisms to improve the level of isolation and protection provided by ACS. ACS Enhanced Capability defines the following additional access control mechanisms:

• ACS I/O Request Blocking

• ACS DSP Memory Target Access

• ACS USP Memory Target Access

• ACS Unclaimed Request Redirect

Through these mechanisms, ACS Enhanced Capability provides protection and consistent handling of Requests directed toward regions not covered by the original ACS mechanisms.

**IMPLEMENTATION NOTE**

ACS Redirect and Guest Physical Addresses (GPAs)

ACS redirect mechanisms were originally architected to enable fine-grained access control for P2P Memory

Requests, by redirecting selected Requests Upstream to the RC, where validation logic determines whether to

allow or deny access. However, ACS redirect mechanisms can also ensure that Functions under the direct control of VMs have their DMA Requests routed correctly to the Translation Agent in the host, which then translates their guest physical addresses (GPAs) into host physical addresses (HPAs).

GPA ranges used for Memory Space vs. DMA are not guaranteed to coincide with HPA ranges, which the PCIe fabric uses for Memory Request routing and access control. If any GPAs used for DMA fall with within the HPA ranges

used for Memory Space, legitimate or malicious packet misrouting can result.

ACS redirect mechanisms can ensure that Upstream Memory Requests with GPAs intended for DMA never get

routed to HPA Memory ranges. ACS P2P Request Redirect handles this for (1) peer accesses between Functions within a Multi-Function Device and (2) peer accesses between Downstream Ports within a Switch or RC. ACS P2P Egress Control with redirect handles this in a more fine-grained manner for the same two cases.

Redirect mechanisms introduced with ACS Enhanced Capability handle this for additional cases. ACS DSP

Memory Target Access with redirect handles this for Downstream Port Memory Resource ranges. ACS USP Memory Target Access with redirect handles this for Switch Upstream Port Memory Resource ranges. In Switches, ACS

Unclaimed Request Redirect handles this for any areas within Upstream Port Memory apertures that are not

handled by the other ACS redirect mechanisms. Together these ACS redirect mechanisms can ensure that

Upstream Memory Requests with GPAs intended for DMA are always routed or redirected to the Translation Agent in the host, and those with GPAs intended for P2P are still routed as originally architected.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAHACAYAAACfwynmAAAAVUlEQVRoge3MMREAIAwEwQSTtEijRWVQwEQA++3tfESzjHXqWffM0T0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB8BS6fQAZ+8OsaOQAAAABJRU5ErkJggg==)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.12.5 ACS Violation Error Handling**

ACS Violations may occur due to either hardware or software defects/failures. To assist in fault isolation and root cause analysis, it is recommended that AER be implemented in ACS components. AER prefix/header logging and the Prefix Log/ Header Log registers may be used to determine the prefix/header of the offending Request. The ACS Violation Status,

Mask, and Severity bits provide positive identification of the error and increased control over error logging and signaling.

When an ACS Violation is detected, the ACS component that operates as the Completer122 must do the following:

• For Non-Posted Requests, the Completer must generate a Completion with a Completer Abort (CA) Completion Status.

• The Completer must log and signal the ACS Violation as indicated in [Figure 6-2 .](#bookmark35) Note the following:

。 Even though the Completer uses a CA Completion Status when it sends a Completion, the Completer

must log an ACS Violation error instead of a Completer Abort error.

。 If the severity of the ACS Violation is non-fatal and the Completer sends a Completion with CA

Completion Status, this case must be handled as an Advisory Non-Fatal Error as described in [Section](#bookmark22)

[6.2.3.2.4.1 .](#bookmark22)

• The Completer123 must set the Signaled Target Abort bit in either its Status register or Secondary Status register as appropriate.

**6.12.6 ACS Redirection Impacts on Ordering Rules**

When ACS P2P Request Redirect is enabled, some or all peer-to-peer Requests are redirected, which can cause ordering rule violations in some cases. This section explores those cases, plus a similar case that occurs with RCs that implement “Request Retargeting” as an alternative mechanism for enforcing peer-to-peer access control.

[**6.12.6.1**](6.12.6.1) **Completions Passing Posted Requests**

When a peer-to-peer Posted Request is redirected, a subsequent peer-to-peer non-RO124 Completion that is routed

directly can effectively pass the redirected Posted Request, violating the ordering rule that non-RO Completions must not pass Posted Requests. Refer toSection 2.4.1for more information.

ACS P2P Completion Redirectcan be used to avoid violating this ordering rule. When ACS P2P Completion Redirectis

enabled, all peer-to-peer non-RO Completions will be redirected, thus taking the same path as redirected peer-to-peer Posted Requests. Enabling ACS P2P Completion Redirect when some or all peer-to-peer Requests are routed directly will not cause any ordering rule violations, since it is permitted for a given Completion to be passed by any TLP other than another Completion with the same Transaction ID.

As an alternative mechanism to ACS P2P Request Redirect for enforcing peer-to-peer access control, some RCs

implement “Request Retargeting”, where the RC supports special address ranges for “peer-to-peer” traffic, and the RC will retarget validated Upstream Requests to peer devices. Upon receiving an Upstream Request targeting a special

address range, the RC validates the Request, translates the address to target the appropriate peer device, and sends the Request back Downstream. With retargeted Requests that are Non-posted, if the RC does not modify the Requester ID,

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

122. In all cases but one, the ACS component that detects the ACS Violation also operates as the Completer. The exception case is when Root Complex Redirected Request Validation logic disallows a redirected Request. If the redirected Request came through a Root Port, that Root Port must operate as the Completer. If the redirected Request came from a Root Complex Integrated Endpoint, the associated Root Complex Event Collector must operate as the Completer.

123. Similarly, if the Request was Non-Posted, when the Requester receives the resulting Completion with CA Completion Status, the Requester must set the

Received Target Abort bit in either its Status register or Secondary Status register as appropriate. Note that for the case of aMulti-Function Deviceincurring an ACS Violation error with a peer-to-peer Request between its Functions, the same Function might serve both as Requester and Completer.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)124. In this section, “non-RO” is an abbreviation characterizing TLPs whoseRelaxed OrderingAttribute field is not set.

Page 588

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

the resulting Completions will travel “directly” peer-to-peer back to the original Requester, creating the possibility of non-RO Completions effectively passing retargeted Posted Requests, violating the same ordering rule as when ACS P2P Request Redirect is being used. ACS P2P Completion Redirect can be used to avoid violating this ordering rule here as well.

IfACS P2P Request Redirectand RC P2P Request Retargeting are not being used, there is no envisioned benefit to

enabling ACS P2P Completion Redirect, and it is recommended not to do so because of potential performance impacts.

**IMPLEMENTATION NOTE**

Performance Impacts with ACS P2P Completion Redirect

While the use ofACS P2P Completion Redirectcan avoid ordering violations with Completions passing Posted

Requests, it also may impact performance. Specifically, all redirected Completions will have to travel up to the RC from the point of redirection and back, introducing extra latency and possibly increasing Link and RC congestion.

Since peer-to-peer Completions with theRelaxed Ordering bit set are never redirected (thus avoiding

performance impacts), it is strongly recommended that Requesters be implemented to maximize the proper use ofRelaxed Ordering, and that software enable Requesters to utilize Relaxed Ordering by setting the Enable

Relaxed Ordering bit in the Device Control Register.

If software enablesACS P2P Request Redirect, RC P2P Request Retargeting, or both, and software is certain that proper operation is not compromised by peer-to-peer non-RO Completions passing peer-to-peer125 Posted

Requests, it is recommended that software leave ACS P2P Completion Redirect disabled as a way to avoid its performance impacts.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAExCAYAAABBDeNaAAAASElEQVRoge3MoREAIAwEwYQmsZSGpcpQAROL2Le38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP+DCyXNBWDzcOPGAAAAAElFTkSuQmCC)

[**6.12.6.2**](6.12.6.2) **Requests Passing Posted Requests**

When some peer-to-peer Requests are redirected but other peer-to-peer Requests are routed directly, the possibility exists of violating the ordering rules where Non-posted Requests or non-RO Posted Requests must not pass Posted Requests. Refer toSection 2.4.1for more information.

These ordering rule violation possibilities exist only when ACS P2P Request Redirect and ACS Direct Translated P2P are both enabled. Software should not enable both these mechanisms unless it is certain either that such ordering rule

violations cannot occur, or that proper operation will not be compromised if such ordering rule violations do occur.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

125. These include true peer-to-peer Requests that are redirected by the ACS P2P Request Redirect mechanism, as well as “logically peer-to-peer” Requests routed to the Root Complex that the Root Complex then retargets to the peer device.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Ensuring Proper Operation with ACS Direct Translated P2P

The intent of ACS Direct Translated P2P is to optimize performance in environments where Address Translation Services (ATS) are being used with peer-to-peer communication whose access control is enforced by the RC.

Permitting peer-to-peer Requests with Translated addresses to be routed directly avoids possible performance impacts associated with redirection, which introduces extra latency and may increase Link and RC congestion.

For the usage model where peer-to-peer Requests with Translated addresses are permitted, but those with

Untranslated addresses are to be blocked as ACS Violations, it is recommended that software enable ACS Direct Translated P2P andACS P2P Request Redirect, and configure the Redirected Request Validation logic in the RC to block the redirected Requests with Untranslated addresses. This configuration has no ordering rule violations

associated with Requests passing Posted Requests.

For the usage model where some Requesters use Translated addresses exclusively with peer-to-peer Requests

and some Requesters use Untranslated addresses exclusively with peer-to-peer Requests, and the two classes of Requesters do not communicate peer-to-peer with each other, proper operation is unlikely to be compromised by redirected peer-to-peer Requests (with Untranslated addresses) being passed by direct peer-to-peer Requests

(with Translated addresses). It is recommended that software not enable ACS Direct Translated P2P unless software is certain that proper operation is not compromised by the resulting ordering rule violations.

For the usage model where a single Requester uses both Translated and Untranslated addresses with

peer-to-peer Requests, again it is recommended that software not enable ACS Direct Translated P2P unless

software is certain that proper operation is not compromised by the resulting ordering rule violations. This

requires a detailed analysis of the peer-to-peer communications models being used, and is beyond the scope of this specification.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAHRCAYAAABXSfjYAAAAVklEQVRoge3MMREAIAwEwQSTtEijRWVQkImBvfZ3PmIo47xq17tzTQ8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHR9AbEGoPOh7g0AAAAASUVORK5CYII=)

**6.13 Alternative Routing-ID Interpretation (ARI)**

Routing IDs, Requester IDs, and Completer IDs are 16-bit identifiers traditionally composed of three fields: an 8-bit Bus Number, a 5-bit Device Number, and a 3-bit Function Number. With ARI, the 16-bit field is interpreted as two fields

instead of three: an 8-bit Bus Number and an 8-bit Function Number -the Device Number field is eliminated. This new interpretation enables an ARI Device to support up to 256 Functions [0..255] instead of 8 Functions [0..7].

ARI is controlled by a new set of optional capability and control register bits. These provide:

• Software the ability to detect whether a component supports ARI.

• Software the ability to configure an ARI Downstream Port so the logic that determines when to turn a Type 1 Configuration Request into a Type 0 Configuration Request no longer enforces a restriction on the traditional Device Number field being 0.

• Software the ability to configure an ARI Device to assign each Function to a Function Group. Controls based on Function Groups may be preferable when finer granularity controls based on individual Functions are not

required.

。 If Multi-Function VC arbitration is supported and enabled, arbitration can optionally be based on Function Groups instead of individual Functions.

。 If ACS P2P Egress Controls are supported and enabled, access control can optionally be based on Function Groups instead of individual Functions.

The following illustrates an example flow for enabling these capabilities and provides additional details on their usage:

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

1. Software enumerates the PCI Express hierarchy and determines whether theARI Extended Capabilityis supported.

a. For an ARI Downstream Port, the capability is communicated through the Device Capabilities 2 register.

b. For an ARI Device, the capability is communicated through the ARI Extended Capabilitystructure.

c. ARI has no impact on the base enumeration algorithms used in platforms today.

2. Software enables ARI functionality in each component.

a. In an ARI Downstream Port immediately above an ARI Device, software sets the ARI Forwarding

Enable bit in the Device Control 2 register. Setting this bit ensures the logic that determines when to turn a Type 1 Configuration Request into a Type 0 Configuration Request no longer enforces a

restriction on the traditional Device Number field being 0.

b. In an ARI Device, Extended Functions must respond if addressed with a Type 0 Configuration Request. It is necessary for ARI-aware software to enable ARI Forwarding in the Downstream Port immediately above the ARI Device, in order for ARI-aware software to discover and configure the Extended

Functions.

c. If an ARI Device implements a Multi-Function VC Capability structure with Function arbitration, and also implements MFVC Function Groups, ARI-aware software categorizes Functions into Function Groups.

i. Each Function is assigned to a Function Group represented by a **Function Group Number**. ii. A maximum of 8 Function Groups can be configured.

iii. Within the Multi-Function VC Arbitration Table, a [Function Group Number](#bookmark115)is used in place of a Function Number in each arbitration slot.

1. Arbitration occurs on a Function Group basis instead of an individual Function basis.

2. All other aspects of Multi-Function VC arbitration remain unchanged. See Section

7.9.2.10 for additional details.

iv. Function arbitration within each Function Groupis implementation-specific.

d. If an ARI Device supports ACS P2P Egress Control, access control can be optionally implemented on a Function Group basis.

e. To improve the enumeration performance and create a more deterministic solution, software can enumerate Functions through a linked list of Function Numbers. The next linked list element is

communicated through each Function’s ARI Capability Register.

i. Function 0 acts as the head of a linked list of Function Numbers. Software detects a

non-zero Next Function Number field within the ARI Capability Registeras the next Function within the linked list. Software issues a configuration probe using the Bus Number captured by the Device and the Function Number derived from the ARI Capability Registerto locate the next associated Function’s configuration space.

ii. Function Numbers may be sparse and non-sequential in their consumption by an ARI Device.

With an ARI Device, the Phantom Functions Supportedfield within each Function’s Device Capabilities register (see

Section 7.5.3.3 ,Table 7-19 ) must be set to 00b to indicate that Phantom Functions are not supported. The Extended Tag Field Enable bit and the 10-Bit Tag Requester Enable bit can still be used to enable each Function to support higher

numbers of outstanding Requests. See Section 2.2.6.2 .

[Figure 6-13](#bookmark116)shows an example system topology with two ARI Devices, one below a Root Port and one below a Switch. For access to Extended Functions inARI Device X, Root PortA must support ARI Forwarding and have it enabled by

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

software. For access to Extended Functions inARI Device Y, Switch Downstream Port D must support ARI Forwarding and have it enabled by software. With this configuration, it is recommended that software not enable ARI Forwarding in Root Port B or Switch Downstream Port C.

Root Port

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Root Port A  Root Complex | | |  | |
| B |  |
|  |  |  |  |  |

|  |  |  |  |
| --- | --- | --- | --- |
| ARI Device X | | | |
| |  | | --- | | F0 | | |  | | --- | | F1 | | |  | | --- | | F2 | |  |

Up to 256 Functions

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
|  | | |  | |
| Non-ARI Device | | | | |
|  | |  | | --- | | F1 | | |  | | --- | | F2 | | |  |

|  |
| --- |
| Upstream Port |

Switch

Downstream Port D

Downstream Port C

F0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
|  | | |  | |
| ARI Device Y | | | | |
| F0 | |  | | --- | | F1 | | |  | | --- | | F2 | | |  |

1 to 8 Functions Up to 256 Functions A-0719

Figure 6-13 Example System Topology with ARI Devices

**IMPLEMENTATION NOTE**

ARI Forwarding Enable Being Set Inappropriately

It is strongly recommended that software in general Set the ARI Forwarding Enable bit in a Downstream Port only if software is certain that the device immediately below the Downstream Port is an ARI Device. If the bit is Set

when a non-ARI Device is present, the non-ARI Device can respond to Configuration Space accesses under what it interprets as being different Device Numbers, and its Functions can be aliased under multiple Device Numbers, generally leading to undesired behavior.

Following a hot-plug event below a Downstream Port, it is strongly recommended that software Clear the ARI

Forwarding Enable bit in the Downstream Port until software determines that a newly added component is in fact an ARI Device.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAD1CAYAAABtA7RMAAAAQElEQVRYhe3KoREAIAwAsZYlsYyGZUow2B4DkLefjLF2VM2erZw3AAAAAAAAAAAAAAAAAAAAAAAAAAAAAPgTPDv7EAToeNxdeQAAAABJRU5ErkJggg==)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

ARI Forwarding Enable Setting at Firmware/Operating System Control Handoff

It is strongly recommended that firmware not have the ARI Forwarding Enable bit Set in a Downstream Port upon control handoff to an operating system unless firmware knows that the operating system is ARI-aware. With this bit Set, a non-ARI-aware operating system might be able to discover and enumerate Extended Functions in an ARI Device below the Downstream Port, but such an operating system would generally not be able to manage

Extended Functions successfully, since it would interpret there being multiple Devices below the Downstream Port instead of a single ARI Device. As one example of many envisioned problems, the interrupt binding for INTx virtual wires would not be consistent with what the non-ARI-aware operating system would expect.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAD4CAYAAADRnaeSAAAAQ0lEQVRYhe3MoREAIAwEwYQmsZSGpcpQAROF27e38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMAncAFAqwTuK+NT5gAAAABJRU5ErkJggg==)

**6.14 Multicast Operations**

The Multicast Capability structure defines a Multicast address range, the segmentation of that range into a number, N, of equal sized Multicast Windows, and the association of each Multicast Window with a Multicast Group, MCG. Each

Function that supports Multicast within a component implements a Multicast Capability structure that provides routing directions and permission checking for each MCG for TLPs passing through or to the Function. The Multicast Group is a field of up to 6 bits in width embedded in the address beginning at theMC\_Index\_Position, as defined in Section 7.9.11.4

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAACo0lEQVQ4ja3UTUwTQRQH8H+XImzbdKvh5GUXtoWW7raKEVATwSgXaiBGIxFjPCoJMSTix0lj/Dp48yroiWgUDYEQThC8AMFQBQ8tkiZdDyjRpoRlt9tNmfFUg9o2Ffo/TvJ+700mbyzIE5EX9gAIsSzbyrLsUUKI02KxmJmtzJK6oU4DGIkp8R/56i05wHKWZW8BuOH2eCyn2tockiRZnByHdDqNlZUvmJuZ1d9PT5eV7ykfUTfUvpgS/56vQRYVg5K83N3VpS1Ho7RQEokEffzwkSl5farPU3umEOqRvL7Ei8FBQggpiG5PeCFMD8iy7nV7LuRC7YF6/7eXQ0PFi9sSjURooN6vi7xw+A84KMnPrvX2pnaCZjM2OkqDfumryAsV2Wn3++u8RjKZ3I1LKaX0/Nlzm57qmssAwFRWVvZ0dHbC5XIVfNhicqXnqt3hcNwGAIZl2Y7206GKXasAjre0wDAMt8gLTkbTtDo5ECiFC6vViuqaGh3AQYZSWsZxXElgAFiORp0AQgxybN9uYrfbCYAkwzCMsba2VjK4qqpqE8AUY7PZPi8tLpYETaVSWF1dtQFYZFRVffVueFgvBTwxPg6WZedjStyAyAvO+to6XVGUXS1HJpOhJ1tPqCIvhACAiSnxDQAPrvf16YSQHU/7fGCAJBI/owAmfh+KvFAWlOSP9+7cTf/Pz5bN1OQklbw+VeQF4Z+OIi/sDUpy5GZ/f1rTtKJAQggdfv0mizbmvY7IC1xQkt8ea2rWxkZHqWmaecHwQphe6r6oBf1STOQF+W8r53KIvNDOcdx9QomvsbFpq+FQg4NzuZA2DEQiEWNuZjazvr6um6b5xDTNpzElbhYFb2vgBnDEZrM1W63WfYTSlK5pnwgh8wA+xJT4Vr7aXwAXqkyBN/8XAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAYAAAAFCAYAAABmWJ3mAAAAGUlEQVQImWNkYGBgUJZX+M+ABpjQBWggAQClCgFrZJdfVAAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAsAAAAiCAYAAACJDyPYAAABI0lEQVQ4jc2Sv0pDMRSHv9sWcZJLFzcTyOLct+jq0tkX0FfxCVxcHNx0sPd2kTpIt2JBHAIJIuJkneqfK3UwV9LYtHcR7g9Ckt/5ODnnkARPSsg5gbQ1SXluhMFVqglcEzWXmUrIs3aavr+8Tu99P9ZgB9gOzZrM+R9hJeSGEnJzHaiETBtAAVwrIfci0K4SMgM6iTNOgR4wAA6BC+AI2AEOgE+gXcL7wLFLVgAfbt9y3qW2pttyl8x7ueWWrxzcNLQ1j8BkRX/ZL+zUj4BP2ppJVTgvDz48BGaVYG3NG3AVgPNY5mWl3GprnqvCuX9ZgLU1d8CDZ2VROMhe8NN0JfhGWzNbBw+AL+A8DPyBtTVTYBTWG8sMcAKMI7FFKSHDXwfAN4sDT3ohzA9gAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIMAAAANCAYAAACKJ93OAAAAUUlEQVRYhe3XMQqAQAxFwb9eRMH7H0nQk2iXQmVbRWfKVIG8Ji1J5nHac7JsazvP+I67mw9PLMI7iYEiBooYAOhoidfyj7yWdImBIgaKGICrA7WZCtW5O4SCAAAAAElFTkSuQmCC).

|  |
| --- |
| MC\_Base\_Address |

|  |
| --- |
| 2MC\_Index\_Position |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAACu0lEQVQ4ja2TS08TURiG357SFmg7EKRRAskMDEgvMzDFAAkLRIPGhX8AowsUQzTRFdG4cOdKRd0Rd14I1Q2JihECJphggiBxQYuG0qSzqCFgsa1tmUuZcYVppFSBPsuTnOd9z5fzGZAHlmYoAC0ABAAUAAXANwDzITEcyXfXsIuw2Wa331YU+WxtbZ3sbWmxVFRUWCRpM+Nf9KcDfr/FaDR+TSQSdwCMhsSwni8ELM1YmtyewWaOTz8eGtI2Njb0XCiKor8dG9O7T5xMCjw/w9JMTT5pcTPHfzjfcy69vraWU5gr4OHgA5VzuqIszTTkkhoEnp/o77ucVhTlv6TZvPD5NM7p+sHSjGPbaQSAww7HpSNVVf3DvpFSs9mcd1y54DjOEI/HTCsrQcFaUjryMx4DWJop8TQ6fwX8gT03zUbalPSOtvYkSzOdAEAIIT2CV4Db495z02wsxRb0X71ipSjqFgDgWLMw/ebV6wO13SYei+vO+gaFpRkTkWVZELzeA7XdhiqjUOlwSAA8RFVVe3VNdUHEAKBrWjGATkII0QyGnAu4L1ZXV00AnETXdT2ZTBZMzHFcAsAosVqtoaVAoCBSTdMQDAZLAHwhqqpOvJ+aUgshnp+bg8ls/h4Sw1GwNMM2uT1SKpU68Hfr672YamTrrwEACYnhEDGS8ft37ykHaftxZgafZmelTCbz5M8hSzOHOKcrNjU5ua+mkUhEb/W2pI/WsWd2JLI008Y5XcmJd+N7koqiqHe0tac4p+vmrs9haaaVd7nXbwwMSNFoNK9QlmX9+dNnGu9yp3mX+/rfrh2bwdIMZbPbH6mK0tN9+pR+vKurhOM4lJWXQ5IkBJeXsfB5Yeulz6cAWEwkEr0hMbz0T3FWQGVRUdEFm83Wndna8m5lMlZCiGo2m4OpdGpakZXhkBjedQF+A+mQuQ2UtANyAAAAAElFTkSuQmCC)

*+*

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAACK0lEQVQ4jbWVP0wTURzHv/enPdI2V0mHigN38RDptXetiYuiA43QhsTRlQQXDYvGhMS46Ipu6OROGheVFSkutg4QjX8iSLj0Whhaky7iXXstuedCScVeK3B+xpe8z/u9vLzvl4IDkiBSAC6xLHslEAiM0gzTT2y7bpjGh4bVyAN4oxX1mtN+qpPQ4/Hc5Pr6HvE8f2osOeZV1biXD/KwLAub3zftfO6dsbG+QTMM89wwjIdaUd91OqAlPZ1QlFx6fOJXPpcntm0TJwqFArl3525dicg/JEG82k06oMrR7Sdzc3vNZtNReJiVbJaoctQcPiulOkm5eDS29Wx+fu+fjW2sra6S2EjEkARR/kOsROTH01NTZrer9yKzsGDHY8q6JIhsa9qQPHy+Vi6Xjy0lhBDbtsn1ycldSRBvAADNcdytiXQK4XC468P2gqIo3J6ZCQSDwQcAgIuJC2tvsysnmrZFvV4nI0PnmpIg+mnDNGQlrp5o2hYcx2FQGDQBJGhiE28oFHJFDADalsYDSNGuGQ9BUzTVqFarrgmlIekngCXa7/N/+/LpsytSy7JQKpZ8AD7Spmm+XFx87ZhSRyG7vAyfz/dVK+rGwQepVCrufhCtqFcZhnl6f3a2Rgg59rQvMhlSKm3vAHh1sPjfQmhffkaVozuuxmabfCAeU3Lpa+M9g17X9a5B71RN0/vV1J9MJjlFVT1Hraa/xO0HALjMsuxohzJ9D2CpW5n+BmFZ6iYbUzBwAAAAAElFTkSuQmCC)

*+*

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAACqklEQVQ4ja3VS0hUURgH8P/c61znYRPZoqDiXubkvO5jnOwBVgoJZe0MAhMK3bSIGAQxokXRKogKJrdp1mwiadEuIQgKJN/SoiQZm4nAjeO87r3OjM09bTJKr4OP+e/P73zfdzjnWLBBCC94nE7ndY7jWjRN8xSLRY5lWcPhdPwEMJLL5gYAvIsl4tRsvcUEPOByuQYNwzjV3tFR1dTcVCVKElwuF4qFIubmvmFyYgLPnw1qS0tLSVVVr8QS8Q8bFQgA8LhJq+j15R4/fLSSX87TcjEMgw6/HaYhWdGVgPiA8MK6IlfR80pA1MfHxsqCa7O4uEjPtrRoSkB8YjbPg6LXp06Mj28JXU0qlaKnG09qvsN1l/+DQ7Lyvi8SWdmW+icz09NU8vlzhBf2rlYrh2RFLxQKO3EppZR2h8N6wOO9DQBMTU3NjaudnRzHcWUPdjPp7OqyW63WMAAwLMueaWpuZnesAlCCQZRKpT2EF/YxmqYJ/oC/Ei4sFgu8Pm8eQIhhGAZ2u70iMADMTM+4ALQzpVKJodT0Vm4rbuLOA/jI2Gy2VCIerxis5tRfAD4xHMdNTU1OVgRNJpNIp9McgFkmk8n0R19E1UrAr4eGDK66+k0sES+B8IJV8vmTY6OjO7oc2WyWNgTrNcILR//u5HGTtsbjJzRVVbcN9/b05IOSHF3XRr0sRy+1XdR0Xd8y2heJrCgBMUF4Ydc6mPACGxSlVxfOtWrzsdimwFwuR2/13swrAfEH4YX9Gw6f8ALjr/OEJZ9fv3fnbuH7/LwpmEln6MDTfuPYkQatXpZfEl7YvdYyffUJLxyy2+3dlNJrDoeDESWpVFtbyy7nl+nsl6/GwsKCzeFwDGcymfuxRHzEzDD/Tv7pAAABEALgAlAAMAvgcywRL5Rb+xs4otag8Mfl4AAAAABJRU5ErkJggg==)

*+*

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAAKCAYAAAC5Sw6hAAAA10lEQVQokZ3QvUoDQRTF8V+ivaCC5S6unYUPlM7G1jfxCSx8DJM0BgmIiDYiCgMzoFaijZCg+FFkFhYlcfHCcIsz5885t1MVZQ9vGIYUX/xzOlVRbuMKXVygjwHGIcX31iCoivIA+z+0V5zU4JDiTRvQCm6xseDvfU7aNzvD0y9Qhu3isE0NfOEygwc47TbEx5aQOsAmtvJer6stmR16Z4H5E+c4zu8spPhRi8t5782BPDSMw5Di89yIVVGu4Q6rmGJUm0OK13+WbCTq4SibRyHFSVtzc74BP/pDH0Xq64QAAAAASUVORK5CYII=) *+*

|  |
| --- |
| Multicast Group 0 Memory Space |
| Multicast Group 1 Memory Space |
| Multicast Group 2 Memory Space |
| Multicast Group 3 Memory Space |
|  |
| Multicast Group *N-1* Memory Space |

A-0755

Figure 6-14 Segmentation ofthe Multicast Address Range

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.14.1 Multicast TLP Processing**

A Multicast Hit occurs if all of the following are true:

• MC\_Enableis Set

• TLP is a Memory Write or an Address Routed Message, both of which are Posted Requests

• Address TLP >=MC\_Base\_Address

• Address TLP < (MC\_Base\_Address+ (2MC\_Index\_Position \* (MC\_Num\_Group+ 1)))

In this step, each SwitchIngress Port and other components use values ofMC\_Enable,MC\_Base\_Address,

MC\_Index\_Position, and MC\_Num\_Groupfrom any one of their Functions. Software is required to configure all Functions of a Switch and all Functions of a Multi-Function Upstream Port to have the same values in each of these fields and

results are indeterminate if this is not the case.

If the address in a Non-Posted Memory Request hits in a Multicast Window, no Multicast Hit occurs and the TLP is processed normally per the base specification - i.e., as a unicast.

If a Multicast Hit occurs, the only ACS access control that can still apply is ACS Source Validation. In particular, neither ACS redirection nor the ACS Egress Control vector affects operations during a Multicast Hit.

If a Multicast Hit occurs, normal address routing rules do not apply. Instead, the TLP is processed as follows:

The Multicast Group is extracted from the address in the TLP using any Function’s values for MC\_Base\_Addressand MC\_Index\_Position. Specifically:

MCG = ((Address TLP -MC\_Base\_Address) >>MC\_Index\_Position) & 3Fh

In this process, the component may use any Function’s values for MC\_Base\_Addressand MC\_Index\_Position. Which Function’s values are used is device-specific.

Components next check theMC\_Block\_Alland the MC\_Block\_Untranslatedbits corresponding to the extracted MCG.

Switches and Root Ports check Multicast TLPs in their Ingress Ports using theMC\_Block\_Alland MC\_Block\_Untranslated registers associated with the Ingress Port. Endpoint Functions check Multicast TLPs they are preparing to send, using

their MC\_Block\_Alland MC\_Block\_Untranslated registers. If theMC\_Block\_All bit corresponding to the extracted MCG is set, the TLP is handled as an [MC Blocked TLP](#bookmark117). If the MC\_Block\_Untranslated bit corresponding to the extracted MCG is set and the TLP contains an Untranslated Address, the TLP, is also handled as an [MC Blocked TLP.](#bookmark118)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

MC\_Block\_Untranslated and PIO Writes

Programmed I/O (PIO) Writes to Memory Space generally have Untranslated addresses since there is no

architected mechanism for software to control the Address Type (AT) field for PIO Requests. Thus, if it’s necessary

for a given Switch to Multicast any PIO Writes, software should ensure that the appropriate

MC\_Block\_Untranslated bits in the Upstream Port of that Switch are Clear. Otherwise, the Switch Upstream Port may block PIO Writes that legitimately target Multicast Windows. Since it may be necessary for software to clear MC\_Block\_Untranslated bits in a Switch Upstream Port for the sake of PIO Writes, the following are strongly

recommended for a Root Complex capable of Address translation:

• All Integrated Endpoints each implement a Multicast Capability structure to provide access control for sending Untranslated Multicast TLPs.

• All peer-to-peer capable Root Ports each implement a Multicast Capability structure to provide access control for Untranslated Multicast TLPs that are forwarded peer-to-peer.

For similar reasons,with Multicast-capable Switch components where the Upstream Port is a Function in a Multi-Function Device, it is strongly recommended that any Endpoints in that Multi-Function Deviceeach implement a Multicast Capability structure.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAFzCAYAAAADnUg9AAAATklEQVRoge3MsQ0AIAwDwYQlaRmNlinDAAhlgfvWJ0c0ZaxT33XPHN0DAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABvFx1jBeT0+WgzAAAAAElFTkSuQmCC)

**IMPLEMENTATION NOTE**

Multicast Window Size

Each ultimate Receiver of a Multicast TLP may have a different Multicast Window size requirement. At one

extreme, a Multicast Window may be required to cover a range of memory implemented within the device. At the other, it may only need to cover a particular offset at which a FIFO register is located. The

MC\_Window\_Size\_Requested field within the Multicast Capability register is used by an Endpoint to advertise the size of Multicast Window that it requires.

Unless available address space is limited, resource allocation software may be able to treat each request as a

minimum and set the Multicast Window size via MC\_Index\_Positionto accommodate the largest request. In some cases, a request for a larger window size can be satisfied by configuring a smaller window size and assigning the same membership to multiple contiguous MCGs.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAEFCAYAAADe5qbhAAAAQUlEQVRoge3KoREAIAwAsZYlsYyGZcpisD0WyNtPxjoVXXvmaOcLAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA+HYBQWUFCMEbDqwAAAAASUVORK5CYII=)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Multicast, ATS, and Redirection

The ACS P2P Request Redirection and ACS Direct Translated P2P mechanisms provide a means where P2P

Requests with Untranslated Addresses can be redirected to the Root Complex (RC) for access control checking, whereas P2P Requests with Translated Addresses can be routed “directly” to their P2P targets for improved

performance. No corresponding redirection mechanism exists for Multicast TLPs.

To achieve similar functionality, an RC might be configured to provide one or more target Memory Space ranges that are not in the Multicast address range, but the RC maps to “protected” Multicast Windows. Multicast TLP

senders either with or without ATS capability then target these RC Memory Space ranges in order to access the protected Multicast Windows indirectly. When either type of sender targets these ranges with Memory Writes,

each TLP that satisfies the access control checks will be reflected back down by the RC with a Translated Address targeting a protected Multicast Window.126 ATS-capable senders can request and cache Translated Addresses

using the RC Memory Space range, and then later use those Translated Addresses for Memory Writes that target protected Multicast Windows directly and can be Multicast without a taking a trip through the RC.

For hardware enforcement that only Translated Addresses can be used to target the protected Multicast Windows directly, software Sets appropriate MCG bits in the MC\_Block\_Untranslated register in all applicable Functions

throughout the platform. Each MCG whose bit is set will cause its associated Multicast Window to be protected from direct access using Untranslated Addresses.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAGECAYAAAALCmGcAAAAUElEQVRoge3MoREAIAwEwYQmsZSGpcpQAROB3be38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAfIILLjwGBvIN9tEAAAAASUVORK5CYII=)

If the TLP is not blocked in a Switch or Root Complex it is forwarded out all of the Ports, except its Ingress Port, whose MC\_Receive bit corresponding to the extracted MCG is set. In an Endpoint, it is consumed by all Functions whose

MC\_Receive bit corresponding to the extracted MCG is set. If no Ports forward the TLP or no Functions consume it, the TLP is silently dropped.

To prevent loops, it is prohibited for a Root Port or a Switch Port to forward a TLP back out its Ingress Port, even if so

specified by the MC\_Receive register associated with the Port. An exception is the case described in the preceding

Implementation Note, where an RC reflects a unicast TLP that came in on an Ingress Root Port to a Multicast Window. In that case, when specified by the MC\_Receive register associated with that Ingress Root Port, the RC is required to send the reflected TLP out the same Root Port that it originally came in.

A Multicast Hit suspends normal address routing, including default Upstream routing in Switches. When a Multicast Hit occurs, the TLP will be forwarded out only those Egress Ports whose MC\_Receive bit associated with the MCG extracted from the address in the TLP is set. If the address in the TLP does not decode to any Downstream Port using normal

address decode, the TLP will be copied to the Upstream Port only if so specified by the Upstream Port’s MC\_Receive register.

**6.14.2 Multicast Ordering**

No new ordering rules are defined for processing Multicast TLPs. All Multicast TLPs are Posted Requests and follow Posted Request ordering rules. Multicast TLPs are ordered per normal ordering rules relative to other TLPs in a

component’s ingress stream through the point of replication. Once copied into an egress stream, a Multicast TLP follows the same ordering as other Posted Requests in the stream.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

126. If the original sender belongs to the MCG associated with this Window, the original sender will also receive a copy of the reflected TLP.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**6.14.3 Multicast Capability Structure Field Updates**

Some fields of the Multicast Capability structure may be changed at anytime. Others cannot be changed with

predictable results unless the MC\_Enable bit is Clear in every Function of the component. The latter group includes MC\_Base\_Addressand MC\_Index\_Position.

Fields which software may change at anytime include MC\_Enable,MC\_Num\_Group, MC\_Receive,MC\_Block\_All, and MC\_Block\_Untranslated. Updates to these fields must themselves be ordered. Consider, for example,TLPs A and B arriving in that order at the same Ingress Port and in the same TC. If A uses value X for one of these fields, then B must use the same value or a newer value.

For Multi-Function Upstream Switch Ports Multicast TLPs received by one Switch or transmitted by one Endpoint

Function are presented to the other parallel Endpoint Functions and the Downstream Switch Ports of the other parallel Switches (Functions are considered to be parallel if they are in the same Device. A single Multicast TLP is forwarded

Upstream when any of the Upstream Switch Functions has the appropriate MC\_Receive bit Set.

**6.14.4 MC Blocked TLP Processing**

When a TLP is blocked by the MC\_Block\_Allor the MC\_Block\_Untranslatedmechanisms, the TLP is dropped. The

Function blocking the TLP serves as the Completer. The Completer must log and signal this [MC Blocked TLP](#bookmark19)error as indicated in [Figure 6-2](#bookmark35). In addition, the Completer must set the Signaled Target Abort bit in either its Status register or Secondary Status register as appropriate. To assist in fault isolation and root cause analysis, it is highly recommended that AER be implemented in Functions with Multicast capability.

In Root Complexes and Switches, if the error occurs with a TLP received by an Ingress Port, the error is reported by that Ingress Port. If the error occurs in an Endpoint Function preparing to send the TLP, the error is reported by that Endpoint Function.

**6.14.5 MC\_Overlay Mechanism**

The [MC\_Overlay](#bookmark120) mechanism is provided to allow a single BAR in an Endpoint that doesn’t contain a Multicast Capability structure to be used for both Multicast and unicast TLP reception. Software can configure the [MC\_Overlay](#bookmark120) mechanism to affect this by setting the MC\_Overlay\_BARin a Downstream Port so that the Multicast address range, or a portion of it, is remapped (overlaid) onto the Memory Space range accepted by the Endpoint’s BAR. At the Upstream Port of a Switch, the mechanism can be used to overlay a portion of the Multicast address range onto a Memory Space range associated with host memory.

A Downstream Port’s [MC\_Overlay](#bookmark120)mechanism applies to TLPs exiting that Port. An Upstream Port’s [MC\_Overlay](#bookmark120)

mechanism applies to TLPs exiting the Switch heading Upstream. A Port’s [MC\_Overlay](#bookmark120)mechanism does not apply to TLPs received by the Port, to TLPs targeting memory space within the Port, or to TLPs routed Peer-to-Peer between Functions in a Multi-Function Upstream Port.

When enabled, the overlay operation specifies that bits in the address in the Multicast TLP, whose bit numbers are equal to or higher than theMC\_Overlay\_Sizefield, be replaced by the corresponding bits in the MC\_Overlay\_BAR. In other

words:

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

If (MC\_Overlay\_Size < 6)

Then Egress\_TLP\_Addr = Ingress\_TLP\_Addr;

Else Egress\_TLP\_Addr = { MC\_Overlay\_BAR[63:MC\_Overlay\_Size],

Ingress\_TLP\_Addr[MC\_Overlay\_Size-1:0] };

Equation 6-1 MC\_Overlay Transform rules

If the TLP with modified address contains the optional ECRC, the unmodified ECRC will almost certainly indicate an

error. The action to be taken if a TLP containing an ECRC is Multicast copied to an Egress Port that has [MC\_Overlay](#bookmark120)

enabled depends upon whether or not optional support for ECRC regeneration is implemented. All of the contingent actions are outlined in [Table 6-11](#bookmark121). If[MC\_Overlay](#bookmark120)is not enabled, the TLP is forwarded unmodified. If[MC\_Overlay](#bookmark120)is

enabled and the TLP has no ECRC, the modified TLP, with its address replaced as specified in the previous paragraph is forwarded. If the TLP has an ECRC but ECRC regeneration is not supported, then the modified TLP is forwarded with its ECRC dropped and the TD bit in the header cleared to indicate no ECRC attached. If the TLP has an ECRC and ECRC

regeneration is supported,then an ECRC check is performed before the TLP is forwarded. If the ECRC check passes, the TLP is forwarded with regenerated ECRC. If the ECRC check fails, the TLP is forwarded with inverted regenerated ECRC.

Table 6-11 ECRC Rules for MC\_Overlay

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| [MC\_Overlay](#bookmark120) Enabled | TLP has ECRC | ECRC Regeneration Supported | Action if ECRC Check Passes | Action if ECRC Check Fails |
| No | x | x | Forward TLP unmodified | |
| Yes | No | x | Forward modified TLP | |
| Yes | Yes | No | Forward modified TLPwith ECRC dropped and TD bit clear | |
| Yes | Yes | Yes | Forward modified TLP with regenerated ECRC | Forward modified TLP with inverted regenerated ECRC |

**IMPLEMENTATION NOTE**

MC\_Overlay and ECRC Regeneration

Switch and Root Complex Ports have the option to support ECRC regeneration. If ECRC regeneration is supported, then it is highly advised to do so robustly by minimizing the time between checking the ECRC of the original TLP and replacing it with an ECRC computed on the modified TLP. The TLP is unprotected during this time, leaving a data integrity hole if the pre-check and regeneration aren’t accomplished in the same pipeline stage.

Stripping the ECRC from Multicast TLPs passing through a Port that has [MC\_Overlay](#bookmark120)enabled but doesn’t support ECRC regeneration allows the receiving Endpoint to enable ECRC checking. In such a case, the Endpoint will enjoy

the benefits of ECRC on non-Multicast TLPs without detecting ECRC on Multicast TLPs modified by the [MC\_Overlay](#bookmark120)mechanism.

When Multicast ECRC regeneration is supported, and an ECRC error is detected prior to TLP modification, then inverting the regenerated ECRC ensures that the ECRC error isn’t masked by the regeneration process.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAEfCAYAAAB8q4ccAAAAQ0lEQVRoge3KoQEAIAzAsI0nsZyG5cphsNOY1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAv4AKAqAU+itHP0AAAAABJRU5ErkJggg==)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Multicast to Endpoints That Don’t Have Multicast Capability

An Endpoint Function that doesn’t contain a Multicast Capability structure cannot distinguish Multicast TLPs from unicast TLPs. It is possible for a system designer to take advantage of this fact to employ such Endpoints as

Multicast targets. The primary requirement for doing so is that the base and limit registers of the virtual PCI to PCI Bridge in the Switch Port above the device be configured to overlap at least part of the Multicast address range or that the [MC\_Overlay](#bookmark120) mechanism be employed. Extending this reasoning, it is even possible that a single Multicast target Function could be located on the PCI/PCI-X side of a PCI Express to PCI/PCI-X Bridge.

If an Endpoint without a Multicast Capability structure is being used as a Multicast target and the[MC\_Overlay](#bookmark120) mechanism isn’t used, then it may be necessary to read from the Endpoint’s Memory Space using the same

addresses used for Multicast TLPs. Therefore, Memory Reads that hit in a Multicast Window aren’t necessarily errors. Memory Reads that hit in a Multicast Window and that don’t also hit in the aperture of an RCiEP or the Downstream Port of a Switch will be routed Upstream, per standard address routing rules, and be handled as a UR there.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAE3CAYAAACXVABHAAAARUlEQVRoge3KoQEAIAzAsI0nsZyG5cphsPOI1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD4BFwbPBW4tIwV2AAAAAElFTkSuQmCC)

**IMPLEMENTATION NOTE**

Multicast in a Root Complex

A Root Complex with multiple Root Ports that supports Multicast may implement as many Multicast Capability structures as its implementation requires. If it implements more than one, software should ensure that certain fields, as specified in [Section 6.14.3 ,](#bookmark119) are configured identically. To support Multicast to RCiEPs, the

implementation needs to expose all TLPs identified as Multicast via theMC\_Base\_Address register to all potential Multicast target Endpoints integrated within it. Each such Integrated Endpoint then uses the MC\_Receive register in its Multicast Capability structure to determine if it should receive the TLP.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADJCAYAAAAeu3OaAAAAPUlEQVRYhe3KoREAIAwAsZYlsYyGZUow2B4Kl7efjLF2VM2erZw3AAAAAAAAAAAAAAAAAAAAAAAA4Ad4dgAONgSQoTMscgAAAABJRU5ErkJggg==)

**IMPLEMENTATION NOTE**

Multicast and Multi-Function Devices

All Port Functions and Endpoint Functions that are potential Multicast targets need to implement a Multicast

Capability structure so that each has its own MC\_Receive vector. Within a single component, software should

configure the MC\_Enable,MC\_Base\_Address,MC\_Index\_Position, and MC\_Num\_Groupfields of these Capability structures identically. That being the case, it is sufficient to implement address decoding logic on only one

instance of the Multicast BAR in the component.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAC4CAYAAADexa3+AAAAOUlEQVRYhe3KoQEAIAzAsI0nsZyG5cphsHPI1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAAAAAH6BCy0ABHCQiOhdAAAAAElFTkSuQmCC)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Congestion Avoidance

The use of Multicast increases the output link utilization of Switches to a degree proportional to both the size of the Multicast groups used and the fraction of Multicast traffic to total traffic. This results in an increased risk of congestion and congestion spreading when Multicast is used.

To mitigate this risk, components that are intended to serve as Multicast targets should be designed to consume Multicast TLPs at wire speed. Components that are intended to serve as Multicast sources should consider adding a rate limiting mechanism.

In many applications, the application’s Multicast data flow will have an inherent rate limit and can be

accommodated without causing congestion. Others will require an explicit mechanism to limit the injection rate, selection of a Switch with buffers adequate to hold the requisite bursts of Multicast traffic without asserting flow control, or selection of Multicast target components capable of sinking the Multicast traffic at the required rate. It is the responsibility of the system designer to choose the appropriate mechanisms and components to serve the application.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAFBCAYAAABKL+6bAAAAR0lEQVRoge3KoREAIAwAsZYlsYyGZcpisF2Ay9tPxjoVXXvmaOcLAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgM3ABFTIFgi+TSBkAAAAASUVORK5CYII=)

**IMPLEMENTATION NOTE**

The Host as a Multicast Recipient

For general-purpose systems, it is anticipated that the Multicast address range will usually not be configured to

overlap with Memory Space that’s directly mapped to host memory. If host memory is to be included as a

Multicast recipient, the Root Complex may need to have some sort of I/O Memory Management Unit (IOMMU) that is capable of remapping portions of Multicast Windows to host memory, perhaps with page-level granularity.

Alternatively, the [MC\_Overlay](#bookmark120) mechanism in the Upstream Port of a Switch can be used to overlay a portion of the Multicast address range onto host memory.

For embedded systems that lack an IOMMU, it may be feasible to configure Multicast Windows overlapping with Memory Space that’s directly mapped to host memory, thus avoiding the need for an IOMMU. Specific details of this approach are beyond the scope of this specification.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAEFCAYAAADe5qbhAAAAQUlEQVRoge3KoREAIAwAsZYlsYyGZcpisD0WyNtPxjoVXXvmaOcLAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA+IILQacFCnmNbgAAAAAASUVORK5CYII=)

**6.15 Atomic Operations (AtomicOps)**

AnAtomic Operation (AtomicOp) is a single PCI Express transaction that targets a location in Memory Space, reads the

location’s value, potentially writes a new value back to the location, and returns the original value. This “read-modify-write” sequence to the location is performed atomically. AtomicOps include the following:

• FetchAdd (Fetch and Add): Request contains a single operand, the “add” value 。 Read the value of the target location.

。 Add the “add” value to it using two’s complement arithmetic ignoring any carry or overflow. 。 Write the sum back to the target location.

。 Return the original value of the target location.

• Swap (Unconditional Swap): Request contains a single operand, the “swap” value