Misplaced Pages

PCI Express: Difference between revisions

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 12:42, 10 March 2022 edit124.170.232.166 (talk)No edit summary← Previous edit Latest revision as of 13:51, 12 January 2025 edit undo109.120.30.3 (talk) e to ETags: Mobile edit Mobile web edit 
(254 intermediate revisions by more than 100 users not shown)
Line 1: Line 1:
{{short description|Computer expansion bus standard}} {{short description|Computer expansion bus standard}}
{{use dmy dates |date=October 2020}}
{{Distinguish|PCI-X|UCIe}} {{Distinguish|PCI-X|UCIe}}
{{For|Engineering, Procurement, Construction and Installation|EPCI}} {{For|Engineering, Procurement, Construction and Installation|EPCI}}
{{use dmy dates |date=October 2020}}
{{Infobox computer hardware bus {{Infobox computer hardware bus
| name = PCI Express | name = PCI Express
| fullname = Peripheral Component Interconnect Express | fullname = Peripheral Component Interconnect Express
| image = PCI Express.svg | image = PCI Express.svg
| image_size = | image_size =
| alt = PCI Express logo | alt = Logo
| caption = PCI Express logo | caption = Logo
| invent-date = {{Start date and age|2003}} | invent-date = {{Start date and age|2003}}
| invent-name = {{Hlist|]|]|]|]}} | invent-name = {{Hlist
| ]
| ]
| ]
| ]
| super-name =
| super-date =
| replaces = {{Hlist|]|]|]}}
| width = 1 per lane {{Small|(up to 16 lanes)}}
| numdev = 1 on each endpoint of each connection.{{Efn|Switches can create multiple endpoints out of one to allow sharing it with multiple devices.}}
| speed = ] {{Small|(in each direction)}}; examples in single-lane (×1) and 16-lane (×16):
{{Unbulleted list
| '''Version 1.x:''' {{Nowrap|2.5 ]}}
: {{Unbulleted list
| '''×1:''' {{Nowrap|250 ]}}
| '''×16:''' {{Nowrap|4 GB/s}}
}} }}
| super-name =
| '''Version 2.x:''' {{Nowrap|5 GT/s}}
| super-date =
: {{Unbulleted list
| replaces = {{Hlist
| '''×1:''' {{Nowrap|500 MB/s}}
| ]
| '''×16:''' {{Nowrap|8 GB/s}}
| ]
| ]
}} }}
| width = 1 per lane<ref>{{cite book | url=https://books.google.com/books?id=ZjyrAgAAQBAJ&dq=pcie+dual+simplex&pg=PA69 | isbn=978-0-7384-5121-3 | title=IBM Power 770 and 780 Technical Overview and Introduction | date=6 June 2013 | publisher=IBM Redbooks }}</ref> {{Small|(up to 16 lanes)}}
| '''Version 3.x:''' {{Nowrap|8 GT/s}}
| numdev = 1 on each endpoint of each connection.{{Efn|Switches can create multiple endpoints out of one to allow sharing it with multiple devices.}}
: {{Unbulleted list
| speed = ], up to 242&nbsp;GB/s
| '''×1:''' {{Nowrap|985 MB/s}}
| style = s
| '''×16:''' {{Nowrap|15.75 GB/s}}
| hotplug = Optional {{Small|(support with ], ], ] or ])}}
}}
| external = Optional {{Small|(support with ] or ])}}
| '''Version 4.0:''' {{Nowrap|16 GT/s}}
| website = {{URL|https://pcisig.com/}}
: {{Unbulleted list
| '''×1:''' {{Nowrap|1.97 GB/s}}
| '''×16:''' {{Nowrap|31.5 GB/s}}
}}
| '''Version 5.0:''' {{Nowrap|32 GT/s}}
: {{Unbulleted list
| '''×1:''' {{Nowrap|3.94 GB/s}}
| '''×16:''' {{Nowrap|63 GB/s}}
}}
| '''Version 6.0:''' {{Nowrap|64 GT/s}}
: {{Unbulleted list
| '''×1:''' {{Nowrap|7.56 GB/s}}
| '''×16:''' {{Nowrap|121 GB/s}}
}}
}}
| style = s
| hotplug = Yes {{Small|(with ], ], ] or ])}}
| external = Yes {{Small|(with ] or ])}}
| website = {{URL|https://pcisig.com/}}
}} }}


], from top to bottom: {{unordered list ]
], from top to bottom: {{unordered list
| PCI Express ×4
| PCI Express ×16 | PCI Express x4
| PCI Express ×1 | PCI Express x16
| PCI Express ×16 | PCI Express x1
| PCI Express x16
| ] (32-bit, 5&nbsp;V) | ] (32-bit, 5&nbsp;V)
}}]] }}]]


'''PCI Express''' ('''Peripheral Component Interconnect Express'''), officially abbreviated as '''PCIe''' or '''PCI-e''',<ref name="s5NDG" /> is a high-speed ] ] ] standard, designed to replace the older ], ] and ] bus standards. It is the common ] interface for personal computers' ], ] ]s, ], ] and ] hardware connections.<ref name="DQmzv" /> PCIe has numerous improvements over the older standards, including higher maximum system bus throughput, lower I/O pin count and smaller physical footprint, better performance scaling for bus devices, a more detailed error detection and reporting mechanism (Advanced Error Reporting, AER),<ref name="gf9Lm" /> and native ] functionality. More recent revisions of the PCIe standard provide hardware support for ]. '''PCI Express''' ('''Peripheral Component Interconnect Express'''), officially abbreviated as '''PCIe''' or '''PCI-E''',<ref name="s5NDG" /> is a high-speed ] ] ] standard, meant to replace the older ], ] and ] bus standards. It is the common ] interface for personal computers' ], ], ]s, ] ]s, ], ], and ] hardware connections.<ref name="DQmzv" /> PCIe has numerous improvements over the older standards, including higher maximum system bus throughput, lower I/O pin count, smaller physical footprint, better performance scaling for bus devices, a more detailed error detection and reporting mechanism (Advanced Error Reporting, AER),<ref name="gf9Lm" /> and native ] functionality. More recent revisions of the PCIe standard provide hardware support for ].


Defined by its number of lanes,<ref name="sxOen" /> (the number of simultaneous sending and receiving lines of data as in a highway which features traffic in both directions) the PCI Express electrical interface is also used in a variety of other standards, most notably the ] expansion card interface ] and computer storage interfaces ], ] (SFF-8639) and ]. The PCI Express electrical interface is measured by the number of simultaneous lanes.<ref name="sxOen"/> (A lane is a single send/receive line of data, analogous to a "one-lane road" having one lane of traffic in both directions.) The interface is also used in a variety of other standards most notably the ] expansion card interface called ]. It is also used in the storage interfaces of ], ] (SFF-8639) and ].


Format specifications are maintained and developed by the ] (PCI ]), a group of more than 900 companies that also maintain the ] specifications. Formal specifications are maintained and developed by the ] (PCI ]) a group of more than 900 companies that also maintains the ] specifications.


== {{Anchor|SWITCH}}Architecture == == {{Anchor|SWITCH}}Architecture ==
] ]
]), which creates multiple endpoints out of one endpoint and lets multiple devices share it]] ]), which creates multiple endpoints out of one endpoint and lets multiple devices share it]]


] ]


Conceptually, the PCI Express bus is a high-speed ] replacement of the older PCI/PCI-X bus.<ref name="howstuffworks1" /> One of the key differences between the PCI Express bus and the older PCI is the bus topology; PCI uses a shared ] ] architecture, in which the PCI host and all devices share a common set of address, data and control lines. In contrast, PCI Express is based on point-to-point ], with separate ] links connecting every device to the ] (host). Because of its shared bus topology, access to the older PCI bus is arbitrated (in the case of multiple masters), and limited to one master at a time, in a single direction. Furthermore, the older PCI clocking scheme limits the bus clock to the slowest peripheral on the bus (regardless of the devices involved in the bus transaction). In contrast, a PCI Express bus link supports ] communication between any two endpoints, with no inherent limitation on concurrent access across multiple endpoints. Conceptually, the PCI Express bus is a high-speed ] replacement of the older PCI/PCI-X bus.<ref name="howstuffworks1" /> One of the key differences between the PCI Express bus and the older PCI is the bus topology; PCI uses a shared ] ] architecture, in which the PCI host and all devices share a common set of address, data, and control lines. In contrast, PCI Express is based on point-to-point ], with separate ] links connecting every device to the ] (host). Because of its shared bus topology, access to the older PCI bus is arbitrated (in the case of multiple masters), and limited to one master at a time, in a single direction. Furthermore, the older PCI clocking scheme limits the bus clock to the slowest peripheral on the bus (regardless of the devices involved in the bus transaction). In contrast, a PCI Express bus link supports ] communication between any two endpoints, with no inherent limitation on concurrent access across multiple endpoints.


In terms of bus protocol, PCI Express communication is encapsulated in packets. The work of packetizing and de-packetizing data and status-message traffic is handled by the transaction layer of the PCI Express port (described later). Radical differences in electrical signaling and bus protocol require the use of a different mechanical form factor and expansion connectors (and thus, new motherboards and new adapter boards); PCI slots and PCI Express slots are not interchangeable. At the software level, PCI Express preserves ] with PCI; legacy PCI system software can detect and configure newer PCI Express devices without explicit support for the PCI Express standard, though new PCI Express features are inaccessible. In terms of bus protocol, PCI Express communication is encapsulated in packets. The work of packetizing and de-packetizing data and status-message traffic is handled by the transaction layer of the PCI Express port (described later). Radical differences in electrical signaling and bus protocol require the use of a different mechanical form factor and expansion connectors (and thus, new motherboards and new adapter boards); PCI slots and PCI Express slots are not interchangeable. At the software level, PCI Express preserves ] with PCI; legacy PCI system software can detect and configure newer PCI Express devices without explicit support for the PCI Express standard, though new PCI Express features are inaccessible.


The PCI Express link between two devices can vary in size from one to 16 ]s. In a multi-lane link, the packet data is striped across lanes, and peak data throughput scales with the overall link width. The lane count is automatically negotiated during device initialization, and can be restricted by either endpoint. For example, a single-lane PCI Express (×1) card can be inserted into a multi-lane slot (×4, ×8, etc.), and the initialization cycle auto-negotiates the highest mutually supported lane count. The link can dynamically down-configure itself to use fewer lanes, providing a failure tolerance in case bad or unreliable lanes are present. The PCI Express standard defines link widths of ×1, ×2, ×4, ×8 and ×16. Up to and including PCIe 5.0, ×12 and ×32 links were defined as well but never used.<ref name="4TrCr" /> This allows the PCI Express bus to serve both cost-sensitive applications where high throughput is not needed, and performance-critical applications such as 3D graphics, networking (] or multiport ]), and enterprise storage (] or ]). Slots and connectors are only defined for a subset of these widths, with link widths in between using the next larger physical slot size. The PCI Express link between two devices can vary in size from one to 16 ]s. In a multi-lane link, the packet data is striped across lanes, and peak data throughput scales with the overall link width. The lane count is automatically negotiated during device initialization and can be restricted by either endpoint. For example, a single-lane PCI Express (x1) card can be inserted into a multi-lane slot (x4, x8, etc.), and the initialization cycle auto-negotiates the highest mutually supported lane count. The link can dynamically down-configure itself to use fewer lanes, providing a failure tolerance in case bad or unreliable lanes are present. The PCI Express standard defines link widths of x1, x2, x4, x8, and x16. Up to and including PCIe 5.0, x12, and x32 links were defined as well but never used.<ref name="4TrCr" /> This allows the PCI Express bus to serve both cost-sensitive applications where high throughput is not needed, and performance-critical applications such as 3D graphics, networking (] or multiport ]), and enterprise storage (] or ]). Slots and connectors are only defined for a subset of these widths, with link widths in between using the next larger physical slot size.


As a point of reference, a PCI-X (133&nbsp;MHz 64-bit) device and a PCI Express&nbsp;1.0 device using four lanes (×4) have roughly the same peak single-direction transfer rate of 1064&nbsp;MB/s. The PCI Express bus has the potential to perform better than the PCI-X bus in cases where multiple devices are transferring data simultaneously, or if communication with the PCI Express peripheral is ]. As a point of reference, a PCI-X (133&nbsp;MHz 64-bit) device and a PCI Express&nbsp;1.0 device using four lanes (x4) have roughly the same peak single-direction transfer rate of 1064&nbsp;MB/s. The PCI Express bus has the potential to perform better than the PCI-X bus in cases where multiple devices are transferring data simultaneously, or if communication with the PCI Express peripheral is ].


=== {{Anchor|LINK}}Interconnect === === {{Anchor|LINK}}Interconnect ===
] channels using two ] pairs.<ref name="pcie-basics" />{{rp|3}}]] ] channels using two ] pairs.<ref name="pcie-basics" />{{rp|3}}]]


PCI Express devices communicate via a logical connection called an ''interconnect''<ref name="faq1" /> or ''link''. A link is a point-to-point communication channel between two PCI Express ports allowing both of them to send and receive ordinary PCI requests (configuration, I/O or memory read/write) and ]s (], ]). At the physical level, a link is composed of one or more ''lanes''.<ref name="faq1" /> Low-speed peripherals (such as an ] ] ]) use a single-lane (×1) link, while a graphics adapter typically uses a much wider and therefore faster 16-lane (×16) link. PCI Express devices communicate via a logical connection called an ''interconnect''<ref name="faq1" /> or ''link''. A link is a point-to-point communication channel between two PCI Express ports allowing both of them to send and receive ordinary PCI requests (configuration, I/O or memory read/write) and ]s (], ]). At the physical level, a link is composed of one or more ''lanes''.<ref name="faq1" /> Low-speed peripherals (such as an ] ] ]) use a single-lane (x1) link, while a graphics adapter typically uses a much wider and therefore faster 16-lane (x16) link.


=== {{Anchor|LANE}}Lane === === {{Anchor|LANE}}Lane ===
A lane is composed of two ] pairs, with one pair for receiving data and the other for transmitting. Thus, each lane is composed of four wires or ]. Conceptually, each lane is used as a ] ], transporting data packets in eight-bit "byte" format simultaneously in both directions between endpoints of a link.<ref name="2Nt8T" /> Physical PCI Express links may contain 1, 4, 8 or 16 lanes.<ref name="Gchhw" /><ref name="pcie-basics" />{{rp|4,5}}<ref name="faq1" /> Lane counts are written with an "×" prefix (for example, "×8" represents an eight-lane card or slot), with ×16 being the largest size in common use.<ref name="odC7t" /> Lane sizes are also referred to via the terms "width" or "by" e.g., an eight-lane slot could be referred to as a "by 8" or as "8 lanes wide." A lane is composed of two ] pairs, with one pair for receiving data and the other for transmitting. Thus, each lane is composed of four wires or ]s. Conceptually, each lane is used as a ] ], transporting data packets in eight-bit "byte" format simultaneously in both directions between endpoints of a link.<ref name="2Nt8T" /> Physical PCI Express links may contain 1, 4, 8 or 16 lanes.<ref name="Gchhw" /><ref name="pcie-basics" />{{rp|4,5}}<ref name="faq1" /> Lane counts are written with an "x" prefix (for example, "x8" represents an eight-lane card or slot), with x16 being the largest size in common use.<ref name="odC7t" /> Lane sizes are also referred to via the terms "width" or "by" e.g., an eight-lane slot could be referred to as a "by 8" or as "8 lanes wide."


For mechanical card sizes, see ]. For mechanical card sizes, see ].
Line 96: Line 74:
=== Serial bus === === Serial bus ===
{{unreferenced section|date=March 2018}} {{unreferenced section|date=March 2018}}
The bonded serial ] architecture was chosen over the traditional parallel bus because of inherent limitations of the latter, including ] operation, excess signal count, and inherently lower ] due to ]. Timing skew results from separate electrical signals within a parallel interface traveling through conductors of different lengths, on potentially different ] (PCB) layers, and at possibly different ]. Despite being transmitted simultaneously as a single ], signals on a parallel interface have different travel duration and arrive at their destinations at different times. When the interface clock period is shorter than the largest time difference between signal arrivals, recovery of the transmitted word is no longer possible. Since timing skew over a parallel bus can amount to a few nanoseconds, the resulting bandwidth limitation is in the range of hundreds of megahertz. The bonded serial ] architecture was chosen over the traditional parallel bus because of the inherent limitations of the latter, including ] operation, excess signal count, and inherently lower ] due to ]. Timing skew results from separate electrical signals within a parallel interface traveling through conductors of different lengths, on potentially different ] (PCB) layers, and at possibly different ]. Despite being transmitted simultaneously as a single ], signals on a parallel interface have different travel duration and arrive at their destinations at different times. When the interface clock period is shorter than the largest time difference between signal arrivals, recovery of the transmitted word is no longer possible. Since timing skew over a parallel bus can amount to a few nanoseconds, the resulting bandwidth limitation is in the range of hundreds of megahertz.


] ]


A serial interface does not exhibit timing skew because there is only one differential signal in each direction within each lane, and there is no external clock signal since clocking information is embedded within the serial signal itself. As such, typical bandwidth limitations on serial signals are in the multi-gigahertz range. PCI Express is one example of the general trend toward replacing parallel buses with serial interconnects; other examples include ] (SATA), ], ] (SAS), ] (IEEE 1394), and ]. In digital video, examples in common use are ], ] and ]. A serial interface does not exhibit timing skew because there is only one differential signal in each direction within each lane, and there is no external clock signal since clocking information is ] within the serial signal itself. As such, typical bandwidth limitations on serial signals are in the multi-gigahertz range. PCI Express is one example of the general trend toward replacing parallel buses with serial interconnects; other examples include ] (SATA), ], ] (SAS), ] (IEEE 1394), and ]. In digital video, examples in common use are ], ], and ].


Multichannel serial design increases flexibility with its ability to allocate fewer lanes for slower devices. Multichannel serial design increases flexibility with its ability to allocate fewer lanes for slower devices.
Line 107: Line 85:


=== {{Anchor|HHHL|FHHL}}PCI Express (standard) === === {{Anchor|HHHL|FHHL}}PCI Express (standard) ===
]A PCI Express card fits into a slot of its physical size or larger (with ×16 as the largest used), but may not fit into a smaller PCI Express slot; for example, a ×16 card may not fit into a ×4 or ×8 slot. Some slots use open-ended sockets to permit physically longer cards and negotiate the best available electrical and logical connection. ]A PCI Express card fits into a slot of its physical size or larger (with x16 as the largest used), but may not fit into a smaller PCI Express slot; for example, a x16 card may not fit into a x4 or x8 slot. Some slots use open-ended sockets to permit physically longer cards and negotiate the best available electrical and logical connection.


The number of lanes actually connected to a slot may also be fewer than the number supported by the physical slot size. An example is a ×16 slot that runs at ×4, which accepts any ×1, ×2, ×4, ×8 or ×16 card, but provides only four lanes. Its specification may read as "×16 (×4 mode)", while "×mechanical @ ×electrical" notation ("×16&nbsp;@&nbsp;×4") is also common. The advantage is that such slots can accommodate a larger range of PCI Express cards without requiring motherboard hardware to support the full transfer rate. Standard mechanical sizes are ×1, ×4, ×8, and ×16. Cards with a differing number of lanes need to use the next larger mechanical size (i.e. a ×2 card uses the ×4 size, or a ×12 card uses the ×16 size). The number of lanes actually connected to a slot may also be fewer than the number supported by the physical slot size. An example is a x16 slot that runs at x4, which accepts any x1, x2, x4, x8 or x16 card, but provides only four lanes. Its specification may read as "x16 (x4 mode)", while "mechanical @ electrical" notation (e.g. "x16&nbsp;@&nbsp;x4") is also common.{{Citation needed|date=July 2022}} The advantage is that such slots can accommodate a larger range of PCI Express cards without requiring motherboard hardware to support the full transfer rate. Standard mechanical sizes are x1, x4, x8, and x16. Cards using a number of lanes other than the standard mechanical sizes need to physically fit the next larger mechanical size (e.g. an x2 card uses the x4 size, or an x12 card uses the x16 size).


The cards themselves are designed and manufactured in various sizes. For example, ]s (SSDs) that come in the form of PCI Express cards often use ] (half height, half length) and ] (full height, half length) to describe the physical dimensions of the card.<ref name="8AKZj" /><ref name="c1yve" /> The cards themselves are designed and manufactured in various sizes. For example, ]s (SSDs) that come in the form of PCI Express cards often use ] (half height, half length) and ] (full height, half length) to describe the physical dimensions of the card.<ref name="8AKZj" /><ref name="c1yve" />
Line 115: Line 93:
{| class="wikitable" {| class="wikitable"
|- |-
! rowspan=2" | PCI card type ! rowspan=2" | PCI card type
! colspan="2" | Dimensions height × length × width, maximum ! colspan="2" | Dimensions height × length × width, maximum
|- |-
Line 122: Line 100:
|- |-
| Full-Length | Full-Length
| 111.15 × 312.00 x 20.32 | 111.15 × 312.00 × 20.32
| 4.376 × 12.283 x 0.8 | 4.376 × 12.283 × 0.8
|- |-
| Half-Length | Half-Length
| 111.15 × 167.65 x 20.32 | 111.15 × 167.65 × 20.32
| 4.376 × {{0}}6.600 x 0.8 | 4.376 × {{0}}6.600 × 0.8
|- |-
| Low-Profile/Slim | Low-Profile/Slim
| {{0}}68.90 × 167.65 x 20.32 | {{0}}68.90 × 167.65 × 20.32
| 2.731 × {{0}}6.600 x 0.8 | 2.731 × {{0}}6.600 × 0.8
|} |}


==== Non-standard video card form factors ==== ==== Non-standard video card form factors ====
Modern (since c.2012<ref name="j6TTS" />) gaming ]s usually exceed the height as well as thickness specified in the PCI Express standard, due to the need for more capable and quieter ], as gaming video cards often emit hundreds of watts of heat.<ref name="RAreG" /> Modern computer cases are often wider to accommodate these taller cards, but not always. Since full-length cards (312&nbsp;mm) are uncommon, modern cases sometimes cannot fit those. The thickness of these cards also typically occupies the space of 2 PCIe slots. In fact, even the methodology of how to measure the cards varies between vendors, with some including the metal bracket size in dimensions and others not. Modern (since {{circa|2012}}<ref name="j6TTS" />) gaming ]s usually exceed the height as well as thickness specified in the PCI Express standard, due to the need for more capable and quieter ], as gaming video cards often emit hundreds of watts of heat.<ref name="RAreG" /> Modern computer cases are often wider to accommodate these taller cards, but not always. Since full-length cards (312&nbsp;mm) are uncommon, modern cases sometimes cannot fit those. The thickness of these cards also typically occupies the space of 2 to 5<ref>{{Cite web |last=Discuss |first=btarunr |date=2023-01-06 |title=ASUS x Noctua RTX 4080 Graphics Card is 5 Slots Thick, We Go Hands-on |url=https://www.techpowerup.com/303148/asus-x-noctua-rtx-4080-graphics-card-is-5-slots-thick-we-go-hands-on |access-date=2024-09-19 |website=TechPowerUp |language=en}}</ref> PCIe slots. In fact, even the methodology of how to measure the cards varies between vendors, with some including the metal bracket size in dimensions and others not.


For instance, a 2020 ] card measures 135&nbsp;mm in height (excluding the metal bracket), which exceeds the PCIe standard height by 28&nbsp;mm.<ref name="E0Tsg" /> Another card by ] measures 55&nbsp;mm thick (i.e. 2.7 PCI slots at 20.32 mm), taking up 3 PCIe slots.<ref name="mAt96" /> The Asus GeForce RTX 3080 10 GB STRIX GAMING OC video card is a two slot card that has dimensions of 318.5{{nbsp}}mm × 140.1{{nbsp}}mm × 57.8{{nbsp}}mm, exceeding PCI Express' maximum length, height and thickness respectively.<ref name="kk3xz" /> For instance, comparing three high-end video cards released in 2020: a ] ] card measures 135&nbsp;mm in height (excluding the metal bracket), which exceeds the PCIe standard height by 28&nbsp;mm,<ref name="E0Tsg" /> another Radeon RX 5700 XT card by ] measures 55&nbsp;mm thick (i.e. 2.7 PCI slots at 20.32&nbsp;mm), taking up 3 PCIe slots,<ref name="mAt96" /> while an ] ] video card takes up two slots and measures 140.1{{nbsp}}mm × 318.5{{nbsp}}mm × 57.8{{nbsp}}mm, exceeding PCI Express's maximum height, length, and thickness respectively.<ref name="kk3xz" />


==== Pinout ==== ==== Pinout ====
The following table identifies the conductors on each side of the ] on a PCI Express card. The solder side of the ] (PCB) is the A side, and the component side is the B side.<ref name="IM1RH" /> PRSNT1# and PRSNT2# pins must be slightly shorter than the rest, to ensure that a hot-plugged card is fully inserted. The WAKE# pin uses full voltage to wake the computer, but must be ] from the standby power to indicate that the card is wake capable.<ref name="PCIe card 2" /> The following table identifies the conductors on each side of the ] on a PCI Express card. The solder side of the ] (PCB) is the A-side, and the component side is the B-side.<ref name="IM1RH" /> PRSNT1# and PRSNT2# pins must be slightly shorter than the rest, to ensure that a hot-plugged card is fully inserted. The WAKE# pin uses full voltage to wake the computer, but must be ] from the standby power to indicate that the card is wake capable.<ref name="PCIe card 2" />
{{-}}


{| class="wikitable" {| class="wikitable"
|+ PCI Express connector pinout (×1, ×4, ×8 and ×16 variants) |+ PCI Express connector pinout (x1, x4, x8 and x16 variants)
! Pin !! Side B !! Side A !! Description ! Pin !! Side B !! Side A !! Description
| rowspan=54 | | rowspan=54 |
Line 195: Line 172:
|- |-
! 10 ! 10
|style="background:silver"|+3.3&nbsp;V aux ||style="background:silver"| +3.3&nbsp;V ||align="left"| ] |style="background:silver"|+3.3&nbsp;V aux ||style="background:silver"| +3.3&nbsp;V ||align="left"| Aux power & ]
! 59 ! 59
|style="background:#99f"| HSOn(10) ||style="background:#999"| Ground |style="background:#99f"| HSOn(10) ||style="background:#999"| Ground
Line 209: Line 186:
|- |-
! 12 ! 12
|style="background:#fc6"| CLKREQ#<ref name="vj2hg" /> ||style="background:#999"| Ground ||align="left"| Clock Request Signal |style="background:#f9f"| CLKREQ#<ref name="vj2hg" /> ||style="background:#999"| Ground ||align="left"| Clock Request Signal
! 62 ! 62
|style="background:#99f"| HSOp(11) ||style="background:#999"| Ground || rowspan="2" style="text-align:left;"| Lane 11 transmit data, + and − |style="background:#99f"| HSOp(11) ||style="background:#999"| Ground || rowspan="2" style="text-align:left;"| Lane 11 transmit data, + and −
Line 243: Line 220:
|style="background:#999"| Ground ||style="background:#f9f"| HSIp(12) || rowspan="2" style="text-align:left;"| Lane 12 receive data, + and − |style="background:#999"| Ground ||style="background:#f9f"| HSIp(12) || rowspan="2" style="text-align:left;"| Lane 12 receive data, + and −
|- |-
|colspan=4| PCI Express ×1 cards end at pin 18 |colspan=4| PCI Express x1 cards end at pin 18
! 69 ! 69
|style="background:#999"| Ground ||style="background:#f9f"| HSIn(12) |style="background:#999"| Ground ||style="background:#f9f"| HSIn(12)
Line 298: Line 275:
|- |-
! 29 ! 29
|style="background:#999"| Ground ||style="background:#f9f"| HSIp(3) || rowspan="2" style="text-align:left;"| Lane 3 receive data, + and − |style="background:#999"| Ground ||style="background:#f9f"| HSIp(3) || rowspan="2" style="text-align:left;"| Lane 3 receive data, + and −<br />"Power brake", active-low to reduce device power
! 80 ! 80
|style="background:#999"| Ground ||style="background:#f9f"| HSIp(15) || rowspan="2" style="text-align:left;"| Lane 15 receive data, + and − |style="background:#999"| Ground ||style="background:#f9f"| HSIp(15) || rowspan="2" style="text-align:left;"| Lane 15 receive data, + and −
Line 315: Line 292:
|style="background:#999"| Ground ||style="background:#ff9"| Reserved |style="background:#999"| Ground ||style="background:#ff9"| Reserved
|- |-
|colspan=4| PCI Express ×4 cards end at pin 32 |colspan=4| PCI Express x4 cards end at pin 32
|- |-
! 33 ! 33
Line 381: Line 358:
| colspan="2" style="text-align:left;"| Tied together on card | colspan="2" style="text-align:left;"| Tied together on card
|- |-
|colspan=4| PCI Express ×8 cards end at pin 49 |colspan=4| PCI Express x8 cards end at pin 49
!style="background:#ff9" colspan=2| Reserved !style="background:#ff9" colspan=2| Reserved
| colspan="2" style="text-align:left;"| Not presently used, do not connect | colspan="2" style="text-align:left;"| Not presently used, do not connect
Line 387: Line 364:


==== Power ==== ==== Power ====
]
] used on PCI Express cards]]


===== Slot power =====
<!-- <!--
Please DO NOT add the claim that the PCI express 2.x standard adds support for up to 150&nbsp;W from the slot itself without a very good reference. While several references make the claim, particularly around the time of release, other references particularly those relying on the spec. dispute this. See the talk page discussion dated November 2012 for details. Please DO NOT add the claim that the PCI express 2.x standard adds support for up to 150&nbsp;W from the slot itself without a very good reference. While several references make the claim, particularly around the time of release, other references particularly those relying on the spec. dispute this. See the talk page discussion dated November 2012 for details.
--> -->
All PCI express cards may consume up to {{val|3|ul=A}} at {{val|+3.3|ul=V}} ({{val|9.9|ul=W}}). The amount of +12&nbsp;V and total power they may consume depends on the type of card:<ref name="CEM1.1" />{{rp|35–36}}<ref name="jArAO" /> All PCI express cards may consume up to {{val|3|ul=A}} at {{val|+3.3|ul=V}} ({{val|9.9|ul=W}}). The amount of +12&nbsp;V and total power they may consume depends on the form factor and the role of the card:<ref name="CEM1.1" />{{rp|35–36}}<ref name="jArAO" /><ref>''PCI Express Base Specification, Revision 1.1'' Page 332</ref>
* ×1 cards are limited to 0.5&nbsp;A at +12{{nbsp}}V (6&nbsp;W) and 10&nbsp;W combined. * x1 cards are limited to 0.5&nbsp;A at +12{{nbsp}}V (6&nbsp;W) and 10&nbsp;W combined.
* ×4 and wider cards are limited to 2.1&nbsp;A at +12{{nbsp}}V (25&nbsp;W) and 25&nbsp;W combined. * x4 and wider cards are limited to 2.1&nbsp;A at +12{{nbsp}}V (25&nbsp;W) and 25&nbsp;W combined.
* A full-sized ×1 card may draw up to the 25&nbsp;W limits after initialization and software configuration as a "high power device". * A full-sized x1 card may draw up to the 25&nbsp;W limits after initialization and software configuration as a high-power device.
* A full-sized ×16 graphics card<ref name="PCIe card 2" /> may draw up to 5.5&nbsp;A at +12{{nbsp}}V (66&nbsp;W) and 75&nbsp;W combined after initialization and software configuration as a "high power device". * A full-sized x16 graphics card may draw up to 5.5&nbsp;A at +12{{nbsp}}V (66&nbsp;W) and 75&nbsp;W combined after initialization and software configuration as a high-power device.<ref name="PCIe card 2" />{{rp|38–39}}


===== 6- and 8-pin power connectors =====
Optional connectors add 75&nbsp;W (6-pin) or 150&nbsp;W (8-pin) of +12&nbsp;V power for up to 300&nbsp;W total ({{nowrap|2 × 75&nbsp;W + 1 × 150&nbsp;W}}).
] used on PCI Express cards]]

Optional connectors add {{val|75|ul=W}} (6-pin) or {{val|150|ul=W}} (8-pin) of +12&nbsp;V power for up to {{val|300|ul=W}} total ({{nowrap|2 × 75&nbsp;W + 1 × 150&nbsp;W}}).
* Sense0 pin is connected to ground by the cable or power supply, or float on board if cable is not connected. * Sense0 pin is connected to ground by the cable or power supply, or float on board if cable is not connected.
* Sense1 pin is connected to ground by the cable or power supply, or float on board if cable is not connected. * Sense1 pin is connected to ground by the cable or power supply, or float on board if cable is not connected.


Some cards use two 8-pin connectors, but this has not been standardized yet {{as of|lc=y|2018}}, therefore such cards must not carry the official PCI Express logo. This configuration allows 375&nbsp;W total ({{nowrap|1 × 75&nbsp;W + 2 × 150&nbsp;W}}) and will likely be standardized by PCI-SIG with the PCI Express 4.0 standard{{Update inline|reason=PCI Express is at 5.0 already…|date=May 2021}}. The 8-pin PCI Express connector could be confused with the ] connector, which is mainly used for powering SMP and multi-core systems. The power connectors are variants of the Molex Mini-Fit Jr. series connectors. <ref name="JuErgh" /> Some cards use two 8-pin connectors, but this has not been standardized yet {{as of|lc=y|2018}}, therefore such cards must not carry the official PCI Express logo. This configuration allows 375&nbsp;W total ({{nowrap|1 × 75&nbsp;W + 2 × 150&nbsp;W}}) and will likely be standardized by PCI-SIG with the PCI Express 4.0 standard.{{Update inline|reason=PCI Express is at 5.0 already…|date=May 2021}} The 8-pin PCI Express connector could be confused with the ] connector, which is mainly used for powering SMP and multi-core systems. The power connectors are variants of the Molex Mini-Fit Jr. series connectors.<ref name="JuErgh" />
{| class="wikitable" {| class="wikitable"
|+ Molex Mini-Fit Jr. part numbers<ref name="JuErgh" /> |+ Molex Mini-Fit Jr. part numbers<ref name="JuErgh" />
Line 418: Line 399:
|} |}
{| class="wikitable" {| class="wikitable"
! colspan=2 | '''6-pin power connector (75&nbsp;W)'''<ref name="o2GFI" /> ! colspan=2 | 6-pin power connector (75&nbsp;W)<ref name="o2GFI" />
| rowspan=10| | rowspan=10|
! colspan=2 | '''8-pin power connector (150&nbsp;W)'''<ref name="uLc7Q" /><ref name="CEM3.0" /><ref name="mcd6L" /> ! colspan=2 | 8-pin power connector (150&nbsp;W)<ref name="uLc7Q" /><ref name="CEM3.0" /><ref name="mcd6L" />
| rowspan=10|] | rowspan=10|]
] ]
Line 452: Line 433:
|} |}
{{notelist-ua}} {{notelist-ua}}

===== 12VHPWR connector =====
{{Excerpt|16-Pin 12vHPWR connector|templates=-Advert}}


=== {{Anchor|MINI-CARD}}PCI Express Mini Card === === {{Anchor|MINI-CARD}}PCI Express Mini Card ===
Line 458: Line 442:
] ]


'''PCI Express Mini Card''' (also known as '''Mini PCI Express''', '''Mini PCIe''', '''Mini PCI-E''', '''mPCIe''', and '''PEM'''), based on PCI Express, is a replacement for the ] form factor. It is developed by the ]. The host device supports both PCI Express and ]&nbsp;2.0 connectivity, and each card may use either standard. Most laptop computers built after 2005 use PCI Express for expansion cards; however, {{as of|2015|lc=yes}}, many vendors are moving toward using the newer ] form factor for this purpose. '''PCI Express Mini Card''' (also known as '''Mini PCI Express''', '''Mini PCIe''', '''Mini PCI-E''', '''mPCIe''', and '''PEM'''), based on PCI Express, is a replacement for the ] form factor. It is developed by the ]. The host device supports both PCI Express and ]&nbsp;2.0 connectivity, and each card may use either standard. Most laptop computers built after 2005 use PCI Express for expansion cards; however, {{as of|2015|lc=yes}}, many vendors are moving toward using the newer ] form factor for this purpose.<ref>{{cite web | url=https://arstechnica.com/gadgets/2015/02/understanding-m-2-the-interface-that-will-speed-up-your-next-ssd/ | title=Understanding M.2, the interface that will speed up your next SSD | date=8 February 2015 }}</ref>


Due to different dimensions, PCI Express Mini Cards are not physically compatible with standard full-size PCI Express slots; however, passive adapters exist that let them be used in full-size slots.<ref name="DmwJz" /> Due to different dimensions, PCI Express Mini Cards are not physically compatible with standard full-size PCI Express slots; however, passive adapters exist that let them be used in full-size slots.<ref name="DmwJz" />


==== Physical dimensions ==== ==== Physical dimensions ====
Dimensions of PCI Express Mini Cards are 30&nbsp;mm × 50.95&nbsp;mm (width&nbsp;× length) for a Full Mini Card. There is a 52-pin ], consisting of two staggered rows on a 0.8&nbsp;mm pitch. Each row has eight contacts, a gap equivalent to four contacts, then a further 18 contacts. ] have a thickness of 1.0&nbsp;mm, excluding the components. A "Half Mini Card" (sometimes abbreviated as HMC) is also specified, having approximately half the physical length of 26.8&nbsp;mm. Dimensions of PCI Express Mini Cards are 30&nbsp;mm × 50.95&nbsp;mm (width&nbsp;× length) for a Full Mini Card. There is a 52-pin ], consisting of two staggered rows on a 0.8&nbsp;mm pitch. Each row has eight contacts, a gap equivalent to four contacts, then a further 18 contacts. ] have a thickness of 1.0&nbsp;mm, excluding the components. A "Half Mini Card" (sometimes abbreviated as HMC) is also specified, having approximately half the physical length of 26.8&nbsp;mm. There are also half size mini PCIe cards that are 30 x 31.90 mm which is about half the length of a full size mini PCIe card.<ref>{{cite book | url=https://books.google.com/books?id=otfPEAAAQBAJ&dq=pci+express+micro&pg=PT628 | isbn=978-0-13-816625-0 | title=IT Essentials Companion Guide v8 | date=9 July 2023 | publisher=Cisco Press }}</ref><ref>{{cite book | url=https://google.com.pa/books/edition/Mobile_Computing_Deployment_and_Manageme/rP5gBgAAQBAJ?hl=en&gbpv=1&dq=mini+pcie+full+size+half+size&pg=PA491&printsec=frontcover | isbn=978-1-118-82461-0 | title=Mobile Computing Deployment and Management: Real World Skills for CompTIA Mobility+ Certification and Beyond | date=24 February 2015 | publisher=John Wiley & Sons }}</ref>


==== Electrical interface ==== ==== Electrical interface ====
PCI Express Mini Card edge connectors provide multiple connections and buses: PCI Express Mini Card edge connectors provide multiple connections and buses:
* PCI Express ×1 (with SMBus) * PCI Express x1 (with SMBus)
* USB&nbsp;2.0 * USB&nbsp;2.0
* Wires to diagnostics LEDs for wireless network (i.e., ]) status on computer's chassis * Wires to diagnostics LEDs for wireless network (i.e., ]) status on computer's chassis
Line 475: Line 459:


==== {{Anchor|MSATA}}Mini-SATA (mSATA) variant ==== ==== {{Anchor|MSATA}}Mini-SATA (mSATA) variant ====
] ]
Despite sharing the Mini PCI Express form factor, an ] slot is not necessarily electrically compatible with Mini PCI Express. For this reason, only certain notebooks are compatible with mSATA drives. Most compatible systems are based on Intel's Sandy Bridge processor architecture, using the Huron River platform. Notebooks such as Lenovo's ThinkPad T, W and X series, released in March–April 2011, have support for an mSATA SSD card in their ] card slot. The ThinkPad Edge E220s/E420s, and the Lenovo IdeaPad Y460/Y560/Y570/Y580 also support mSATA.<ref name="5xxpo" /> On the contrary, the L-series among others can only support M.2 cards using the PCIe standard in the WWAN slot. Despite sharing the Mini PCI Express form factor, an ] slot is not necessarily electrically compatible with Mini PCI Express. For this reason, only certain notebooks are compatible with mSATA drives. Most compatible systems are based on Intel's Sandy Bridge processor architecture, using the Huron River platform. Notebooks such as Lenovo's ThinkPad T, W and X series, released in March–April 2011, have support for an mSATA SSD card in their ] card slot. The ThinkPad Edge E220s/E420s, and the Lenovo IdeaPad Y460/Y560/Y570/Y580 also support mSATA.<ref name="5xxpo" /> On the contrary, the L-series among others can only support M.2 cards using the PCIe standard in the WWAN slot.


Some notebooks (notably the ], the ] ], and the Dell mini9 and mini10) use a variant of the PCI Express Mini Card as an ]. This variant uses the reserved and several non-reserved pins to implement SATA and IDE interface passthrough, keeping only USB, ground lines, and sometimes the core PCIe ×1 bus intact.<ref name="EeePC" /> This makes the "miniPCIe" flash and solid-state drives sold for netbooks largely incompatible with true PCI Express Mini implementations. Some notebooks (notably the ], the ] ], and the Dell mini9 and mini10) use a variant of the PCI Express Mini Card as an ]. This variant uses the reserved and several non-reserved pins to implement SATA and IDE interface passthrough, keeping only USB, ground lines, and sometimes the core PCIe x1 bus intact.<ref name="EeePC" /> This makes the "miniPCIe" flash and solid-state drives sold for netbooks largely incompatible with true PCI Express Mini implementations.


Also, the typical Asus miniPCIe SSD is 71&nbsp;mm long, causing the Dell 51&nbsp;mm model to often be (incorrectly) referred to as half length. A true 51&nbsp;mm Mini PCIe SSD was announced in 2009, with two stacked PCB layers that allow for higher storage capacity. The announced design preserves the PCIe interface, making it compatible with the standard mini PCIe slot. No working product has yet been developed. Also, the typical Asus miniPCIe SSD is 71&nbsp;mm long, causing the Dell 51&nbsp;mm model to often be (incorrectly) referred to as half length. A true 51&nbsp;mm Mini PCIe SSD was announced in 2009, with two stacked PCB layers that allow for higher storage capacity. The announced design preserves the PCIe interface, making it compatible with the standard mini PCIe slot. No working product has yet been developed.


Intel has numerous desktop boards with the PCIe ×1 Mini-Card slot that typically do not support mSATA SSD. A list of desktop boards that natively support mSATA in the PCIe ×1 Mini-Card slot (typically multiplexed with a SATA port) is provided on the Intel Support site.<ref name="xpI66" /> Intel has numerous desktop boards with the PCIe x1 Mini-Card slot that typically do not support mSATA SSD. A list of desktop boards that natively support mSATA in the PCIe x1 Mini-Card slot (typically multiplexed with a SATA port) is provided on the Intel Support site.<ref name="xpI66" />


=== PCI Express M.2 === === PCI Express M.2 ===
Line 488: Line 472:
M.2 replaces the mSATA standard and Mini PCIe.<ref name="oL68r" /> Computer bus interfaces provided through the M.2 connector are PCI Express 3.0 (up to four lanes), Serial ATA 3.0, and USB 3.0 (a single logical port for each of the latter two). It is up to the manufacturer of the M.2 host or device to choose which interfaces to support, depending on the desired level of host support and device type. M.2 replaces the mSATA standard and Mini PCIe.<ref name="oL68r" /> Computer bus interfaces provided through the M.2 connector are PCI Express 3.0 (up to four lanes), Serial ATA 3.0, and USB 3.0 (a single logical port for each of the latter two). It is up to the manufacturer of the M.2 host or device to choose which interfaces to support, depending on the desired level of host support and device type.


=== {{Anchor|EXTERNAL-CABLING|OCULINK}}PCI Express External Cabling === === {{Anchor|EXTERNAL-CABLING}}PCI Express External Cabling ===
''PCI Express External Cabling'' (also known as ''External PCI Express'', ''Cabled PCI Express'', or ''ePCIe'') specifications were released by the ] in February 2007.<ref name="pcie_cabling1.0" /><ref name="ZTXPi" /> ''PCI Express External Cabling'' (also known as ''External PCI Express'', ''Cabled PCI Express'', or ''ePCIe'') specifications were released by the ] in February 2007.<ref name="pcie_cabling1.0" /><ref name="ZTXPi" />


Standard cables and connectors have been defined for ×1, ×4, ×8, and ×16 link widths, with a transfer rate of 250&nbsp;MB/s per lane. The PCI-SIG also expects the norm to evolve to reach 500&nbsp;MB/s, as in PCI Express 2.0. An example of the uses of Cabled PCI Express is a metal enclosure, containing a number of PCIe slots and PCIe-to-ePCIe adapter circuitry. This device would not be possible had it not been for the ePCIe specification. Standard cables and connectors have been defined for x1, x4, x8, and x16 link widths, with a transfer rate of 250&nbsp;MB/s per lane. The PCI-SIG also expects the norm to evolve to reach 500&nbsp;MB/s, as in PCI Express 2.0. An example of the uses of Cabled PCI Express is a metal enclosure, containing a number of PCIe slots and PCIe-to-ePCIe adapter circuitry. This device would not be possible had it not been for the ePCIe specification.

===={{Anchor|OCULINK}}PCI Express OCuLink====
''OCuLink'' (standing for "optical-copper link", since ''Cu'' is the ] for ]) is an extension for the "cable version of PCI Express". Version 1.0 of OCuLink, released in Oct 2015, supports up to 4 PCIe 3.0 lanes (3.9&nbsp;GB/s) over copper cabling; a ] version may appear in the future.


The most recent version of OCuLink, OCuLink-2, supports up to 16&nbsp;GB/s (PCIe 4.0 x8)<ref name="OCuLink2" /> while the maximum bandwidth of a ] cable is 10GB/s.
====PCI Express OCuLink====
''OCuLink'' (standing for "optical-copper link", since ''Cu'' is the ] for ]) is an extension for the "cable version of PCI Express", acting as a competitor to version 3 of the Thunderbolt interface. Version 1.0 of OCuLink, released in Oct 2015, supports up to PCIe 3.0 ×4 lanes (8 ], 3.9 GB/s) over copper cabling; a ] version may appear in the future.


While initially intended for use in laptops for the connection of powerful external GPU boxes, OCuLink's popularity lies primarily in its use for PCIe interconnections in servers, a more prevalent application.<ref name="6MiK5" />
In its latest version OCuLink-2, it supports up to 16 GB/s (PCIe 4.0 ×8)<ref name="OCuLink2" /> while the maximum bandwidth of a full speed Thunderbolt 4 cable is 5 GB/s. Some suppliers may design their connector product to be able to support next generation PCI Express 5.0 running at 32 GT/s per lane for future proofing and minimizing development costs over the next few years.<ref name="OCuLink2" /> Initially, PCI-SIG expected to bring OCuLink into laptops for connection of powerful external GPU boxes. It turned out to be a rare use. Instead, OCuLink became popular for PCIe interconnections in servers.<ref name="6MiK5" />


=== Derivative forms === === Derivative forms ===
Numerous other form factors use, or are able to use, PCIe. These include: Numerous other form factors use, or are able to use, PCIe. These include:
* Low-height card * Low-height card
* ]: Successor to the ] form factor (with ×1 PCIe and USB 2.0; hot-pluggable) * ]: Successor to the ] form factor (with x1 PCIe and USB 2.0; hot-pluggable)
* PCI Express ExpressModule: A hot-pluggable modular form factor defined for servers and workstations * PCI Express ExpressModule: A hot-pluggable modular form factor defined for servers and workstations
* ]: A PCI Express-based flash card standard by the ] with ×2 PCIe * ]: A PCI Express-based flash card standard by the ] with x2 PCIe
* ] card: A PCI Express-based flash card by the CompactFlash Association in three form factors supporting 1 to 4 PCIe lanes * ] card: A PCI Express-based flash card by the CompactFlash Association in three form factors supporting 1 to 4 PCIe lanes
* SD card: The ] bus, introduced in version 7.0 of the SD specification uses an ×1 PCIe link * SD card: The ] bus, introduced in version 7.0 of the SD specification uses a x1 PCIe link
* ]: Similar to the ]/] form factor (VITA 42.3) * ]: Similar to the ]/] form factor (VITA 42.3)
* ]: A complement to ] for larger applications; supports serial based backplane topologies * ]: A complement to ] for larger applications; supports serial based backplane topologies
* ]: A complement to the ] specification; supports processor and I/O modules on ATCA boards (×1, ×2, ×4 or ×8 PCIe). * ]: A complement to the ] specification; supports processor and I/O modules on ATCA boards (x1, x2, x4 or x8 PCIe).
* ]: A tiny expansion card format (43{{nbsp}}mm × 65&nbsp;mm) for embedded and small-form-factor applications, which implements two ×1 PCIe links on a high-density connector along with USB, I2C, and up to 100 points of I/O * ]: A tiny expansion card format (43{{nbsp}}mm × 65&nbsp;mm) for embedded and small-form-factor applications, which implements two x1 PCIe links on a high-density connector along with USB, I2C, and up to 100 points of I/O
* ]: A variant from ] Inc designed for use in low-profile rack-mounted chassis.<ref name="tNP5L" /> It has the connector bracket reversed so it cannot fit in a normal PCI Express socket, but it is pin-compatible and may be inserted if the bracket is removed. * ]: A variant from ] Inc designed for use in low-profile rack-mounted chassis.<ref name="tNP5L" /> It has the connector bracket reversed so it cannot fit in a normal PCI Express socket, but it is pin-compatible and may be inserted if the bracket is removed.
* ] (formerly known as NGFF) * ] (formerly known as NGFF)
* ] brings PCIe 3.0 to mobile devices (such as tablets and smartphones), over the ] physical layer.<ref name="osiit" /><ref name="PoRghEr" /> * ] brings PCIe 3.0 to mobile devices (such as tablets and smartphones), over the ] physical layer.<ref name="osiit" /><ref name="PoRghEr" />
* ] (formerly known as SFF-8639) * ] (formerly known as SFF-8639)
* ]


The PCIe slot connector can also carry protocols other than PCIe. Some ] support ], a proprietary technology that uses a slot to transmit video signals from the host CPU's ] instead of PCIe, using a supported add-in. The PCIe slot connector can also carry protocols other than PCIe. Some ] support ], a proprietary technology that uses a slot to transmit video signals from the host CPU's ] instead of PCIe, using a supported add-in.
Line 526: Line 513:
Since, PCIe has undergone several large and smaller revisions, improving on performance and other features. Since, PCIe has undergone several large and smaller revisions, improving on performance and other features.


===Comparison table===
{| class="wikitable"
{| class="wikitable" style="text-align:right"
|+ PCI Express link performance<ref name="faq4" /><ref name="faq3" /> |+ PCI Express link performance<ref name="faq4" /><ref name="faq3" />
|- style="line-height:120%"
|-
! scope="col" rowspan=2 | Version ! scope="col" rowspan=2 | Version
! scope="col" rowspan=2 | Intro-<br />duced ! scope="col" rowspan=2 | intro-<br>duced
! scope="col" colspan=2 rowspan=2 | Line code ! scope="col" rowspan=2 colspan=2 | Line code
! scope="col" rowspan=2 | Transfer rate{{Efn-lr|name="both-directions"|In each direction (each lane is a dual simplex channel).}}{{Efn-lr|name="transfer-rate"|Transfer rate refers to the encoded serial bit rate; 2.5 GT/s means 2.5&nbsp;Gbit/s serial data rate.}}<br />(per lane)
! scope="col" rowspan=2 | Transfer <br />rate
per lane{{Efn-lr|name="both-directions"|In each direction (each lane is a dual simplex channel).}}{{Efn-lr|name="transfer-rate"|Transfer rate refers to the encoded serial bit rate; 2.5{{nbsp}}GT/s means 2.5{{nbsp}}Gbit/s serial data rate.}} ! scope="col" colspan=5 | Throughput{{Efn-lr|name="both-directions"}}{{Efn-lr|name="throughput"|Throughput indicates the usable bandwidth (i.e. only including the payload, not the 8b/10b, 128b/130b, or 242B/256B encoding overhead). The PCIe 1.0 transfer rate of 2.5&nbsp;GT/s per lane means a 2.5&nbsp;Gbit/s serial bit rate; after applying a 8b/10b encoding, this corresponds to a useful throughput of 2.0&nbsp;Gbit/s &#61; 250&nbsp;MB/s.}}
|-
! scope="col" colspan=5 | Throughput{{Efn-lr|name="both-directions"}}{{Efn-lr|name="throughput"|Throughput indicates the unencoded bandwidth (without 8b/10b, 128b/130b, or 242B/256B encoding overhead). The PCIe 1.0 transfer rate of 2.5{{nbsp}}GT/s per lane means a 2.5{{nbsp}}Gbit/s serial bit rate corresponding to a throughput of 2.0{{nbsp}}Gbit/s or 250{{nbsp}}MB/s prior to 8b/10b encoding.}}
! scope="col" | x1
! scope="col" | x2
! scope="col" | x4
! scope="col" | x8
! scope="col" | x16
|- |-
! scope="col" | ×1
! scope="col" | ×2
! scope="col" | ×4
! scope="col" | ×8
! scope="col" | ×16
|- style="text-align:right;"
! scope="row" | 1.0 ! scope="row" | 1.0
| 2003
| 2003 ||rowspan=5| ] ||] || {{Nowrap|2.5 ]}}
| rowspan=5 | ]
| {{Nowrap|0.250 ]}} || {{COther|{{Nowrap|0.500 GB/s}}|align=right}} || {{Nowrap|1.000 GB/s}} || {{COther|{{Nowrap|2.000 GB/s}}|align=right}} || {{Nowrap|4.000 GB/s}}
| rowspan=2 | ]
|- style="text-align:right;"
| {{Nowrap|2.5 ]}}
| {{Nowrap|0.250 ]}}
| {{COther|{{Nowrap|0.500 GB/s}}|align=right}}
| {{Nowrap|1.000 GB/s}}
| {{COther|{{Nowrap|2.000 GB/s}}|align=right}}
| {{Nowrap|4.000 GB/s}}
|-
! scope="row" | 2.0 ! scope="row" | 2.0
| 2007 ||8b/10b || {{Nowrap|5.0 GT/s}} | 2007
| {{Nowrap|5.0 GT/s}}
| {{COther|{{Nowrap|0.500 GB/s}}|align=right}} || {{Nowrap|1.000 GB/s}} || {{COther|{{Nowrap|2.000 GB/s}}|align=right}} || {{Nowrap|4.000 GB/s}} || {{CNone|{{Nowrap|8.000 GB/s}}|align=right}} | {{COther|{{Nowrap|0.500 GB/s}}|align=right}}
| {{Nowrap|1.000 GB/s}}
| {{COther|{{Nowrap|2.000 GB/s}}|align=right}}
| {{Nowrap|4.000 GB/s}}
| {{CNone|{{Nowrap|8.000 GB/s}}|align=right}}
|-
|- style="text-align:right;"
! scope="row" | 3.0 ! scope="row" | 3.0
| 2010 ||] || {{Nowrap|8.0 GT/s}} | 2010
| rowspan=3 | ]
| {{Nowrap|8.0 GT/s}}
| {{Nowrap|0.985 GB/s}} || {{COther|{{Nowrap|1.969 GB/s}}|align=right}} || {{Nowrap|3.938 GB/s}} || {{CNone|{{Nowrap|{{0|0}}7.877 GB/s}}|align=right}} || {{Nowrap|15.754 GB/s}} | {{Nowrap|0.985 GB/s}}
| {{COther|{{Nowrap|1.969 GB/s}}|align=right}}
| {{Nowrap|3.938 GB/s}}
| {{CNone|{{Nowrap|{{0|0}}7.877 GB/s}}|align=right}}
| {{Nowrap|15.754 GB/s}}
|-
|- style="text-align:right;"
! scope="row" | 4.0 ! scope="row" | 4.0
| 2017 ||128b/130b || {{Nowrap|16.0 GT/s}} | 2017
| {{Nowrap|16.0 GT/s}}
| {{COther|{{Nowrap|1.969 GB/s}}|align=right}} || {{Nowrap|3.938 GB/s}} || {{CNone|{{Nowrap|{{0|0}}7.877 GB/s}}|align=right}} || {{Nowrap|15.754 GB/s}} || {{CNone|{{Nowrap|{{0|0}}31.508 GB/s}}|align=right}} | {{COther|{{Nowrap|1.969 GB/s}}|align=right}}
| {{Nowrap|3.938 GB/s}}
| {{CNone|{{Nowrap|{{0|0}}7.877 GB/s}}|align=right}}
| {{Nowrap|15.754 GB/s}}
| {{CNone|{{Nowrap|{{0|0}}31.508 GB/s}}|align=right}}
|-
|- style="text-align:right;"
! scope="row" | 5.0 ! scope="row" | 5.0
| 2019 ||128b/130b || {{Nowrap|32.0 GT/s}} | 2019
| {{Nowrap|32.0 GT/s}}
| {{Nowrap|3.938 GB/s}} || {{CNone|{{Nowrap|{{0|0}}7.877 GB/s}}|align=right}} || {{Nowrap|15.754 GB/s}} || {{CNone|{{Nowrap|31.508 GB/s}}|align=right}} || {{Nowrap|63.015 GB/s}} | {{Nowrap|3.938 GB/s}}
| {{CNone|{{Nowrap|{{0|0}}7.877 GB/s}}|align=right}}
| {{Nowrap|15.754 GB/s}}
| {{CNone|{{Nowrap|31.508 GB/s}}|align=right}}
| {{Nowrap|63.015 GB/s}}
|-
|- style="text-align:right;"
! scope="row" | 6.0 ! scope="row" | 6.0
| 2022
| 2022 || ]<br />]|| 242B/256B <br />]|| {{Nowrap|64.0 GT/s}}<br />{{Nowrap|32.0 G]}}
| rowspan=2 | {{Nowrap|]}}<br />]
| {{CNone|{{Nowrap|7.563 GB/s}}|align=right}} || {{Nowrap|15.125 GB/s}} || {{CNone|{{Nowrap|30.250 GB/s}}|align=right}} || {{Nowrap|60.500 GB/s}} || {{CNone|{{Nowrap|121.000 GB/s}}|align=right}}
| rowspan=2 | 1b/1b<br />242B/256B ]
| {{Nowrap|64.0 GT/s}}<br />{{Nowrap|32.0 G]}}
| {{CNone|{{Nowrap|7.563 GB/s}}|align=right}}
| {{Nowrap|15.125 GB/s}}
| {{CNone|{{Nowrap|30.250 GB/s}}|align=right}}
| {{Nowrap|60.500 GB/s}}
| {{CNone|{{Nowrap|121.000 GB/s}}|align=right}}
|-
! scope="row" | 7.0
| 2025<br />(planned)
| {{Nowrap|128.0 GT/s}}<br />{{Nowrap|64.0 GBd}}
| {{Nowrap|15.125 GB/s}}
| {{CNone|{{Nowrap|30.250 GB/s}}|align=right}}
| {{Nowrap|60.500 GB/s}}
| {{CNone|{{Nowrap|121.000 GB/s}}|align=right}}
| {{Nowrap|242.000 GB/s}}
|} |}


Line 573: Line 604:
In 2003, PCI-SIG introduced PCIe 1.0a, with a per-lane data rate of 250&nbsp;MB/s and a ] of 2.5 gigatransfers per second (GT/s). In 2003, PCI-SIG introduced PCIe 1.0a, with a per-lane data rate of 250&nbsp;MB/s and a ] of 2.5 gigatransfers per second (GT/s).


Transfer rate is expressed in transfers per second instead of bits per second because the number of transfers includes the overhead bits, which do not provide additional throughput;<ref name="HroAC" /> PCIe 1.x uses an ] scheme, resulting in a 20% (=&nbsp;2/10) overhead on the raw channel bandwidth.<ref name="tfQxK" /> So in the PCIe terminology, transfer rate refers to the encoded bit rate: 2.5 GT/s is 2.5 Gbps on the encoded serial link. This corresponds to 2.0 Gbps of pre-coded data or 250 MB/s, which is referred to as throughput in PCIe. Transfer rate is expressed in transfers per second instead of bits per second because the number of transfers includes the overhead bits, which do not provide additional throughput;<ref name="HroAC" /> PCIe 1.x uses an ] scheme, resulting in a 20% (=&nbsp;2/10) overhead on the raw channel bandwidth.<ref name="tfQxK" /> So in the PCIe terminology, transfer rate refers to the encoded bit rate: 2.5&nbsp;GT/s is 2.5&nbsp;Gbit/s on the encoded serial link. This corresponds to 2.0&nbsp;Gbit/s of pre-coded data or 250&nbsp;MB/s, which is referred to as throughput in PCIe.


===={{Anchor|1.1}}PCI Express 1.1==== ===={{Anchor|1.1}}PCI Express 1.1====
Line 579: Line 610:


=== {{Anchor|2.0}}PCI Express 2.0 === === {{Anchor|2.0}}PCI Express 2.0 ===
] is present because the USB&nbsp;3.0 ports require more power than the PCI Express bus can supply. More often, a ] is used.}}]] ] is present because the USB&nbsp;3.0 ports require more power than the PCI Express bus can supply. More often, a ] is used.}}]]


] announced the availability of the PCI Express Base 2.0 specification on 15 January 2007.<ref name="PCIExpressPressRelease" /> The PCIe 2.0 standard doubles the transfer rate compared with PCIe 1.0 to 5{{nbsp}}GT/s and the per-lane throughput rises from 250&nbsp;MB/s to 500&nbsp;MB/s. Consequently, a 16-lane PCIe connector (×16) can support an aggregate throughput of up to 8&nbsp;GB/s. ] announced the availability of the PCI Express Base 2.0 specification on 15 January 2007.<ref name="PCIExpressPressRelease" /> The PCIe 2.0 standard doubles the transfer rate compared with PCIe 1.0 to 5{{nbsp}}GT/s and the per-lane throughput rises from 250&nbsp;MB/s to 500&nbsp;MB/s. Consequently, a 16-lane PCIe connector (x16) can support an aggregate throughput of up to 8&nbsp;GB/s.


PCIe 2.0 motherboard slots are fully ] with PCIe v1.x cards. PCIe 2.0 cards are also generally backward compatible with PCIe 1.x motherboards, using the available bandwidth of PCI Express 1.1. Overall, graphic cards or motherboards designed for v2.0 work, with the other being v1.1 or v1.0a. PCIe 2.0 motherboard slots are fully ] with PCIe v1.x cards. PCIe 2.0 cards are also generally backward compatible with PCIe 1.x motherboards, using the available bandwidth of PCI Express 1.1. Overall, graphic cards or motherboards designed for v2.0 work, with the other being v1.1 or v1.0a.


The PCI-SIG also said that PCIe 2.0 features improvements to the point-to-point data transfer protocol and its software architecture.<ref name="UaYlc" /> The PCI-SIG also said that PCIe 2.0 features improvements to the point-to-point data transfer protocol and its software architecture.<ref name="UaYlc" />


]'s first PCIe 2.0 capable chipset was the ] and boards began to ship from various vendors (], ], ]) as of 21 October 2007.<ref name="wHHTf" /> AMD started supporting PCIe 2.0 with its ] and nVidia started with the ].<ref name="gL2GQ" /> All of Intel's prior chipsets, including the ] chipset, supported PCIe 1.1 or 1.0a.<ref name="mUQKD" /> ]'s first PCIe 2.0 capable chipset was the ] and boards began to ship from various vendors (], ], ]) as of 21 October 2007.<ref name="wHHTf" /> AMD started supporting PCIe 2.0 with its ] and nVidia started with the ].<ref name="gL2GQ" /> All of Intel's prior chipsets, including the ] chipset, supported PCIe 1.1 or 1.0a.<ref name="mUQKD" />


Like 1.x, PCIe 2.0 uses an ] scheme, therefore delivering, per-lane, an effective 4&nbsp;Gbit/s max. transfer rate from its 5&nbsp;GT/s raw data rate. Like 1.x, PCIe 2.0 uses an ] scheme, therefore delivering, per-lane, an effective 4&nbsp;Gbit/s max. transfer rate from its 5&nbsp;GT/s raw data rate.


===={{Anchor|2.1}}PCI Express 2.1==== ===={{Anchor|2.1}}PCI Express 2.1====
PCI Express 2.1 (with its specification dated 4 March 2009) supports a large proportion of the management, support, and troubleshooting systems planned for full implementation in PCI Express 3.0. However, the speed is the same as PCI Express 2.0. The increase in power from the slot breaks backward compatibility between PCI Express 2.1 cards and some older motherboards with 1.0/1.0a, but most motherboards with PCI Express 1.1 connectors are provided with a BIOS update by their manufacturers through utilities to support backward compatibility of cards with PCIe 2.1. PCI Express 2.1 (with its specification dated 4 March 2009) supports a large proportion of the management, support, and troubleshooting systems planned for full implementation in PCI Express 3.0. However, the speed is the same as PCI Express 2.0. The increase in power from the slot breaks backward compatibility between PCI Express 2.1 cards and some older motherboards with 1.0/1.0a, but most motherboards with PCI Express 1.1 connectors are provided with a BIOS update by their manufacturers through utilities to support backward compatibility of cards with PCIe 2.1.


=== {{Anchor|3.0}}PCI Express 3.0 === === {{Anchor|3.0}}PCI Express 3.0 ===
Line 604: Line 635:


==== {{Anchor|3.1}}PCI Express 3.1 ==== ==== {{Anchor|3.1}}PCI Express 3.1 ====
In September 2013, PCI Express&nbsp;3.1 specification was announced for release in late 2013 or early 2014, consolidating various improvements to the published PCI Express&nbsp;3.0 specification in three areas: power management, performance and functionality.<ref name="PoRghEr" /><ref name="5lvIH" /> It was released in November 2014.<ref name="9EIkz" /> In September 2013, PCI Express&nbsp;3.1 specification was announced for release in late 2013 or early 2014, consolidating various improvements to the published PCI Express&nbsp;3.0 specification in three areas: power management, performance and functionality.<ref name="PoRghEr" /><ref name="5lvIH" /> It was released in November 2014.<ref name="9EIkz" />


=== {{Anchor|4.0}}PCI Express 4.0 === === {{Anchor|4.0}}PCI Express 4.0 ===
On 29 November 2011, PCI-SIG preliminarily announced PCI Express 4.0,<ref name="W466M" /> providing a 16&nbsp;GT/s bit rate that doubles the bandwidth provided by PCI Express 3.0, while maintaining backward and ] in both software support and used mechanical interface.<ref name="QNZsy" /> PCI Express 4.0 specs also bring OCuLink-2, an alternative to ]. OCuLink version 2 has up to 16&nbsp;GT/s (16{{nbsp}}GB/s total for ×8 lanes),<ref name="OCuLink2" /> while the maximum bandwidth of a Thunderbolt 3 link is 5{{nbsp}}GB/s. On 29 November 2011, PCI-SIG preliminarily announced PCI Express 4.0,<ref name="W466M" /> providing a 16&nbsp;GT/s bit rate that doubles the bandwidth provided by PCI Express 3.0 to 31.5&nbsp;GB/s in each direction for a 16-lane configuration, while maintaining backward and ] in both software support and used mechanical interface.<ref name="QNZsy" /> PCI Express 4.0 specs also bring OCuLink-2, an alternative to ]. OCuLink version 2 has up to 16&nbsp;GT/s (16{{nbsp}}GB/s total for x8 lanes),<ref name="OCuLink2" /> while the maximum bandwidth of a Thunderbolt 3 link is 5{{nbsp}}GB/s.


In June 2016 Cadence, PLDA and Synopsys demoed PCIe 4.0 physical-layer, controller, switch and other IP blocks at the PCI SIG’s annual developer’s conference.<ref name="EE_4+5" /> In June 2016 Cadence, PLDA and Synopsys demonstrated PCIe 4.0 physical-layer, controller, switch and other IP blocks at the PCI SIG’s annual developer’s conference.<ref name="EE_4+5" />
] announced the first 100{{nbsp}}Gbit/s network adapter with PCIe 4.0 on 15 June 2016,<ref name="FZ4hQ" /> and the first 200{{nbsp}}Gbit/s network adapter with PCIe 4.0 on 10 November 2016.<ref name="zovf4" /> ] announced the first 100{{nbsp}}Gbit/s network adapter with PCIe 4.0 on 15 June 2016,<ref name="FZ4hQ" /> and the first 200{{nbsp}}Gbit/s network adapter with PCIe 4.0 on 10 November 2016.<ref name="zovf4" />
Line 625: Line 656:
] announced on 9 January 2019 its upcoming ]-based processors and X570 chipset would support PCIe 4.0.<ref name="Akskd" /> AMD had hoped to enable partial support for older chipsets, but instability caused by motherboard traces not conforming to PCIe 4.0 specifications made that impossible.<ref name="KDBMK" /><ref name="CAY71" /> ] announced on 9 January 2019 its upcoming ]-based processors and X570 chipset would support PCIe 4.0.<ref name="Akskd" /> AMD had hoped to enable partial support for older chipsets, but instability caused by motherboard traces not conforming to PCIe 4.0 specifications made that impossible.<ref name="KDBMK" /><ref name="CAY71" />


Intel released their first mobile CPUs with PCI express 4.0 support in mid-2020, as a part of the ] microarchitecture.<ref name="C02lC" /> Intel released their first mobile CPUs with PCI Express 4.0 support in mid-2020, as a part of the ] microarchitecture.<ref name="C02lC" />


=== {{Anchor|5.0}}PCI Express 5.0 === === {{Anchor|5.0}}PCI Express 5.0 ===
]
In June 2017, PCI-SIG announced the PCI Express 5.0 preliminary specification.<ref name="TR_pcie4" /> Bandwidth was expected to increase to 32{{nbsp}}GT/s, yielding 63{{nbsp}}GB/s<!-- 32 GT/s × 16 × 128/130 / 8 = 63,015,384,615 B/s --> in each direction in a 16-lane configuration. The draft spec was expected to be standardized in 2019.{{citation needed|date=July 2019}} Initially, {{Nowrap|25.0 GT/s}} was also considered for technical feasibility. In June 2017, PCI-SIG announced the PCI Express 5.0 preliminary specification.<ref name="TR_pcie4" /> Bandwidth was expected to increase to 32{{nbsp}}GT/s, yielding 63{{nbsp}}GB/s<!-- 32 GT/s × 16 × 128/130 / 8 = 63,015,384,615 B/s --> in each direction in a 16-lane configuration. The draft spec was expected to be standardized in 2019.{{citation needed|date=July 2019}} Initially, {{Nowrap|25.0 GT/s}} was also considered for technical feasibility.


On June 7, 2017 at PCI-SIG DevCon, Synopsys recorded the first demonstration of PCI Express 5.0 at 32GT/s. <ref name="Syn50" /> On 7 June 2017 at PCI-SIG DevCon, Synopsys recorded the first demonstration of PCI Express 5.0 at 32&nbsp;GT/s.<ref name="Syn50" />


On 31 May 2018, PLDA announced the availability of their XpressRICH5 PCIe 5.0 Controller IP based on draft 0.7 of the PCIe 5.0 specification on the same day.<ref name="n6z9y" /><ref name="9OVm8" /> On 31 May 2018, PLDA announced the availability of their XpressRICH5 PCIe 5.0 Controller IP based on draft 0.7 of the PCIe 5.0 specification on the same day.<ref name="n6z9y" /><ref name="9OVm8" />
Line 637: Line 669:
and on 17 January 2019, PCI SIG announced the version 0.9 had been ratified, with version 1.0 targeted for release in the first quarter of 2019.<ref name="ETVqe" /> and on 17 January 2019, PCI SIG announced the version 0.9 had been ratified, with version 1.0 targeted for release in the first quarter of 2019.<ref name="ETVqe" />


On 29 May 2019, PCI-SIG officially announced the release of the final PCI-Express 5.0 specification.<ref name="MW69U" />{{clarify|beyond the release of the spec, what do we know about uptake and applications of this spec in real products? who is using it? what product lines? etc.|date=July 2019}} On 29 May 2019, PCI-SIG officially announced the release of the final PCI Express 5.0 specification.<ref name="MW69U" />


On 20 November 2019, ] presented the first PCIe 5.0 Controller HC9001 in a 12&nbsp;nm manufacturing process.<ref name="yk5Nd" /> Production started in 2020. On 20 November 2019, ] presented the first PCIe 5.0 Controller HC9001 in a 12&nbsp;nm manufacturing process.<ref name="yk5Nd" /> Production started in 2020.


On 17 August 2020, IBM announced the ] processor with PCIe 5.0 and up to 32 lanes per single-chip module (SCM) and up to 64 lanes per double-chip module (DCM).<ref></ref> On 17 August 2020, IBM announced the ] processor with PCIe 5.0 and up to 32 lanes per single-chip module (SCM) and up to 64 lanes per double-chip module (DCM).<ref></ref>

On 9 September 2021, IBM announced the Power E1080 Enterprise server with planned availability date 17 September.<ref name="IBM-ENUSZG21-0059"></ref> It can have up to 16 Power10 SCMs with maximum of 32 slots per system which can act as PCIe 5.0 x8 or PCIe 4.0 x16.<ref name="IBM-REDP-5649-00"></ref> Alternatively they can be used as PCIe 5.0 x16 slots for optional optical CXP converter adapters connecting to external PCIe expansion drawers.

On 27 October 2021, Intel announced the 12th Gen Intel Core CPU family, the world's first consumer x86-64 processors with PCIe 5.0 (up to 16 lanes) connectivity.<ref>{{cite web|url=https://www.intel.com/content/www/us/en/newsroom/news/12th-gen-core-processors.html |title=Intel Unveils 12th Gen Intel Core, Launches World's Best Gaming |publisher=Intel.com |accessdate=2022-02-16}}</ref>


On 22 March 2022, Nvidia announced Nvidia Hopper GH100 GPU, the world's first PCIe 5.0 GPU.<ref>{{cite web|url=https://nvidianews.nvidia.com/news/nvidia-announces-hopper-architecture-the-next-generation-of-accelerated-computing|title = NVIDIA Announces Hopper Architecture, the Next Generation of Accelerated Computing}}</ref>
On 9 September 2021, IBM announced the Power E1080 Enterprise server with planned availability date 17 September.<ref name="IBM-ENUSZG21-0059"></ref> It can have up to 16 POWER10 SCMs with maximum of 32 slots per system which can act as PCIe 5.0 x8 or PCIe 4.0 x16.<ref name="IBM-REDP-5649-00"></ref> Alternatively they can be used as PCIe 5.0 x16 slots for optional optical CXP converter adapters connecting to external PCIe expansion drawers.


On 27 October 2021, Intel announced the 12th Gen Intel Core CPU family, the world's first consumer x86-64 processors with PCIe 5.0(up to 16 lanes) connectivity.<ref>{{cite web|url=https://www.intel.com/content/www/us/en/newsroom/news/12th-gen-core-processors.html |title=Intel Unveils 12th Gen Intel Core, Launches World’s Best Gaming |publisher=Intel.com |date= |accessdate=2022-02-16}}</ref> On 23 May 2022, AMD announced its Zen 4 architecture with support for up to 24 lanes of PCIe 5.0 connectivity on consumer platforms and 128 lanes on server platforms.<ref>{{cite web|url=https://www.amd.com/en/press-releases/2022-05-23-amd-showcases-growth-gaming-commercial-and-mainstream-mobile-and-industry|title=AMD Showcases Industry-Leading Gaming, Commercial, and Mainstream PC Technologies at COMPUTEX 2022|publisher=AMD.com|accessdate=2022-05-23}}</ref><ref>{{cite web|url=
https://www.amd.com/en/campaigns/epyc-9004-architecture|title=4th Gen AMD EPYC™ Processor Architecture|publisher=AMD.com|accessdate=2022-11-12}}</ref>


=== {{Anchor|6.0}}PCI Express 6.0 === === {{Anchor|6.0}}PCI Express 6.0 ===
On 18 June 2019, PCI-SIG announced the development of PCI Express 6.0 specification. Bandwidth is expected to increase to 64{{nbsp}}GT/s, yielding 128{{nbsp}}GB/s in each direction in a 16-lane configuration, with a target release date of 2021.<ref name="businesswire.com" /> The new standard uses 4-level ] (PAM-4) with a low-latency ] (FEC) in place of ] (NRZ) modulation.<ref name="O5gOe" /> Unlike previous PCI Express versions, forward error correction is used to increase data integrity and PAM-4 is used as line code so that two bits are transferred per transfer. With 64{{nbsp}}GT/s data transfer rate (raw bit rate), up to 252{{nbsp}}GB/s is possible in ×16 configuration.<ref name="businesswire.com" /> On 18 June 2019, PCI-SIG announced the development of PCI Express 6.0 specification. Bandwidth is expected to increase to 64{{nbsp}}GT/s, yielding 128{{nbsp}}GB/s in each direction in a 16-lane configuration, with a target release date of 2021.<ref name="businesswire.com" /> The new standard uses 4-level ] (PAM-4) with a low-latency ] (FEC) in place of ] (NRZ) modulation.<ref name="O5gOe" /> Unlike previous PCI Express versions, forward error correction is used to increase data integrity and PAM-4 is used as line code so that two bits are transferred per transfer. With 64{{nbsp}}GT/s data transfer rate (raw bit rate), up to 121{{nbsp}}GB/s in each direction is possible in x16 configuration.<ref name="businesswire.com" />


On 24 February 2020, the PCI Express 6.0 revision 0.5 specification (a "first draft" with all architectural aspects and requirements defined) was released.<ref name="puGmx" /> On 24 February 2020, the PCI Express 6.0 revision 0.5 specification (a "first draft" with all architectural aspects and requirements defined) was released.<ref name="puGmx" />
Line 654: Line 691:
On 5 November 2020, the PCI Express 6.0 revision 0.7 specification (a "complete draft" with electrical specifications validated via test chips) was released.<ref name="ltCSi" /> On 5 November 2020, the PCI Express 6.0 revision 0.7 specification (a "complete draft" with electrical specifications validated via test chips) was released.<ref name="ltCSi" />


On 6 October 2021, the PCI Express 6.0 revision 0.9 specification (a "final draft") was released.<ref name="60r9">{{cite web |last1=Yanes |first1=Al |title=PCIe® 6.0 Specification, Version 0.9: One Step Closer to Final Release {{!}} PCI-SIG |url=https://pcisig.com/blog/pcie®-60-specification-version-09-one-step-closer-final-release |website=pcisig.com |access-date=6 October 2021}}</ref> On 6 October 2021, the PCI Express 6.0 revision 0.9 specification (a "final draft") was released.<ref name="60r9">{{cite web |last=Yanes |first=Al |title=PCIe® 6.0 Specification, Version 0.9: One Step Closer to Final Release {{!}} PCI-SIG |url=https://pcisig.com/blog/pcie®-60-specification-version-09-one-step-closer-final-release |website=pcisig.com |access-date=6 October 2021}}</ref>


On 11 January 2022, PCI-SIG officially announced the release of the final PCI-Express 6.0 specification.<ref>{{cite web|url=https://www.businesswire.com/news/home/20220111005011/en/PCI-SIG%C2%AE-Releases-PCIe%C2%AE-6.0-Specification-Delivering-Record-Performance-to-Power-Big-Data-Applications |title=PCI-SIG® Releases PCIe® 6.0 Specification Delivering Record Performance to Power Big Data Applications |publisher=Business Wire |date=2022-01-11 |accessdate=2022-02-16}}</ref> On 11 January 2022, PCI-SIG officially announced the release of the final PCI Express 6.0 specification.<ref>{{cite web|url=https://www.businesswire.com/news/home/20220111005011/en/PCI-SIG%C2%AE-Releases-PCIe%C2%AE-6.0-Specification-Delivering-Record-Performance-to-Power-Big-Data-Applications |title=PCI-SIG® Releases PCIe® 6.0 Specification Delivering Record Performance to Power Big Data Applications |publisher=Business Wire |date=2022-01-11 |accessdate=2022-02-16}}</ref>


On 18 March 2024, Nvidia announced Nvidia Blackwell GB100 GPU, the world's first PCIe 6.0 GPU.<ref>{{cite web|url=https://nvidianews.nvidia.com/news/nvidia-blackwell-platform-arrives-to-power-a-new-era-of-computing|title = NVIDIA Blackwell Platform Arrives to Power a New Era of Computing}}</ref>
] coding results in a vastly higher ] (BER) of 10<sup>−6</sup> (vs. 10<sup>−12</sup> previously), so in place of 128b/130b encoding, a 3-way interlaced ] (FEC) is used in addition to ] (CRC). A fixed 256 byte ] (FLIT) block carries 242 bytes of data, which includes variable-sized transaction level packets (TLP) and data link layer payload (DLLP); remaining 14 bytes are reserved for 8-byte CRC and 6-byte FEC. <ref name=pcie6_evolution_blog>{{cite web|url=https://pcisig.com/blog/evolution-pci-express-specification-its-sixth-generation-third-decade-and-still-going-strong |title=The Evolution of the PCI Express Specification: On its Sixth Generation, Third Decade and Still Going Strong |publisher=Pci-Sig |date=2022-01-11 |accessdate=2022-02-16}}</ref><ref name="PCIe6_fut">{{cite web|url=https://www.youtube.com/watch?v=jhehXwnu0Ss | archive-url=https://ghostarchive.org/varchive/youtube/20211030/jhehXwnu0Ss| archive-date=2021-10-30|title=PCIe 6.0 Specification: The Interconnect for I/O Needs of the Future |page=8 |author=Debendra Das Sharma |publisher=PCI-SIG}}{{cbignore}} </ref> 3-way ] is used in PAM-4/FLIT mode to reduce error rate; the interface does not switch to NRZ and 128/130b encoding even when retraining to lower data rates.<ref name=cadence_pice6>{{cite web|url=https://www.cadence.com/content/dam/cadence-www/global/en_US/documents/tools/ip/design-ip/pushing-the-envelope-with-pcie-6-wp.pdf |title=Pushing the Envelope with PCIe 6.0: Bringing PAM4 to PCIe |format=PDF |date= |accessdate=2022-02-16}}</ref><ref name=pcie6_webinar>{{cite web|url=https://pcisig.com/sites/default/files/files/PCIe%206.0%20Webinar_Final_.pdf |title=PowerPoint Presentation |format=PDF |date= |accessdate=2022-02-16}}</ref>

] coding results in a vastly higher ] (BER) of 10<sup>−6</sup> (vs. 10<sup>−12</sup> previously), so in place of 128b/130b encoding, a 3-way interlaced ] (FEC) is used in addition to ] (CRC). A fixed 256 byte ] (FLIT) block carries 242 bytes of data, which includes variable-sized transaction level packets (TLP) and data link layer payload (DLLP); remaining 14 bytes are reserved for 8-byte CRC and 6-byte FEC.<ref name=pcie6_evolution_blog>{{cite web|url=https://pcisig.com/blog/evolution-pci-express-specification-its-sixth-generation-third-decade-and-still-going-strong |title=The Evolution of the PCI Express Specification: On its Sixth Generation, Third Decade and Still Going Strong |publisher=Pci-Sig |date=2022-01-11 |accessdate=2022-02-16}}</ref><ref name="PCIe6_fut">{{cite web|url=https://www.youtube.com/watch?v=jhehXwnu0Ss | archive-url=https://ghostarchive.org/varchive/youtube/20211030/jhehXwnu0Ss| archive-date=2021-10-30|title=PCIe 6.0 Specification: The Interconnect for I/O Needs of the Future |page=8 |author=Debendra Das Sharma | date=8 June 2020|publisher=PCI-SIG}}{{cbignore}}</ref> 3-way ] is used in PAM-4/FLIT mode to reduce error rate; the interface does not switch to NRZ and 128/130b encoding even when retraining to lower data rates.<ref name=cadence_pice6>{{cite web|url=https://www.cadence.com/content/dam/cadence-www/global/en_US/documents/tools/ip/design-ip/pushing-the-envelope-with-pcie-6-wp.pdf |title=Pushing the Envelope with PCIe 6.0: Bringing PAM4 to PCIe |date= |accessdate=2022-02-16}}</ref><ref name=pcie6_webinar>{{cite web|url=https://pcisig.com/sites/default/files/files/PCIe%206.0%20Webinar_Final_.pdf |title=PowerPoint Presentation |date= |accessdate=2022-02-16}}</ref>

=== {{Anchor|7.0}}PCI Express 7.0 ===
On 21 June 2022, PCI-SIG announced the development of PCI Express 7.0 specification.<ref>{{cite web|url=https://www.businesswire.com/news/home/20220621005137/en |title=PCI-SIG® Announces PCI Express® 7.0 Specification to Reach 128 GT/s |publisher=Business Wire |date=2022-06-21 |accessdate=2022-06-25}}</ref> It will deliver 128&nbsp;GT/s raw bit rate and up to 242&nbsp;GB/s per direction in x16 configuration, using the same ] signaling as version 6.0. Doubling of the data rate will be achieved by fine-tuning channel parameters to decrease signal losses and improve power efficiency, but signal integrity is expected to be a challenge. The specification is expected to be finalized in 2025.

On 2 April 2024, PCI-SIG announced the release of PCIe 7.0 specification version 0.5; PCI Express 7.0 remains on track for release in 2025.<ref name="PCIe70v05"/>


== {{Anchor|M-PCIE|Thunderbolt}}Extensions and future directions == == {{Anchor|M-PCIE|Thunderbolt}}Extensions and future directions ==
Line 665: Line 709:
'']'' was co-developed by ] and ] as a general-purpose high speed interface combining a logical PCIe link with ] and was originally intended as an all-fiber interface, but due to early difficulties in creating a consumer-friendly fiber interconnect, nearly all implementations are copper systems. A notable exception, the ] VPC-Z2, uses a nonstandard USB port with an optical component to connect to an outboard PCIe display adapter. Apple has been the primary driver of Thunderbolt adoption through 2011, though several other vendors<ref name="kZCuH" /> have announced new products and systems featuring Thunderbolt. Thunderbolt 3 forms the basis of the ] standard. '']'' was co-developed by ] and ] as a general-purpose high speed interface combining a logical PCIe link with ] and was originally intended as an all-fiber interface, but due to early difficulties in creating a consumer-friendly fiber interconnect, nearly all implementations are copper systems. A notable exception, the ] VPC-Z2, uses a nonstandard USB port with an optical component to connect to an outboard PCIe display adapter. Apple has been the primary driver of Thunderbolt adoption through 2011, though several other vendors<ref name="kZCuH" /> have announced new products and systems featuring Thunderbolt. Thunderbolt 3 forms the basis of the ] standard.


''Mobile PCIe'' specification (abbreviated to ''M-PCIe'') allows PCI Express architecture to operate over the ]'s ] physical layer technology. Building on top of already existing widespread adoption of M-PHY and its low-power design, Mobile PCIe lets mobile devices use PCI Express.<ref name="RKmF2" /> ''Mobile PCIe'' specification (abbreviated to ''M-PCIe'') allows PCI Express architecture to operate over the ]'s ] physical layer technology. Building on top of already existing widespread adoption of M-PHY and its low-power design, Mobile PCIe lets mobile devices use PCI Express.<ref name="RKmF2" />


=== Draft process === === Draft process ===
Line 680: Line 724:
The PCIe link is built around dedicated unidirectional couples of serial (1-bit), point-to-point connections known as ''lanes''. This is in sharp contrast to the earlier PCI connection, which is a bus-based system where all the devices share the same bidirectional, 32-bit or 64-bit parallel bus. The PCIe link is built around dedicated unidirectional couples of serial (1-bit), point-to-point connections known as ''lanes''. This is in sharp contrast to the earlier PCI connection, which is a bus-based system where all the devices share the same bidirectional, 32-bit or 64-bit parallel bus.


PCI Express is a ], consisting of a '']'', a '']'', and a '']''. The Data Link Layer is subdivided to include a ] (MAC) sublayer. The Physical Layer is subdivided into logical and electrical sublayers. The Physical logical-sublayer contains a physical coding sublayer (PCS). The terms are borrowed from the ] networking protocol model. PCI Express is a ], consisting of a '']'', a '']'', and a '']''. The Data Link Layer is subdivided to include a ] (MAC) sublayer. The Physical Layer is subdivided into logical and electrical sublayers. The Physical logical-sublayer contains a physical coding sublayer (PCS). The terms are borrowed from the ] networking protocol model.


=== {{Anchor|PHYSICAL-LAYER}}Physical layer === === {{Anchor|PHYSICAL-LAYER}}Physical layer ===
Line 695: Line 739:
! Variable ! Variable
|- |-
| {{0}}×1 || 2×18 = {{0}}36<ref name="9tQ3g" /> || 2×{{0}}7 = {{0}}14 || 25&nbsp;mm || {{0}}7.65&nbsp;mm | {{0}}x1 || 2×18 = {{0}}36<ref name="9tQ3g" /> || 2×{{0}}7 = {{0}}14 || 25&nbsp;mm || {{0}}7.65&nbsp;mm
|- |-
| {{0}}×4 || 2×32 = {{0}}64 || 2×21 = {{0}}42 || 39&nbsp;mm || 21.65&nbsp;mm | {{0}}x4 || 2×32 = {{0}}64 || 2×21 = {{0}}42 || 39&nbsp;mm || 21.65&nbsp;mm
|- |-
| {{0}}×8 || 2×49 = {{0}}98 || 2×38 = {{0}}76 || 56&nbsp;mm || 38.65&nbsp;mm | {{0}}x8 || 2×49 = {{0}}98 || 2×38 = {{0}}76 || 56&nbsp;mm || 38.65&nbsp;mm
|- |-
| ×16 || 2×82 = 164 || 2×71 = 142 || 89&nbsp;mm || 71.65&nbsp;mm | {{0}}x16 || 2×82 = 164 || 2×71 = 142 || 89&nbsp;mm || 71.65&nbsp;mm
|} |}


] ]


The PCIe Physical Layer (''PHY'', ''PCIEPHY'', ''PCI Express PHY'', or ''PCIe PHY'') specification is divided into two sub-layers, corresponding to electrical and logical specifications. The logical sublayer is sometimes further divided into a MAC sublayer and a PCS, although this division is not formally part of the PCIe specification. A specification published by Intel, the PHY Interface for PCI Express (PIPE),<ref name="pipe_spec" /> defines the MAC/PCS functional partitioning and the interface between these two sub-layers. The PIPE specification also identifies the ''physical media attachment'' (PMA) layer, which includes the ] and other analog circuitry; however, since SerDes implementations vary greatly among ] vendors, PIPE does not specify an interface between the PCS and PMA. The PCIe Physical Layer (''PHY'', ''PCIEPHY'', ''PCI Express PHY'', or ''PCIe PHY'') specification is divided into two sub-layers, corresponding to electrical and logical specifications. The logical sublayer is sometimes further divided into a MAC sublayer and a PCS, although this division is not formally part of the PCIe specification. A specification published by Intel, the PHY Interface for PCI Express (PIPE),<ref name="pipe_spec" /> defines the MAC/PCS functional partitioning and the interface between these two sub-layers. The PIPE specification also identifies the ''physical media attachment'' (PMA) layer, which includes the ] and other analog circuitry; however, since SerDes implementations vary greatly among ] vendors, PIPE does not specify an interface between the PCS and PMA.
Line 710: Line 754:
At the electrical level, each lane consists of two unidirectional ]s operating at 2.5, 5, 8, 16 or 32&nbsp;]/s, depending on the negotiated capabilities. Transmit and receive are separate differential pairs, for a total of four data wires per lane. At the electrical level, each lane consists of two unidirectional ]s operating at 2.5, 5, 8, 16 or 32&nbsp;]/s, depending on the negotiated capabilities. Transmit and receive are separate differential pairs, for a total of four data wires per lane.


A connection between any two PCIe devices is known as a ''link'', and is built up from a collection of one or more ''lanes''. All devices must minimally support single-lane (×1) link. Devices may optionally support wider links composed of up to 32 lanes.<ref name="PCIe-System-Architecture"></ref><ref name="Intel-PCIe"></ref> This allows for very good compatibility in two ways: A connection between any two PCIe devices is known as a ''link'', and is built up from a collection of one or more ''lanes''. All devices must minimally support single-lane (x1) link. Devices may optionally support wider links composed of up to 32 lanes.<ref name="PCIe-System-Architecture"></ref><ref name="Intel-PCIe"></ref> This allows for very good compatibility in two ways:
* A PCIe card physically fits (and works correctly) in any slot that is at least as large as it is (e.g., an ×1 sized card works in any sized slot); * A PCIe card physically fits (and works correctly) in any slot that is at least as large as it is (e.g., a x1 sized card works in any sized slot);
* A slot of a large physical size (e.g., ×16) can be wired electrically with fewer lanes (e.g., ×1, ×4, ×8, or ×12) as long as it provides the ground connections required by the larger physical slot size. * A slot of a large physical size (e.g., x16) can be wired electrically with fewer lanes (e.g., x1, x4, x8, or x12) as long as it provides the ground connections required by the larger physical slot size.
In both cases, PCIe negotiates the highest mutually supported number of lanes. Many graphics cards, motherboards and ] versions are verified to support ×1, ×4, ×8 and ×16 connectivity on the same connection. In both cases, PCIe negotiates the highest mutually supported number of lanes. Many graphics cards, motherboards and ] versions are verified to support x1, x4, x8 and x16 connectivity on the same connection.


The width of a PCIe connector is 8.8&nbsp;mm, while the height is 11.25&nbsp;mm, and the length is variable. The fixed section of the connector is 11.65&nbsp;mm in length and contains two rows of 11 pins each (22 pins total), while the length of the other section is variable depending on the number of lanes. The pins are spaced at 1&nbsp;mm intervals, and the thickness of the card going into the connector is 1.6&nbsp;mm.<ref name="pcie_schematics1" /><ref name="pcie_schematics2" /> The width of a PCIe connector is 8.8&nbsp;mm, while the height is 11.25&nbsp;mm, and the length is variable. The fixed section of the connector is 11.65&nbsp;mm in length and contains two rows of 11 pins each (22 pins total), while the length of the other section is variable depending on the number of lanes. The pins are spaced at 1&nbsp;mm intervals, and the thickness of the card going into the connector is 1.6&nbsp;mm.<ref name="pcie_schematics1" /><ref name="pcie_schematics2" />


==== Data transmission ==== ==== Data transmission ====
PCIe sends all control messages, including interrupts, over the same links used for data. The serial protocol can never be blocked, so latency is still comparable to conventional PCI, which has dedicated interrupt lines. When the problem of IRQ sharing of pin based interrupts is taken into account and the fact that message signaled interrupts (MSI) can bypass an I/O APIC and be delivered to the CPU directly, MSI performance ends up being substantially better. <ref name="vV4Hv" /> PCIe sends all control messages, including interrupts, over the same links used for data. The serial protocol can never be blocked, so latency is still comparable to conventional PCI, which has dedicated interrupt lines. When the problem of IRQ sharing of pin based interrupts is taken into account and the fact that message signaled interrupts (MSI) can bypass an I/O APIC and be delivered to the CPU directly, MSI performance ends up being substantially better.<ref name="vV4Hv" />


Data transmitted on multiple-lane links is interleaved, meaning that each successive byte is sent down successive lanes. The PCIe specification refers to this interleaving as ''data striping''. While requiring significant hardware complexity to synchronize (or ]) the incoming striped data, striping can significantly reduce the latency of the ''n''<sup>th</sup> byte on a link. While the lanes are not tightly synchronized, there is a limit to the ''lane to lane skew'' of 20/8/6&nbsp;ns for 2.5/5/8&nbsp;GT/s so the hardware buffers can re-align the striped data.<ref name="iPAaS" /> Due to padding requirements, striping may not necessarily reduce the latency of small data packets on a link. Data transmitted on multiple-lane links is interleaved, meaning that each successive byte is sent down successive lanes. The PCIe specification refers to this interleaving as ''data striping''. While requiring significant hardware complexity to synchronize (or ]) the incoming striped data, striping can significantly reduce the latency of the ''n''<sup>th</sup> byte on a link. While the lanes are not tightly synchronized, there is a limit to the ''lane to lane skew'' of 20/8/6&nbsp;ns for 2.5/5/8&nbsp;GT/s so the hardware buffers can re-align the striped data.<ref name="iPAaS" /> Due to padding requirements, striping may not necessarily reduce the latency of small data packets on a link.
Line 725: Line 769:


A desirable balance (and therefore ]) of 0 and 1 bits in the data stream is achieved by ]ing a known ] as a "]" to the data stream in a feedback topology. Because the scrambling polynomial is known, the data can be recovered by applying the XOR a second time. Both the scrambling and descrambling steps are carried out in hardware. A desirable balance (and therefore ]) of 0 and 1 bits in the data stream is achieved by ]ing a known ] as a "]" to the data stream in a feedback topology. Because the scrambling polynomial is known, the data can be recovered by applying the XOR a second time. Both the scrambling and descrambling steps are carried out in hardware.

Dual simplex in PCIe means there are two simplex channels on every PCIe lane. Simplex means communication is only possible in one direction. By having two simplex channels, two-way communication is made possible. One differential pair is used for each channel.<ref>https://ww1.microchip.com/downloads/aemDocuments/documents/TCG/ProductDocuments/Brochures/00003818.pdf</ref><ref>{{cite book | url=https://books.google.com/books?id=ZjyrAgAAQBAJ&dq=pcie+dual+simplex&pg=PA69 | isbn=978-0-7384-5121-3 | title=IBM Power 770 and 780 Technical Overview and Introduction | date=6 June 2013 | publisher=IBM Redbooks }}</ref><ref>{{cite book | url=https://books.google.com/books?id=k_HJCgAAQBAJ&dq=pcie+differential+pair&pg=PT128 | isbn=978-0-7686-9003-3 | title=CompTIA A+ Exam Cram (Exams 220-602, 220-603, 220-604) | date=19 July 2007 | publisher=Pearson Education }}</ref>


=== Data link layer === === Data link layer ===
Line 732: Line 778:
# initialize and manage flow control credits # initialize and manage flow control credits


On the transmit side, the data link layer generates an incrementing sequence number for each outgoing TLP. It serves as a unique identification tag for each transmitted TLP, and is inserted into the header of the outgoing TLP. A 32-bit ] code (known in this context as Link CRC or LCRC) is also appended to the end of each outgoing TLP. On the transmit side, the data link layer generates an incrementing sequence number for each outgoing TLP. It serves as a unique identification tag for each transmitted TLP, and is inserted into the header of the outgoing TLP. A 32-bit ] code (known in this context as Link CRC or LCRC) is also appended to the end of each outgoing TLP.


On the receive side, the received TLP's LCRC and sequence number are both validated in the link layer. If either the LCRC check fails (indicating a data error), or the sequence-number is out of range (non-consecutive from the last valid received TLP), then the bad TLP, as well as any TLPs received after the bad TLP, are considered invalid and discarded. The receiver sends a negative acknowledgement message (NAK) with the sequence-number of the invalid TLP, requesting re-transmission of all TLPs forward of that sequence-number. If the received TLP passes the LCRC check and has the correct sequence number, it is treated as valid. The link receiver increments the sequence-number (which tracks the last received good TLP), and forwards the valid TLP to the receiver's transaction layer. An ACK message is sent to remote transmitter, indicating the TLP was successfully received (and by extension, all TLPs with past sequence-numbers.) On the receive side, the received TLP's LCRC and sequence number are both validated in the link layer. If either the LCRC check fails (indicating a data error), or the sequence-number is out of range (non-consecutive from the last valid received TLP), then the bad TLP, as well as any TLPs received after the bad TLP, are considered invalid and discarded. The receiver sends a negative acknowledgement message (NAK) with the sequence-number of the invalid TLP, requesting re-transmission of all TLPs forward of that sequence-number. If the received TLP passes the LCRC check and has the correct sequence number, it is treated as valid. The link receiver increments the sequence-number (which tracks the last received good TLP), and forwards the valid TLP to the receiver's transaction layer. An ACK message is sent to remote transmitter, indicating the TLP was successfully received (and by extension, all TLPs with past sequence-numbers.)


If the transmitter receives a NAK message, or no acknowledgement (NAK or ACK) is received until a timeout period expires, the transmitter must retransmit all TLPs that lack a positive acknowledgement (ACK). Barring a persistent malfunction of the device or transmission medium, the link-layer presents a reliable connection to the transaction layer, since the transmission protocol ensures delivery of TLPs over an unreliable medium. If the transmitter receives a NAK message, or no acknowledgement (NAK or ACK) is received until a timeout period expires, the transmitter must retransmit all TLPs that lack a positive acknowledgement (ACK). Barring a persistent malfunction of the device or transmission medium, the link-layer presents a reliable connection to the transaction layer, since the transmission protocol ensures delivery of TLPs over an unreliable medium.


In addition to sending and receiving TLPs generated by the transaction layer, the data-link layer also generates and consumes data link layer packets (DLLPs). ACK and NAK signals are communicated via DLLPs, as are some power management messages and flow control credit information (on behalf of the transaction layer). In addition to sending and receiving TLPs generated by the transaction layer, the data-link layer also generates and consumes data link layer packets (DLLPs). ACK and NAK signals are communicated via DLLPs, as are some power management messages and flow control credit information (on behalf of the transaction layer).
Line 746: Line 792:


PCI Express uses credit-based flow control. In this scheme, a device advertises an initial amount of credit for each received buffer in its transaction layer. The device at the PCI Express uses credit-based flow control. In this scheme, a device advertises an initial amount of credit for each received buffer in its transaction layer. The device at the
opposite end of the link, when sending transactions to this device, counts the number of credits each TLP consumes from its account. The sending device may only transmit a TLP when doing so does not make its consumed credit count exceed its credit limit. When the receiving device finishes processing the TLP from its buffer, it signals a return of credits to the sending device, which increases the credit limit by the restored amount. The credit counters are modular counters, and the comparison of consumed credits to credit limit requires ]. The advantage of this scheme (compared to other methods such as wait states or handshake-based transfer protocols) is that the latency of credit return does not affect performance, provided that the credit limit is not encountered. This assumption is generally met if each device is designed with adequate buffer sizes. opposite end of the link, when sending transactions to this device, counts the number of credits each TLP consumes from its account. The sending device may only transmit a TLP when doing so does not make its consumed credit count exceed its credit limit. When the receiving device finishes processing the TLP from its buffer, it signals a return of credits to the sending device, which increases the credit limit by the restored amount. The credit counters are modular counters, and the comparison of consumed credits to credit limit requires ]. The advantage of this scheme (compared to other methods such as wait states or handshake-based transfer protocols) is that the latency of credit return does not affect performance, provided that the credit limit is not encountered. This assumption is generally met if each device is designed with adequate buffer sizes.


PCIe 1.x is often quoted to support a data rate of 250&nbsp;MB/s in each direction, per lane. This figure is a calculation from the physical signaling rate (2.5&nbsp;]) divided by the encoding overhead (10 bits per byte). This means a sixteen lane (×16) PCIe card would then be theoretically capable of 16×250&nbsp;MB/s = 4&nbsp;GB/s in each direction. While this is correct in terms of data bytes, more meaningful calculations are based on the usable data payload rate, which depends on the profile of the traffic, which is a function of the high-level (software) application and intermediate protocol levels. PCIe 1.x is often quoted to support a data rate of 250&nbsp;MB/s in each direction, per lane. This figure is a calculation from the physical signaling rate (2.5&nbsp;]) divided by the encoding overhead (10 bits per byte). This means a sixteen lane (x16) PCIe card would then be theoretically capable of 16x250&nbsp;MB/s = 4&nbsp;GB/s in each direction. While this is correct in terms of data bytes, more meaningful calculations are based on the usable data payload rate, which depends on the profile of the traffic, which is a function of the high-level (software) application and intermediate protocol levels.


Like other high data rate serial interconnect systems, PCIe has a protocol and processing overhead due to the additional transfer robustness (CRC and acknowledgements). Long continuous unidirectional transfers (such as those typical in high-performance storage controllers) can approach >95% of PCIe's raw (lane) data rate. These transfers also benefit the most from increased number of lanes (×2, ×4, etc.) But in more typical applications (such as a ] or ] controller), the traffic profile is characterized as short data packets with frequent enforced acknowledgements.<ref name="traffic_profile" /> This type of traffic reduces the efficiency of the link, due to overhead from packet parsing and forced interrupts (either in the device's host interface or the PC's CPU). Being a protocol for devices connected to the same ], it does not require the same tolerance for transmission errors as a protocol for communication over longer distances, and thus, this loss of efficiency is not particular to PCIe. Like other high data rate serial interconnect systems, PCIe has a protocol and processing overhead due to the additional transfer robustness (CRC and acknowledgements). Long continuous unidirectional transfers (such as those typical in high-performance storage controllers) can approach >95% of PCIe's raw (lane) data rate. These transfers also benefit the most from increased number of lanes (x2, x4, etc.) But in more typical applications (such as a ] or ] controller), the traffic profile is characterized as short data packets with frequent enforced acknowledgements.<ref name="traffic_profile" /> This type of traffic reduces the efficiency of the link, due to overhead from packet parsing and forced interrupts (either in the device's host interface or the PC's CPU). Being a protocol for devices connected to the same ], it does not require the same tolerance for transmission errors as a protocol for communication over longer distances, and thus, this loss of efficiency is not particular to PCIe.


=== Efficiency of the link === === Efficiency of the link ===
As for any "network like" communication links, some of the "raw" bandwidth is consumed by protocol overhead:<ref name="Xilinx">{{cite web|title=Understanding Performance of PCI Express Systems|url=https://www.xilinx.com/support/documentation/white_papers/wp350.pdf|last=Lawley|first=Jason|publisher=Xilinx|version=1.2|date=2014-10-28|url-status=live}}</ref> As for any network-like communication links, some of the raw bandwidth is consumed by protocol overhead:<ref name="Xilinx">{{cite web|title=Understanding Performance of PCI Express Systems|url=https://www.xilinx.com/support/documentation/white_papers/wp350.pdf|last=Lawley|first=Jason|publisher=Xilinx|version=1.2|date=2014-10-28}}</ref>


A PCIe 1.x lane for example offers a data rate on top of the physical layer of 250 MB/s (simplex). This isn't the payload bandwidth but the physical layer bandwidth – a PCIe lane has to carry additional information for full functionality.{{r|Xilinx}} A PCIe 1.x lane for example offers a data rate on top of the physical layer of 250&nbsp;MB/s (simplex). This is not the payload bandwidth but the physical layer bandwidth – a PCIe lane has to carry additional information for full functionality.{{r|Xilinx}}


{| class="wikitable" {| class="wikitable"
Line 775: Line 821:
|End |End
|- |-
|Size (Bytes) !scope="row" |Size (Bytes)
|1 |1
|2 |2
Line 789: Line 835:
|+Gen 3 Transaction Layer Packet{{r|Xilinx|p=3}} |+Gen 3 Transaction Layer Packet{{r|Xilinx|p=3}}
!scope="row" scope="col" style="width: 80px;" |Layer !scope="row" scope="col" style="width: 80px;" |Layer
!scope="col" style="width: 40px;" |G3 PHY !scope="col" style="width: 40px;" |PHY
!scope="col" style="width: 120px;" |Data Link Layer !scope="col" style="width: 120px;" |Data Link Layer
!scope="col" colspan="3" style="width: 400px;" |Transaction Layer !scope="col" colspan="3" style="width: 400px;" |Transaction Layer
Line 812: Line 858:
The Gen3 overhead is then 22, 26 or 30 bytes per transaction.<!-- Seriously how did somebody get odd numbers out of this? -->{{Clarify |reason=Don't we also have a 128/130b encoding overhead that's not factored in to any of this?|date=September 2021}}{{Citation needed|reason=I fixed the bad math here, but it needs a source, not me and a calculator|date=September 2021}} The Gen3 overhead is then 22, 26 or 30 bytes per transaction.<!-- Seriously how did somebody get odd numbers out of this? -->{{Clarify |reason=Don't we also have a 128/130b encoding overhead that's not factored in to any of this?|date=September 2021}}{{Citation needed|reason=I fixed the bad math here, but it needs a source, not me and a calculator|date=September 2021}}


The <math>\text{Packet Efficiency} = \frac{\text{Payload}}{\left(\text{Payload} + \text{Overhead} \right)}</math> for a 128 byte payload is 86%, and 98% for a 1024 byte payload. For small accesses like register settings (4 bytes), the efficiency drops as low as 16%.{{Citation needed|reason=Formula is in text, but it didn't state this anywhere or anything about register settings being 4 bytes or the like... and most of the PCIe config registers aren't on the devices and don't need a bus access, they're just sitting around in a DMA region mapped to the CPU's control registers|date=September 2021}} The <math>\text{Packet Efficiency} = \frac{\text{Payload}}{\text{Payload} + \text{Overhead}}</math> for a 128 byte payload is 86%, and 98% for a 1024 byte payload. For small accesses like register settings (4 bytes), the efficiency drops as low as 16%.{{Citation needed|reason=Formula is in text, but it didn't state this anywhere or anything about register settings being 4 bytes or the like... and most of the PCIe config registers aren't on the devices and don't need a bus access, they're just sitting around in a DMA region mapped to the CPU's control registers|date=September 2021}}


The maximum payload size (MPS) is set on all devices based on smallest maximum on any device in the chain. If one device has an MPS of 128 bytes, ''all'' devices of the tree must set their MPS to 128 bytes. In this case the bus will have a peak efficiency of 86% for writes.{{r|Xilinx|p=3}} The maximum payload size (MPS) is set on all devices based on smallest maximum on any device in the chain. If one device has an MPS of 128 bytes, ''all'' devices of the tree must set their MPS to 128 bytes. In this case the bus will have a peak efficiency of 86% for writes.{{r|Xilinx|p=3}}


== Applications == == Applications ==
] Nvidia GeForce GTX 650 Ti, a PCI Express 3.0 ×16 graphics card]] ] Nvidia GeForce GTX 650 Ti, a PCI Express 3.0 x16 graphics card]]
] GeForce GTX 1070, a PCI Express 3.0 ×16 Graphics card.]] ] GeForce GTX 1070, a PCI Express 3.0 x16 Graphics card]]
] 82574L Gigabit Ethernet ], a PCI Express ×1 card]] ] 82574L Gigabit Ethernet ], a PCI Express x1 card]]
]-based ] controller, as a PCI Express ×1 card]] ]-based ] controller, as a PCI Express x1 card]]


PCI Express operates in consumer, server, and industrial applications, as a motherboard-level interconnect (to link motherboard-mounted peripherals), a passive backplane interconnect and as an ] interface for add-in boards. PCI Express operates in consumer, server, and industrial applications, as a motherboard-level interconnect (to link motherboard-mounted peripherals), a passive backplane interconnect and as an ] interface for add-in boards.
Line 826: Line 872:
In virtually all modern ({{as of|2012|lc=on}}) PCs, from consumer laptops and desktops to enterprise data servers, the PCIe bus serves as the primary motherboard-level interconnect, connecting the host system-processor with both integrated peripherals (surface-mounted ICs) and add-on peripherals (expansion cards). In most of these systems, the PCIe bus co-exists with one or more legacy PCI buses, for backward compatibility with the large body of legacy PCI peripherals. In virtually all modern ({{as of|2012|lc=on}}) PCs, from consumer laptops and desktops to enterprise data servers, the PCIe bus serves as the primary motherboard-level interconnect, connecting the host system-processor with both integrated peripherals (surface-mounted ICs) and add-on peripherals (expansion cards). In most of these systems, the PCIe bus co-exists with one or more legacy PCI buses, for backward compatibility with the large body of legacy PCI peripherals.


{{As of | 2013}}, PCI Express has replaced ] as the default interface for graphics cards on new systems. Almost all models of ]s released since 2010 by ] (ATI) and ] use PCI Express. Nvidia uses the high-bandwidth data transfer of PCIe for its ] (SLI) technology, which allows multiple graphics cards of the same chipset and model number to run in tandem, allowing increased performance.{{Citation needed |reason=Needs cables running across the top connecting the cards, unsure if this is something proprietary or PCIe 1x based.|date=September 2021}} AMD has also developed a multi-GPU system based on PCIe called ].{{Citation needed |reason=Needs cables running across the top connecting the cards, unsure if this is something proprietary or PCIe 1x based.|date=September 2021}} AMD, Nvidia, and Intel have released motherboard chipsets that support as many as four PCIe ×16 slots, allowing tri-GPU and quad-GPU card configurations. {{As of | 2013}}, PCI Express has replaced ] as the default interface for graphics cards on new systems. Almost all models of ]s released since 2010 by ] (ATI) and ] use PCI Express. Nvidia used the high-bandwidth data transfer of PCIe for its ] (SLI) technology, which allowed multiple graphics cards of the same chipset and model number to run in tandem, allowing increased performance.{{Citation needed |reason=Needs cables running across the top connecting the cards, unsure if this is something proprietary or PCIe 1x based.|date=September 2021}} This interface has, since, been discontinued. AMD has also developed a multi-GPU system based on PCIe called ].{{Citation needed |reason=Needs cables running across the top connecting the cards, unsure if this is something proprietary or PCIe 1x based.|date=September 2021}} AMD, Nvidia, and Intel have released motherboard chipsets that support as many as four PCIe x16 slots, allowing tri-GPU and quad-GPU card configurations.


=== External GPUs === === External GPUs ===
Line 833: Line 879:
In 2006, ] developed the ] external PCIe family of ] that can be used for advanced graphic applications for the professional market.<ref name="gxHZT" /> These video cards require a PCI Express x8 or x16 slot for the host-side card, which connects to the Plex via a ] carrying eight PCIe lanes.<ref name="zJYg8" /> In 2006, ] developed the ] external PCIe family of ] that can be used for advanced graphic applications for the professional market.<ref name="gxHZT" /> These video cards require a PCI Express x8 or x16 slot for the host-side card, which connects to the Plex via a ] carrying eight PCIe lanes.<ref name="zJYg8" />


In 2008, AMD announced the ] technology, based on a proprietary cabling system that is compatible with PCIe ×8 signal transmissions.<ref name="HgxXj" /> This connector is available on the Fujitsu Amilo and the Acer Ferrari One notebooks. Fujitsu launched their AMILO GraphicBooster enclosure for XGP soon thereafter.<ref name="WHU07" /> Around 2010 Acer launched the Dynavivid graphics dock for XGP.<ref name="mvR09" /> In 2008, AMD announced the ] technology, based on a proprietary cabling system that is compatible with PCIe x8 signal transmissions.<ref name="HgxXj" /> This connector is available on the Fujitsu Amilo and the Acer Ferrari One notebooks. Fujitsu launched their AMILO GraphicBooster enclosure for XGP soon thereafter.<ref name="WHU07" /> Around 2010 Acer launched the Dynavivid graphics dock for XGP.<ref name="mvR09" />


In 2010 external card hubs were introduced that can connect to a laptop or desktop through a PCI ExpressCard slot. These hubs can accept full-sized graphics cards. Examples include MSI GUS,<ref name="ZAJ0y" /> Village Instrument's ViDock,<ref name="J5UtH" /> the Asus ], Bplus PE4H V3.2 adapter,<ref name="jWWJt" /> as well as more improvised DIY devices.<ref name="ERk1e" /> However such solutions are limited by the size (often only ×1) and version of the available PCIe slot on a laptop. In 2010, external card hubs were introduced that can connect to a laptop or desktop through a PCI ExpressCard slot. These hubs can accept full-sized graphics cards. Examples include MSI GUS,<ref name="ZAJ0y" /> Village Instrument's ViDock,<ref name="J5UtH" /> the Asus ], Bplus PE4H V3.2 adapter,<ref name="jWWJt" /> as well as more improvised DIY devices.<ref name="ERk1e" /> However such solutions are limited by the size (often only x1) and version of the available PCIe slot on a laptop.


The Intel Thunderbolt interface has provided a new option to connect with a PCIe card externally. Magma has released the ExpressBox 3T, which can hold up to three PCIe cards (two at ×8 and one at ×4).<ref name="CvJwZ" /> MSI also released the Thunderbolt GUS II, a PCIe chassis dedicated for video cards.<ref name="OLzu7" /> Other products such as the Sonnet's Echo Express<ref name="5LOrR" /> and mLogic's mLink are Thunderbolt PCIe chassis in a smaller form factor.<ref name="apXPa" /> The Intel Thunderbolt interface has provided a new option to connect with a PCIe card externally. Magma has released the ExpressBox 3T, which can hold up to three PCIe cards (two at x8 and one at x4).<ref name="CvJwZ" /> MSI also released the Thunderbolt GUS II, a PCIe chassis dedicated for video cards.<ref name="OLzu7" /> Other products such as the Sonnet's Echo Express<ref name="5LOrR" /> and mLogic's mLink are Thunderbolt PCIe chassis in a smaller form factor.<ref name="apXPa" />


In 2017, more fully featured external card hubs were introduced, such as the Razer Core, which has a full-length PCIe ×16 interface.<ref name="PXbHS" /> In 2017, more fully featured external card hubs were introduced, such as the Razer Core, which has a full-length PCIe x16 interface.<ref name="PXbHS" />


=== Storage devices === === Storage devices ===
] RevoDrive ], a full-height x4 PCI Express card]] ] RevoDrive ], a full-height x4 PCI Express card]]
{{See also|SATA Express|NVM Express}} {{See also|SATA Express|NVMe}}


The PCI Express protocol can be used as data interface to ] devices, such as ]s and ]s (SSDs). The PCI Express protocol can be used as data interface to ] devices, such as ]s and ]s (SSDs).


The ] is a memory card format utilizing PCI Express, developed by the CompactFlash Association, with transfer rates of up to 1GB/s.<ref name="49Gx4" /> The ] is a memory card format utilizing PCI Express, developed by the CompactFlash Association, with transfer rates of up to 1&nbsp;GB/s.<ref name="49Gx4" />


Many high-performance, enterprise-class SSDs are designed as PCI Express ] cards.{{Citation needed|date=September 2021}} Before NVMe was standardized, many of these cards utilized proprietary interfaces and custom drivers to communicate with the operating system; they had much higher transfer rates (over 1&nbsp;GB/s) and IOPS (over one million I/O operations per second) when compared to Serial ATA or ] drives.{{Quantify |reason=Listing numbers isn't a comparison.|date=September 2021}}<ref name="P3Feb" /><ref name="NeWKh" /> For example, in 2011 OCZ and Marvell co-developed a native PCI Express solid-state drive controller for a PCI Express 3.0 ×16 slot with maximum capacity of 12&nbsp;TB and a performance of to 7.2&nbsp;GB/s sequential transfers and up to 2.52&nbsp;million IOPS in random transfers.<ref name="VLf63" />{{Relevance inline|reason=Can't find any info on whether this product was even sold, and I can't imagine it was when the other thing OCZ was in the news for at the time were their PCIe based SSDs being constantly failing nightmares that were impossible to recover because of the proprietary interface and required drivers... Enterprise would have rightfully scoffed at those numbers, thrown a couple thousand more regular SSDs in their giant storage arrays if they needed more than the billions of IOPS they were already achieving, maybe updated from 40Gbps to 100Gbps runs between the storage servers, and called it a day.|date=September 2021}} Many high-performance, enterprise-class SSDs are designed as PCI Express ] cards.{{Citation needed|date=September 2021}} Before NVMe was standardized, many of these cards utilized proprietary interfaces and custom drivers to communicate with the operating system; they had much higher transfer rates (over 1&nbsp;GB/s) and IOPS (over one million I/O operations per second) when compared to Serial ATA or ] drives.{{Quantify |reason=Listing numbers isn't a comparison.|date=September 2021}}<ref name="P3Feb" /><ref name="NeWKh" /> For example, in 2011 OCZ and Marvell co-developed a native PCI Express solid-state drive controller for a PCI Express 3.0 x16 slot with maximum capacity of 12&nbsp;TB and a performance of to 7.2&nbsp;GB/s sequential transfers and up to 2.52&nbsp;million IOPS in random transfers.<ref name="VLf63" />{{Relevance inline|reason=Can't find any info on whether this product was even sold, and I can't imagine it was when the other thing OCZ was in the news for at the time were their PCIe based SSDs being constantly failing nightmares that were impossible to recover because of the proprietary interface and required drivers... Enterprise would have rightfully scoffed at those numbers, thrown a couple thousand more regular SSDs in their giant storage arrays if they needed more than the billions of IOPS they were already achieving, maybe updated from 40&nbsp;Gbps to 100&nbsp;Gbps runs between the storage servers, and called it a day.|date=September 2021}}


] was an interface for connecting SSDs through SATA-compatible ports, optionally providing multiple PCI Express lanes as a pure PCI Express connection to the attached storage device.<ref name="ymSig" /> ] is a specification for internally mounted computer ]s and associated connectors, which also uses multiple PCI Express lanes.<ref name="SNLQe" /> ] was an interface for connecting SSDs through SATA-compatible ports, optionally providing multiple PCI Express lanes as a pure PCI Express connection to the attached storage device.<ref name="ymSig" /> ] is a specification for internally mounted computer ]s and associated connectors, which also uses multiple PCI Express lanes.<ref name="SNLQe" />


PCI Express storage devices can implement both ] logical interface for backward compatibility, and ] logical interface for much faster I/O operations provided by utilizing internal parallelism offered by such devices. Enterprise-class SSDs can also implement ].<ref name="FJvMX" /> PCI Express storage devices can implement both ] logical interface for backward compatibility, and ] logical interface for much faster I/O operations provided by utilizing internal parallelism offered by such devices. Enterprise-class SSDs can also implement ].<ref name="FJvMX" />


=== Cluster interconnect === === Cluster interconnect ===
Certain ] applications (such as large ]s) require the use of fiber-optic interconnects due to the distance limitations inherent in copper cabling. Typically, a network-oriented standard such as Ethernet or ] suffices for these applications, but in some cases the overhead introduced by ] protocols is undesirable and a lower-level interconnect, such as ], ], or ] is needed. Local-bus standards such as PCIe and ] can in principle be used for this purpose,<ref name="YUum6" /> but {{as of | 2015 | lc = on}}, solutions are only available from niche vendors such as ], and TTTech Auto. Certain ] applications (such as large ]s) require the use of fiber-optic interconnects due to the distance limitations inherent in copper cabling. Typically, a network-oriented standard such as Ethernet or ] suffices for these applications, but in some cases the overhead introduced by ] protocols is undesirable and a lower-level interconnect, such as ], ], or ] is needed. Local-bus standards such as PCIe and ] can in principle be used for this purpose,<ref name="YUum6" /> but {{as of | 2015 | lc = on}}, solutions are only available from niche vendors such as ], and TTTech Auto.


== Competing protocols == == Competing protocols ==
Other communications standards based on high bandwidth serial architectures include ], ], ], ], and the ] (MIPI). The differences are based on the trade-offs between flexibility and extensibility vs latency and overhead. For example, making the system hot-pluggable, as with Infiniband but not PCI Express, requires that software track network topology changes.{{fact|date=February 2021}} Other communications standards based on high bandwidth serial architectures include ], ], ], ], the ] (MIPI), and ]. Differences are based on the trade-offs between flexibility and extensibility vs latency and overhead. For example, making the system hot-pluggable, as with Infiniband but not PCI Express, requires that software track network topology changes.{{citation needed|date=February 2021}}


Another example is making the packets shorter to decrease latency (as is required if a bus must operate as a memory interface). Smaller packets mean packet headers consume a higher percentage of the packet, thus decreasing the effective bandwidth. Examples of bus protocols designed for this purpose are RapidIO and HyperTransport.{{fact|date=February 2021}} Another example is making the packets shorter to decrease latency (as is required if a bus must operate as a memory interface). Smaller packets mean packet headers consume a higher percentage of the packet, thus decreasing the effective bandwidth. Examples of bus protocols designed for this purpose are RapidIO and HyperTransport.{{citation needed|date=February 2021}}


PCI Express falls somewhere in the middle, targeted by design as a system interconnect (]) rather than a device interconnect or routed network protocol. Additionally, its design goal of software transparency constrains the protocol and raises its latency somewhat.{{fact|date=February 2021}} {{Clarify|date=September 2024|text=PCI Express falls somewhere in the middle,|reason=In the middle of *what*? What are the endpoints? Nothing above talks about device interconnects or routed network protocols; some discussion of routing was removed in a February 2019 edit, leaving this paragraph missing some context.}} targeted by design as a system interconnect (]) rather than a device interconnect or routed network protocol. Additionally, its design goal of software transparency constrains the protocol and raises its latency somewhat.{{citation needed|date=February 2021}}


Delays in PCIe 4.0 implementations led to the ] consortium, the ] effort and an open ] (CAPI) all being announced by the end of 2016.<ref name="1Jwlv" /> Delays in PCIe 4.0 implementations led to the ] consortium, the CCIX effort and an open ] (CAPI) all being announced by the end of 2016.<ref name="1Jwlv" />


On 11 March 2019, Intel presented ], a new interconnect bus, based on the PCI Express 5.0 physical layer infrastructure. The initial promoters of the CXL specification included: ], ], ], ], ], ], ], ] and ].<ref name="aJ00L" /> On 11 March 2019, Intel presented ], a new interconnect bus, based on the PCI Express 5.0 physical layer infrastructure. The initial promoters of the CXL specification included: ], ], ], ], ], ], ], ] and ].<ref name="aJ00L" />


== Integrators list == == Integrators list ==
Line 877: Line 923:
{{Div col|colwidth=22em}} {{Div col|colwidth=22em}}
* ] (ASPM) * ] (ASPM)
* ] (PCI)
* ]
* ] * ]
* ] * ] (PCI Extended)
* ] * ]
* ] * ]
Line 885: Line 931:
* ] (SDVO) * ] (SDVO)
* {{Section link|List of device bit rates|Main buses}} * {{Section link|List of device bit rates|Main buses}}
* ]
* ] (CXL)
{{div col end}} {{div col end}}


Line 901: Line 949:
<ref name="EeePC">{{cite web|url=http://beta.ivancover.com/index.php/Eee_PC_Research|title=Eee PC Research|type=wiki|work=ivc|access-date=26 October 2009|url-status=live|archive-url=https://web.archive.org/web/20100330035948/http://beta.ivancover.com/index.php/Eee_PC_Research|archive-date=30 March 2010}}</ref> <ref name="EeePC">{{cite web|url=http://beta.ivancover.com/index.php/Eee_PC_Research|title=Eee PC Research|type=wiki|work=ivc|access-date=26 October 2009|url-status=live|archive-url=https://web.archive.org/web/20100330035948/http://beta.ivancover.com/index.php/Eee_PC_Research|archive-date=30 March 2010}}</ref>
<ref name="pcie_cabling1.0">{{cite web| title = PCI Express External Cabling 1.0 Specification| access-date = 9 February 2007| url = http://www.pcisig.com/specifications/pciexpress/pcie_cabling1.0/| url-status = live| archive-url = https://web.archive.org/web/20070210055546/http://www.pcisig.com/specifications/pciexpress/pcie_cabling1.0/| archive-date = 10 February 2007}}</ref> <ref name="pcie_cabling1.0">{{cite web| title = PCI Express External Cabling 1.0 Specification| access-date = 9 February 2007| url = http://www.pcisig.com/specifications/pciexpress/pcie_cabling1.0/| url-status = live| archive-url = https://web.archive.org/web/20070210055546/http://www.pcisig.com/specifications/pciexpress/pcie_cabling1.0/| archive-date = 10 February 2007}}</ref>
<ref name="PoRghEr">{{Citation | title = PCI SIG discusses M‐PCIe oculink & 4th gen PCIe | date = 13 September 2013 | newspaper = The Register | place = ] | url = https://www.theregister.co.uk/Print/2013/09/13/pci_sig_discusses_m_pcie_oculink_and_fourth_gen_pcie/ | url-status = live | archive-url = https://web.archive.org/web/20170629201006/http://www.theregister.co.uk/Print/2013/09/13/pci_sig_discusses_m_pcie_oculink_and_fourth_gen_pcie/ | archive-date = 29 June 2017}}</ref> <ref name="PoRghEr">{{Citation | title = PCI SIG discusses M-PCIe oculink & 4th gen PCIe | date = 13 September 2013 | newspaper = The Register | place = ] | url = https://www.theregister.co.uk/Print/2013/09/13/pci_sig_discusses_m_pcie_oculink_and_fourth_gen_pcie/ | url-status = live | archive-url = https://web.archive.org/web/20170629201006/http://www.theregister.co.uk/Print/2013/09/13/pci_sig_discusses_m_pcie_oculink_and_fourth_gen_pcie/ | archive-date = 29 June 2017}}</ref>
<ref name="faq4">{{cite web|url = http://www.pcisig.com/news_room/faqs/FAQ_PCI_Express_4.0/#EQ3|archive-url = https://web.archive.org/web/20140518224913/http://www.pcisig.com/news_room/faqs/FAQ_PCI_Express_4.0/#EQ3|title = PCI Express 4.0 Frequently Asked Questions|access-date = 2014-05-18|archive-date = 2014-05-18|publisher = PCI-SIG|work = pcisig.com}}</ref> <ref name="faq4">{{cite web|url = http://www.pcisig.com/news_room/faqs/FAQ_PCI_Express_4.0/#EQ3|archive-url = https://web.archive.org/web/20140518224913/http://www.pcisig.com/news_room/faqs/FAQ_PCI_Express_4.0/#EQ3|title = PCI Express 4.0 Frequently Asked Questions|access-date = 2014-05-18|archive-date = 2014-05-18|publisher = PCI-SIG|work = pcisig.com}}</ref>
<ref name="PCIExpressPressRelease">{{cite press release | title = PCI Express Base 2.0 specification announced | publisher = ] | date = 15 January 2007 | access-date = 9 February 2007 | url = http://www.pcisig.com/news_room/PCIe2_0_Spec_Release_FINAL2.pdf | url-status = dead | archive-url = https://web.archive.org/web/20070304101327/http://www.pcisig.com/news_room/PCIe2_0_Spec_Release_FINAL2.pdf | archive-date = 4 March 2007}} — note that in this press release the term ''aggregate bandwidth'' refers to the sum of incoming and outgoing bandwidth; using this terminology the aggregate bandwidth of full duplex 100BASE-TX is 200{{nbsp}}Mbit/s.</ref> <ref name="PCIExpressPressRelease">{{cite press release | title = PCI Express Base 2.0 specification announced | publisher = ] | date = 15 January 2007 | access-date = 9 February 2007 | url = http://www.pcisig.com/news_room/PCIe2_0_Spec_Release_FINAL2.pdf | url-status = dead | archive-url = https://web.archive.org/web/20070304101327/http://www.pcisig.com/news_room/PCIe2_0_Spec_Release_FINAL2.pdf | archive-date = 4 March 2007}} — note that in this press release the term ''aggregate bandwidth'' refers to the sum of incoming and outgoing bandwidth; using this terminology the aggregate bandwidth of full duplex 100BASE-TX is 200{{nbsp}}Mbit/s.</ref>
Line 917: Line 965:
<ref name="pcie_schematics1">{{cite web | publisher = Interface bus | title = Mechanical Drawing for PCI Express Connector | access-date = 7 December 2007 | url = http://www.interfacebus.com/PCI-Express-Bus-PCIe-Description.html#d}}</ref> <ref name="pcie_schematics1">{{cite web | publisher = Interface bus | title = Mechanical Drawing for PCI Express Connector | access-date = 7 December 2007 | url = http://www.interfacebus.com/PCI-Express-Bus-PCIe-Description.html#d}}</ref>
<ref name="pcie_schematics2">{{cite web | url = http://portal.fciconnect.com/Comergent/fci/drawing/10018783.pdf | title = FCi schematic for PCIe connectors | publisher = FCI connect | access-date = 7 December 2007}}</ref> <ref name="pcie_schematics2">{{cite web | url = http://portal.fciconnect.com/Comergent/fci/drawing/10018783.pdf | title = FCi schematic for PCIe connectors | publisher = FCI connect | access-date = 7 December 2007}}</ref>
<ref name="traffic_profile">{{cite web| url=https://www.google.com/books?id=Xp7-NKsJ8_sC&pg=PA35&dq=frequent+enforced+acknowledgements/| title=Computer Peripherals And Interfaces| publisher=Technical Publications Pune| access-date=23 July 2009| url-status=live| archive-url=https://web.archive.org/web/20140225203956/http://www.google.com/books?id=Xp7-NKsJ8_sC&pg=PA35&dq=frequent+enforced+acknowledgements%2F| archive-date=25 February 2014}}</ref> <ref name="traffic_profile">{{cite book| url=https://books.google.com/books?id=Xp7-NKsJ8_sC&dq=frequent+enforced+acknowledgements/&pg=PA35| title=Computer Peripherals And Interfaces| year=2008| publisher=Technical Publications Pune| isbn=9788184313086| access-date=23 July 2009| url-status=live| archive-url=https://web.archive.org/web/20140225203956/http://www.google.com/books?id=Xp7-NKsJ8_sC&pg=PA35&dq=frequent+enforced+acknowledgements%2F| archive-date=25 February 2014}}</ref>
<ref name="s5NDG">{{cite book |chapter=PCI express and advanced switching: Evolutionary path to building next generation interconnects |pages=21–29 |doi=10.1109/CONECT.2003.1231473 |date=August 2003 |title=11th Symposium on High Performance Interconnects, 2003. Proceedings. |last1=Mayhew |first1=D. |last2=Krishnan |first2=V. |isbn=0-7695-2012-X |s2cid=7456382}}</ref> <ref name="s5NDG">{{cite book |chapter=PCI express and advanced switching: Evolutionary path to building next generation interconnects |pages=21–29 |doi=10.1109/CONECT.2003.1231473 |date=August 2003 |title=11th Symposium on High Performance Interconnects, 2003. Proceedings. |last1=Mayhew |first1=D. |last2=Krishnan |first2=V. |isbn=0-7695-2012-X |s2cid=7456382}}</ref>
<ref name="DQmzv">{{cite web | url=https://www.pcmag.com/encyclopedia/term/48998/pci-express | title=Definition of PCI Express}}</ref> <ref name="DQmzv">{{cite web | url=https://www.pcmag.com/encyclopedia/term/48998/pci-express | title=Definition of PCI Express|work = PCMag}}</ref>
<ref name="gf9Lm">{{cite web | publisher = Fedora project | url = http://ols.fedoraproject.org/OLS/Reprints-2007/zhang-Reprint.pdf | title = Enable PCI Express Advanced Error Reporting in the Kernel | work = Proceedings of the Linux Symposium | first1 = Yanmin | last1 = Zhang | first2 = T Long | last2 = Nguyen | date = June 2007 | url-status = dead | archive-url = https://web.archive.org/web/20160310074031/https://ols.fedoraproject.org/OLS/Reprints-2007/zhang-Reprint.pdf | archive-date = 2016-03-10 | access-date = 2012-05-08}}</ref> <ref name="gf9Lm">{{cite web | publisher = Fedora project | url = http://ols.fedoraproject.org/OLS/Reprints-2007/zhang-Reprint.pdf | title = Enable PCI Express Advanced Error Reporting in the Kernel | work = Proceedings of the Linux Symposium | first1 = Yanmin | last1 = Zhang | first2 = T Long | last2 = Nguyen | date = June 2007 | url-status = dead | archive-url = https://web.archive.org/web/20160310074031/https://ols.fedoraproject.org/OLS/Reprints-2007/zhang-Reprint.pdf | archive-date = 2016-03-10 | access-date = 2012-05-08}}</ref>
<ref name="sxOen">https://www.hyperstone.com Flash Memory Form Factors – The Fundamentals of Reliable Flash Storage, Retrieved 19 April 2018</ref> <ref name="sxOen">https://www.hyperstone.com Flash Memory Form Factors – The Fundamentals of Reliable Flash Storage, Retrieved 19 April 2018</ref>
Line 932: Line 980:
<ref name="RAreG">{{cite web|url=https://www.eurogamer.net/articles/digitalfoundry-2020-nvidia-geforce-rtx-3080-review|title=Nvidia GeForce RTX 3080 review: welcome to the next level|first=Richard|last=Leadbetter|website=]|date=September 16, 2020}}</ref> <ref name="RAreG">{{cite web|url=https://www.eurogamer.net/articles/digitalfoundry-2020-nvidia-geforce-rtx-3080-review|title=Nvidia GeForce RTX 3080 review: welcome to the next level|first=Richard|last=Leadbetter|website=]|date=September 16, 2020}}</ref>
<ref name="E0Tsg">{{cite web|url=https://bit-tech.net/reviews/tech/graphics/sapphire-radeon-rx-5700-xt-pulse-review/1/|title=Sapphire Radeon RX 5700 XT Pulse Review {{!}} bit-tech.net|website=bit-tech.net|language=en|access-date=2019-08-26}}</ref> <ref name="E0Tsg">{{cite web|url=https://bit-tech.net/reviews/tech/graphics/sapphire-radeon-rx-5700-xt-pulse-review/1/|title=Sapphire Radeon RX 5700 XT Pulse Review {{!}} bit-tech.net|website=bit-tech.net|language=en|access-date=2019-08-26}}</ref>
<ref name="mAt96">{{cite web|url=http://xfxforce.com/en-gb/Products/product-category/amd-radeon-rx-5700xt-8gb-thicc-ii-rx-57xt8dfd6|title=AMD Radeon™ RX 5700 XT 8GB GDDR6 THICC II – RX-57XT8DFD6|website=xfxforce.com|access-date=2019-08-25}}</ref> <ref name="mAt96">{{cite web|url=http://xfxforce.com/en-gb/Products/product-category/amd-radeon-rx-5700xt-8gb-thicc-ii-rx-57xt8dfd6|title=AMD Radeon™ RX 5700 XT 8GB GDDR6 THICC II – RX-57XT8DFD6|website=xfxforce.com|access-date=2019-08-25|archive-date=1 September 2019|archive-url=https://web.archive.org/web/20190901193735/http://xfxforce.com/en-gb/Products/product-category/amd-radeon-rx-5700xt-8gb-thicc-ii-rx-57xt8dfd6|url-status=dead}}</ref>
<ref name="kk3xz">{{cite web|url=https://rog.asus.com/graphics-cards/graphics-cards/rog-strix/rog-strix-rtx3080-o10g-gaming-model/spec|title=ROG Strix GeForce RTX 3080 OC Edition 10GB GDDR6X &#124; Graphics Cards|website=rog.asus.com}}</ref> <ref name="kk3xz">{{cite web|url=https://rog.asus.com/graphics-cards/graphics-cards/rog-strix/rog-strix-rtx3080-o10g-gaming-model/spec|title=ROG Strix GeForce RTX 3080 OC Edition 10GB GDDR6X &#124; Graphics Cards|website=rog.asus.com}}</ref>
<ref name="IM1RH">{{cite web| title=What is the A side, B side configuration of PCI cards| work=Frequently Asked Questions| publisher=Adex Electronics| year=1998| url=http://www.adexelec.com/faq.htm#pcikeys| access-date=24 October 2011| url-status=dead| archive-url=https://web.archive.org/web/20111102042843/http://www.adexelec.com/faq.htm#pcikeys| archive-date=2 November 2011}}</ref> <ref name="IM1RH">{{cite web| title=What is the A side, B side configuration of PCI cards| work=Frequently Asked Questions| publisher=Adex Electronics| year=1998| url=http://www.adexelec.com/faq.htm#pcikeys| access-date=24 October 2011| url-status=dead| archive-url=https://web.archive.org/web/20111102042843/http://www.adexelec.com/faq.htm#pcikeys| archive-date=2 November 2011}}</ref>
<ref name="ajnim">{{cite web | title = PCI Express Card Electromechanical Specification Revision 4.0, Version 1.0 (Clean)| url = https://members.pcisig.com/wg/PCI-SIG/document/13446}}</ref> <ref name="ajnim">{{cite web | title = PCI Express Card Electromechanical Specification Revision 4.0, Version 1.0 (Clean)| url = https://members.pcisig.com/wg/PCI-SIG/document/13446}}</ref>
<ref name="vj2hg">{{cite web | url = https://pcisig.com/sites/default/files/specification_documents/ECN_L1_PM_Substates_with_CLKREQ_31_May_2013_Rev10a.pdf | title = L1 PM Substates with CLKREQ, Revision 1.0a | publisher = PCI-SIG | access-date = 2018-11-08}}</ref> <ref name="vj2hg">{{cite web | url = https://pcisig.com/sites/default/files/specification_documents/ECN_L1_PM_Substates_with_CLKREQ_31_May_2013_Rev10a.pdf | title = L1 PM Substates with CLKREQ, Revision 1.0a | publisher = PCI-SIG | archive-url = https://web.archive.org/web/20181204125124/http://pcisig.com/sites/default/files/specification_documents/ECN_L1_PM_Substates_with_CLKREQ_31_May_2013_Rev10a.pdf | archive-date = 2018-12-04 | access-date = 2018-11-08}}</ref>
<ref name="YpQVq">{{cite web | url = https://pcisig.com/sites/default/files/specification_documents/Emergency%20Power%20Reduction%20Mechanism%20with%20PWRBRK%20Signal%20ECN.pdf | title = Emergency Power Reduction Mechanism with PWRBRK Signal ECN | publisher = PCI-SIG | archive-url = https://web.archive.org/web/20181109193739/https://pcisig.com/sites/default/files/specification_documents/Emergency%20Power%20Reduction%20Mechanism%20with%20PWRBRK%20Signal%20ECN.pdf | access-date = 2018-11-08| archive-date = 9 November 2018}}</ref> <ref name="YpQVq">{{cite web | url = https://pcisig.com/sites/default/files/specification_documents/Emergency%20Power%20Reduction%20Mechanism%20with%20PWRBRK%20Signal%20ECN.pdf | title = Emergency Power Reduction Mechanism with PWRBRK Signal ECN | publisher = PCI-SIG | archive-url = https://web.archive.org/web/20181109193739/https://pcisig.com/sites/default/files/specification_documents/Emergency%20Power%20Reduction%20Mechanism%20with%20PWRBRK%20Signal%20ECN.pdf | access-date = 2018-11-08| archive-date = 9 November 2018}}</ref>
<ref name="jArAO">{{Citation |publisher=PCI-SIG |first=Zale |last=Schoenborn |title=Board Design Guidelines for PCI Express Architecture |year=2004 |pages=19–21 |url=http://e2e.ti.com/cfs-file/__key/communityserver-discussions-components-files/639/7851.PCIe_5F00_designGuides.pdf#page=19 |url-status=live |archive-url=https://web.archive.org/web/20160327185412/http://e2e.ti.com/cfs-file/__key/communityserver-discussions-components-files/639/7851.PCIe_5F00_designGuides.pdf#page=19 |archive-date=2016-03-27}}</ref> <ref name="jArAO">{{Citation |publisher=PCI-SIG |first=Zale |last=Schoenborn |title=Board Design Guidelines for PCI Express Architecture |year=2004 |pages=19–21 |url=http://e2e.ti.com/cfs-file/__key/communityserver-discussions-components-files/639/7851.PCIe_5F00_designGuides.pdf#page=19 |url-status=live |archive-url=https://web.archive.org/web/20160327185412/http://e2e.ti.com/cfs-file/__key/communityserver-discussions-components-files/639/7851.PCIe_5F00_designGuides.pdf#page=19 |archive-date=2016-03-27}}</ref>
Line 965: Line 1,013:
<ref name="FZ4hQ">{{cite web|url=https://www.mellanox.com/news/press_release/mellanox-announces-connectx-5-next-generation-100g-infiniband-and-ethernet-smart-interconnect|title=Mellanox Announces ConnectX-5, the Next Generation of 100G InfiniBand and Ethernet Smart Interconnect Adapter &#124; NVIDIA|website=www.mellanox.com}}</ref> <ref name="FZ4hQ">{{cite web|url=https://www.mellanox.com/news/press_release/mellanox-announces-connectx-5-next-generation-100g-infiniband-and-ethernet-smart-interconnect|title=Mellanox Announces ConnectX-5, the Next Generation of 100G InfiniBand and Ethernet Smart Interconnect Adapter &#124; NVIDIA|website=www.mellanox.com}}</ref>
<ref name="zovf4">{{cite web|url=https://www.mellanox.com/news/press_release/mellanox-announces-200gbs-hdr-infiniband-solutions-enabling-record-levels-performance-and|title=Mellanox Announces 200Gb/s HDR InfiniBand Solutions Enabling Record Levels of Performance and Scalability &#124; NVIDIA|website=www.mellanox.com}}</ref> <ref name="zovf4">{{cite web|url=https://www.mellanox.com/news/press_release/mellanox-announces-200gbs-hdr-infiniband-solutions-enabling-record-levels-performance-and|title=Mellanox Announces 200Gb/s HDR InfiniBand Solutions Enabling Record Levels of Performance and Scalability &#124; NVIDIA|website=www.mellanox.com}}</ref>
<ref name="2HOSh">{{cite web|url=https://www-03.ibm.com/press/us/en/pressrelease/53452.wss|title=IBM Unveils Most Advanced Server for AI|date=December 5, 2017|website=www-03.ibm.com}}</ref> <ref name="2HOSh">{{cite web|url=https://www-03.ibm.com/press/us/en/pressrelease/53452.wss|archive-url=https://web.archive.org/web/20171208002632/http://www-03.ibm.com/press/us/en/pressrelease/53452.wss|url-status=dead|archive-date=8 December 2017|title=IBM Unveils Most Advanced Server for AI|date=December 5, 2017|website=www-03.ibm.com}}</ref>
<ref name="ChNhD">{{Cite news|url=https://www.netint.ca/blog/netint-introduces-codensity-with-support-for-pcie-4-0/|title=NETINT Introduces Codensity with Support for PCIe 4.0 – NETINT Technologies|date=2018-07-17|work=NETINT Technologies|access-date=2018-09-28|language=en-US}}</ref> <ref name="ChNhD">{{Cite news|url=https://www.netint.ca/blog/netint-introduces-codensity-with-support-for-pcie-4-0/|title=NETINT Introduces Codensity with Support for PCIe 4.0 – NETINT Technologies|date=2018-07-17|work=NETINT Technologies|access-date=2018-09-28|language=en-US|archive-date=29 September 2018|archive-url=https://web.archive.org/web/20180929041113/https://www.netint.ca/blog/netint-introduces-codensity-with-support-for-pcie-4-0/|url-status=dead}}</ref>
<ref name="Akskd">{{cite web|url=https://wccftech.com/amd-ryzen-3000-zen-2-desktop-am4-processors-launching-mid-2019/|title=AMD Ryzen 3000 Series CPUs Based on Zen 2 Launching in Mid of 2019|first=Hassan|last=Mujtaba|date=January 9, 2019}}</ref> <ref name="Akskd">{{cite web|url=https://wccftech.com/amd-ryzen-3000-zen-2-desktop-am4-processors-launching-mid-2019/|title=AMD Ryzen 3000 Series CPUs Based on Zen 2 Launching in Mid of 2019|first=Hassan|last=Mujtaba|date=January 9, 2019}}</ref>
<ref name="KDBMK">{{cite web|url=https://www.tomshardware.com/news/amd-pcie-4.0-socket-am4-motherboard,39559.html|title=AMD Nixes PCIe 4.0 Support on Older Socket AM4 Motherboards, Here's Why|last=Alcorn|first=Paul|date=3 June 2019|website=Tom's Hardware|archive-url=https://archive.today/20190610025155/https://www.tomshardware.com/news/amd-pcie-4.0-socket-am4-motherboard,39559.html|archive-date=10 June 2019|url-status=live|access-date=10 June 2019}}</ref> <ref name="KDBMK">{{cite web|url=https://www.tomshardware.com/news/amd-pcie-4.0-socket-am4-motherboard,39559.html|title=AMD Nixes PCIe 4.0 Support on Older Socket AM4 Motherboards, Here's Why|last=Alcorn|first=Paul|date=3 June 2019|website=Tom's Hardware|archive-url=https://archive.today/20190610025155/https://www.tomshardware.com/news/amd-pcie-4.0-socket-am4-motherboard,39559.html|archive-date=10 June 2019|url-status=live|access-date=10 June 2019}}</ref>
Line 978: Line 1,026:
<ref name="O5gOe">{{cite web|url=https://www.anandtech.com/show/14559/pci-express-bandwidth-to-be-doubled-again-pcie-60-announced-spec-to-land-in-2021|title=PCI Express Bandwidth to Be Doubled Again: PCIe 6.0 Announced, Spec to Land in 2021|first=Ryan|last=Smith|website=www.anandtech.com}}</ref> <ref name="O5gOe">{{cite web|url=https://www.anandtech.com/show/14559/pci-express-bandwidth-to-be-doubled-again-pcie-60-announced-spec-to-land-in-2021|title=PCI Express Bandwidth to Be Doubled Again: PCIe 6.0 Announced, Spec to Land in 2021|first=Ryan|last=Smith|website=www.anandtech.com}}</ref>
<ref name="puGmx">{{cite web|url=https://www.phoronix.com/scan.php?page=news_item&px=PCI-Express-6.0-v0.5|title=PCI Express 6.0 Reaches Version 0.5 Ahead Of Finalization Next Year – Phoronix|website=www.phoronix.com}}</ref> <ref name="puGmx">{{cite web|url=https://www.phoronix.com/scan.php?page=news_item&px=PCI-Express-6.0-v0.5|title=PCI Express 6.0 Reaches Version 0.5 Ahead Of Finalization Next Year – Phoronix|website=www.phoronix.com}}</ref>
<ref name="ltCSi">{{cite web |last1=Shilov |first1=Anton |title=PCIe 6.0 Specification Hits Milestone: Complete Draft Is Ready |url=https://www.tomshardware.com/news/pcie-6-specification-hits-milestone-complete-draft-is-ready |website=Tom's Hardware |date=4 November 2020 |publisher=Tom's Hardware |access-date=5 November 2020}}</ref> <ref name="ltCSi">{{cite web |last1=Shilov |first1=Anton |title=PCIe 6.0 Specification Hits Milestone: Complete Draft Is Ready |url=https://www.tomshardware.com/news/pcie-6-specification-hits-milestone-complete-draft-is-ready |website=Tom's Hardware |date=4 November 2020 |publisher= |access-date=}}</ref>
<ref name="g6np3">{{cite web |title=PCIe Active Optical Cable System |url=http://www.samtec.com/cable-systems/active-optics/active-optical-cable/pcie.aspx |access-date=23 October 2015 |url-status=live |archive-url=https://web.archive.org/web/20141230122105/http://www.samtec.com/cable-systems/active-optics/active-optical-cable/pcie.aspx |archive-date=30 December 2014}}</ref> <ref name="g6np3">{{cite web |title=PCIe Active Optical Cable System |url=http://www.samtec.com/cable-systems/active-optics/active-optical-cable/pcie.aspx |access-date=23 October 2015 |url-status=live |archive-url=https://web.archive.org/web/20141230122105/http://www.samtec.com/cable-systems/active-optics/active-optical-cable/pcie.aspx |archive-date=30 December 2014}}</ref>
<ref name="kZCuH">{{cite magazine |url=https://www.pcworld.com/article/240013/acer_asus_to_bring_intels_thunderbolt_speed_technology_to_windows_pcs.html |title=Acer, Asus to Bring Intel's Thunderbolt Speed Technology to Windows PCs |magazine=PC World |date=2011-09-14 |access-date=2012-12-07 |url-status=live |archive-url=https://web.archive.org/web/20120118190546/http://www.pcworld.com/article/240013/acer_asus_to_bring_intels_thunderbolt_speed_technology_to_windows_pcs.html |archive-date=2012-01-18}}</ref> <ref name="kZCuH">{{cite magazine |url=https://www.pcworld.com/article/240013/acer_asus_to_bring_intels_thunderbolt_speed_technology_to_windows_pcs.html |title=Acer, Asus to Bring Intel's Thunderbolt Speed Technology to Windows PCs |magazine=PC World |date=2011-09-14 |access-date=2012-12-07 |url-status=live |archive-url=https://web.archive.org/web/20120118190546/http://www.pcworld.com/article/240013/acer_asus_to_bring_intels_thunderbolt_speed_technology_to_windows_pcs.html |archive-date=2012-01-18}}</ref>
Line 985: Line 1,033:
<ref name="9tQ3g">{{cite web |url=http://pinouts.ru/Slots/pci_express_pinout.shtml |title=PCI Express 1x, 4x, 8x, 16x bus pinout and wiring @ |publisher=Pinouts |location=] |access-date=2009-12-07 |url-status=live |archive-url=https://web.archive.org/web/20091125025800/http://pinouts.ru/Slots/pci_express_pinout.shtml |archive-date=2009-11-25}}</ref> <ref name="9tQ3g">{{cite web |url=http://pinouts.ru/Slots/pci_express_pinout.shtml |title=PCI Express 1x, 4x, 8x, 16x bus pinout and wiring @ |publisher=Pinouts |location=] |access-date=2009-12-07 |url-status=live |archive-url=https://web.archive.org/web/20091125025800/http://pinouts.ru/Slots/pci_express_pinout.shtml |archive-date=2009-11-25}}</ref>
<ref name="vV4Hv"></ref> <ref name="vV4Hv"></ref>
<ref name="iPAaS">''PCI EXPRESS BASE SPECIFICATION, REV. 3.0'' Table 4-24</ref> <ref name="iPAaS">''PCI Express Base Specification, Revision 3.0'' Table 4-24</ref>
<!-- <ref name="EVn7L">{{Cite web|url=http://www.playtool.com/pages/psuconnectors/connectors.html#pciexpress8|title=All about the various PC power supply cables and connectors|website=www.playtool.com|access-date=2018-11-10}}</ref> --> <!-- <ref name="EVn7L">{{Cite web|url=http://www.playtool.com/pages/psuconnectors/connectors.html#pciexpress8|title=All about the various PC power supply cables and connectors|website=www.playtool.com|access-date=2018-11-10}}</ref> -->
<ref name="gxHZT">{{cite web|url=http://www.nvidia.com/object/IO_34527.html|title=NVIDIA Introduces NVIDIA Quadro® Plex – A Quantum Leap in Visual Computing|date=2006-08-01|website=Nvidia|archive-url=https://web.archive.org/web/20060824225752/http://www.nvidia.com/object/IO_34527.html|archive-date=2006-08-24|url-status=live|access-date=2018-07-14}}</ref> <ref name="gxHZT">{{cite web|url=http://www.nvidia.com/object/IO_34527.html|title=NVIDIA Introduces NVIDIA Quadro® Plex – A Quantum Leap in Visual Computing|date=2006-08-01|website=Nvidia|archive-url=https://web.archive.org/web/20060824225752/http://www.nvidia.com/object/IO_34527.html|archive-date=2006-08-24|url-status=live|access-date=2018-07-14}}</ref>
Line 1,012: Line 1,060:
<ref name="aJ00L">{{cite web|url=https://www.anandtech.com/show/14068/cxl-specification-1-released-new-industry-high-speed-interconnect-from-intel|title=CXL Specification 1.0 Released: New Industry High-Speed Interconnect From Intel|last=Cutress|first=Ian|website=www.anandtech.com|access-date=2019-08-09}}</ref> <ref name="aJ00L">{{cite web|url=https://www.anandtech.com/show/14068/cxl-specification-1-released-new-industry-high-speed-interconnect-from-intel|title=CXL Specification 1.0 Released: New Industry High-Speed Interconnect From Intel|last=Cutress|first=Ian|website=www.anandtech.com|access-date=2019-08-09}}</ref>
<ref name="9ps7Q">{{cite web|url=http://pcisig.com/developers/integrators-list|title=Integrators List {{!}} PCI-SIG|website=pcisig.com|access-date=2019-03-27}}</ref> <ref name="9ps7Q">{{cite web|url=http://pcisig.com/developers/integrators-list|title=Integrators List {{!}} PCI-SIG|website=pcisig.com|access-date=2019-03-27}}</ref>
<ref name="Syn50">{{cite web|url=https://blogs.synopsys.com/expressyourself/2017/08/15/1-2-3-4-5-its-official-pcie-5-0-is-announced | title = 1,2,3,4,5... It's Official, PCIe 5.0 is Announced {{!}} synopsys.com|website=www.synopsys.com|language=en| access-date=2017-06-07 | url-status = live}}</ref> <ref name="Syn50">{{cite web|url=https://blogs.synopsys.com/expressyourself/2017/08/15/1-2-3-4-5-its-official-pcie-5-0-is-announced | title = 1,2,3,4,5... It's Official, PCIe 5.0 is Announced {{!}} synopsys.com|website=www.synopsys.com|language=en| access-date=2017-06-07 }}</ref>
<ref name="PCIe70v05">{{cite web|url=https://pcisig.com/blog/pcie%C2%AE-70-specification-version-05-now-available-full-draft-available-members | title = PCIe® 7.0 Specification, Version 0.5 Now Available: Full Draft Available to Members|website=pcisig.com|language=en|access-date=2024-04-03}}</ref>
}} }}



== Further reading == == Further reading ==
Line 1,022: Line 1,072:


==External links== ==External links==
* {{commonscatinline}} * {{commons category-inline}}
* *
<!-- WARNING: Do NOT post links to any pirated specs. See DMCA take-down notice at ] --> <!-- WARNING: Do NOT post links to any pirated specs. See DMCA take-down notice at ] -->

Latest revision as of 13:51, 12 January 2025

Computer expansion bus standard Not to be confused with PCI-X or UCIe. For Engineering, Procurement, Construction and Installation, see EPCI.

PCI Express
Peripheral Component Interconnect Express
LogoLogo
Year created2003; 22 years ago (2003)
Created by
Supersedes
Width in bits1 per lane (up to 16 lanes)
No. of devices1 on each endpoint of each connection.
SpeedDual simplex, up to 242 GB/s
StyleSerial
Hotplugging interfaceOptional (support with ExpressCard, OCuLink, CFexpress or U.2)
External interfaceOptional (support with OCuLink or PCI Express External Cabling)
Websitepcisig.com
Two types of PCIe slot on an Asus H81M-K motherboard
Various slots on a computer motherboard, from top to bottom:
  • PCI Express x4
  • PCI Express x16
  • PCI Express x1
  • PCI Express x16
  • Conventional PCI (32-bit, 5 V)

PCI Express (Peripheral Component Interconnect Express), officially abbreviated as PCIe or PCI-E, is a high-speed serial computer expansion bus standard, meant to replace the older PCI, PCI-X and AGP bus standards. It is the common motherboard interface for personal computers' graphics cards, capture cards, sound cards, hard disk drive host adapters, SSDs, Wi-Fi, and Ethernet hardware connections. PCIe has numerous improvements over the older standards, including higher maximum system bus throughput, lower I/O pin count, smaller physical footprint, better performance scaling for bus devices, a more detailed error detection and reporting mechanism (Advanced Error Reporting, AER), and native hot-swap functionality. More recent revisions of the PCIe standard provide hardware support for I/O virtualization.

The PCI Express electrical interface is measured by the number of simultaneous lanes. (A lane is a single send/receive line of data, analogous to a "one-lane road" having one lane of traffic in both directions.) The interface is also used in a variety of other standards — most notably the laptop expansion card interface called ExpressCard. It is also used in the storage interfaces of SATA Express, U.2 (SFF-8639) and M.2.

Formal specifications are maintained and developed by the PCI-SIG (PCI Special Interest Group) — a group of more than 900 companies that also maintains the conventional PCI specifications.

Architecture

Example of the PCI Express topology:
white "junction boxes" represent PCI Express device downstream ports, while the gray ones represent upstream ports.
PCI Express x1 card containing a PCI Express switch (covered by a small heat sink), which creates multiple endpoints out of one endpoint and lets multiple devices share it
The PCIe slots on a motherboard are often labeled with the number of PCIe lanes they have. Sometimes what may seem like a large slot may only have a few lanes. For instance, a x16 slot with only 4 PCIe lanes (bottom slot) is quite common.

Conceptually, the PCI Express bus is a high-speed serial replacement of the older PCI/PCI-X bus. One of the key differences between the PCI Express bus and the older PCI is the bus topology; PCI uses a shared parallel bus architecture, in which the PCI host and all devices share a common set of address, data, and control lines. In contrast, PCI Express is based on point-to-point topology, with separate serial links connecting every device to the root complex (host). Because of its shared bus topology, access to the older PCI bus is arbitrated (in the case of multiple masters), and limited to one master at a time, in a single direction. Furthermore, the older PCI clocking scheme limits the bus clock to the slowest peripheral on the bus (regardless of the devices involved in the bus transaction). In contrast, a PCI Express bus link supports full-duplex communication between any two endpoints, with no inherent limitation on concurrent access across multiple endpoints.

In terms of bus protocol, PCI Express communication is encapsulated in packets. The work of packetizing and de-packetizing data and status-message traffic is handled by the transaction layer of the PCI Express port (described later). Radical differences in electrical signaling and bus protocol require the use of a different mechanical form factor and expansion connectors (and thus, new motherboards and new adapter boards); PCI slots and PCI Express slots are not interchangeable. At the software level, PCI Express preserves backward compatibility with PCI; legacy PCI system software can detect and configure newer PCI Express devices without explicit support for the PCI Express standard, though new PCI Express features are inaccessible.

The PCI Express link between two devices can vary in size from one to 16 lanes. In a multi-lane link, the packet data is striped across lanes, and peak data throughput scales with the overall link width. The lane count is automatically negotiated during device initialization and can be restricted by either endpoint. For example, a single-lane PCI Express (x1) card can be inserted into a multi-lane slot (x4, x8, etc.), and the initialization cycle auto-negotiates the highest mutually supported lane count. The link can dynamically down-configure itself to use fewer lanes, providing a failure tolerance in case bad or unreliable lanes are present. The PCI Express standard defines link widths of x1, x2, x4, x8, and x16. Up to and including PCIe 5.0, x12, and x32 links were defined as well but never used. This allows the PCI Express bus to serve both cost-sensitive applications where high throughput is not needed, and performance-critical applications such as 3D graphics, networking (10 Gigabit Ethernet or multiport Gigabit Ethernet), and enterprise storage (SAS or Fibre Channel). Slots and connectors are only defined for a subset of these widths, with link widths in between using the next larger physical slot size.

As a point of reference, a PCI-X (133 MHz 64-bit) device and a PCI Express 1.0 device using four lanes (x4) have roughly the same peak single-direction transfer rate of 1064 MB/s. The PCI Express bus has the potential to perform better than the PCI-X bus in cases where multiple devices are transferring data simultaneously, or if communication with the PCI Express peripheral is bidirectional.

Interconnect

A PCI Express link between two devices consists of one or more lanes, which are dual simplex channels using two differential signaling pairs.

PCI Express devices communicate via a logical connection called an interconnect or link. A link is a point-to-point communication channel between two PCI Express ports allowing both of them to send and receive ordinary PCI requests (configuration, I/O or memory read/write) and interrupts (INTx, MSI or MSI-X). At the physical level, a link is composed of one or more lanes. Low-speed peripherals (such as an 802.11 Wi-Fi card) use a single-lane (x1) link, while a graphics adapter typically uses a much wider and therefore faster 16-lane (x16) link.

Lane

A lane is composed of two differential signaling pairs, with one pair for receiving data and the other for transmitting. Thus, each lane is composed of four wires or signal traces. Conceptually, each lane is used as a full-duplex byte stream, transporting data packets in eight-bit "byte" format simultaneously in both directions between endpoints of a link. Physical PCI Express links may contain 1, 4, 8 or 16 lanes. Lane counts are written with an "x" prefix (for example, "x8" represents an eight-lane card or slot), with x16 being the largest size in common use. Lane sizes are also referred to via the terms "width" or "by" e.g., an eight-lane slot could be referred to as a "by 8" or as "8 lanes wide."

For mechanical card sizes, see below.

Serial bus

This section does not cite any sources. Please help improve this section by adding citations to reliable sources. Unsourced material may be challenged and removed. (March 2018) (Learn how and when to remove this message)

The bonded serial bus architecture was chosen over the traditional parallel bus because of the inherent limitations of the latter, including half-duplex operation, excess signal count, and inherently lower bandwidth due to timing skew. Timing skew results from separate electrical signals within a parallel interface traveling through conductors of different lengths, on potentially different printed circuit board (PCB) layers, and at possibly different signal velocities. Despite being transmitted simultaneously as a single word, signals on a parallel interface have different travel duration and arrive at their destinations at different times. When the interface clock period is shorter than the largest time difference between signal arrivals, recovery of the transmitted word is no longer possible. Since timing skew over a parallel bus can amount to a few nanoseconds, the resulting bandwidth limitation is in the range of hundreds of megahertz.

Highly simplified topologies of the Legacy PCI Shared (Parallel) Interface and the PCIe Serial Point-to-Point Interface

A serial interface does not exhibit timing skew because there is only one differential signal in each direction within each lane, and there is no external clock signal since clocking information is embedded within the serial signal itself. As such, typical bandwidth limitations on serial signals are in the multi-gigahertz range. PCI Express is one example of the general trend toward replacing parallel buses with serial interconnects; other examples include Serial ATA (SATA), USB, Serial Attached SCSI (SAS), FireWire (IEEE 1394), and RapidIO. In digital video, examples in common use are DVI, HDMI, and DisplayPort.

Multichannel serial design increases flexibility with its ability to allocate fewer lanes for slower devices.

Form factors

PCI Express (standard)

Intel P3608 NVMe flash SSD, PCIe add-in card

A PCI Express card fits into a slot of its physical size or larger (with x16 as the largest used), but may not fit into a smaller PCI Express slot; for example, a x16 card may not fit into a x4 or x8 slot. Some slots use open-ended sockets to permit physically longer cards and negotiate the best available electrical and logical connection.

The number of lanes actually connected to a slot may also be fewer than the number supported by the physical slot size. An example is a x16 slot that runs at x4, which accepts any x1, x2, x4, x8 or x16 card, but provides only four lanes. Its specification may read as "x16 (x4 mode)", while "mechanical @ electrical" notation (e.g. "x16 @ x4") is also common. The advantage is that such slots can accommodate a larger range of PCI Express cards without requiring motherboard hardware to support the full transfer rate. Standard mechanical sizes are x1, x4, x8, and x16. Cards using a number of lanes other than the standard mechanical sizes need to physically fit the next larger mechanical size (e.g. an x2 card uses the x4 size, or an x12 card uses the x16 size).

The cards themselves are designed and manufactured in various sizes. For example, solid-state drives (SSDs) that come in the form of PCI Express cards often use HHHL (half height, half length) and FHHL (full height, half length) to describe the physical dimensions of the card.

PCI card type Dimensions height × length × width, maximum
(mm) (in)
Full-Length 111.15 × 312.00 × 20.32 4.376 × 12.283 × 0.8
Half-Length 111.15 × 167.65 × 20.32 4.376 × 06.600 × 0.8
Low-Profile/Slim 068.90 × 167.65 × 20.32 2.731 × 06.600 × 0.8

Non-standard video card form factors

Modern (since c. 2012) gaming video cards usually exceed the height as well as thickness specified in the PCI Express standard, due to the need for more capable and quieter cooling fans, as gaming video cards often emit hundreds of watts of heat. Modern computer cases are often wider to accommodate these taller cards, but not always. Since full-length cards (312 mm) are uncommon, modern cases sometimes cannot fit those. The thickness of these cards also typically occupies the space of 2 to 5 PCIe slots. In fact, even the methodology of how to measure the cards varies between vendors, with some including the metal bracket size in dimensions and others not.

For instance, comparing three high-end video cards released in 2020: a Sapphire Radeon RX 5700 XT card measures 135 mm in height (excluding the metal bracket), which exceeds the PCIe standard height by 28 mm, another Radeon RX 5700 XT card by XFX measures 55 mm thick (i.e. 2.7 PCI slots at 20.32 mm), taking up 3 PCIe slots, while an Asus GeForce RTX 3080 video card takes up two slots and measures 140.1 mm × 318.5 mm × 57.8 mm, exceeding PCI Express's maximum height, length, and thickness respectively.

Pinout

The following table identifies the conductors on each side of the edge connector on a PCI Express card. The solder side of the printed circuit board (PCB) is the A-side, and the component side is the B-side. PRSNT1# and PRSNT2# pins must be slightly shorter than the rest, to ensure that a hot-plugged card is fully inserted. The WAKE# pin uses full voltage to wake the computer, but must be pulled high from the standby power to indicate that the card is wake capable.

PCI Express connector pinout (x1, x4, x8 and x16 variants)
Pin Side B Side A Description Pin Side B Side A Description
01 +12 V PRSNT1# Must connect to farthest PRSNT2# pin 50 HSOp(8) Reserved Lane 8 transmit data, + and −
02 +12 V +12 V Main power pins 51 HSOn(8) Ground
03 +12 V +12 V 52 Ground HSIp(8) Lane 8 receive data, + and −
04 Ground Ground 53 Ground HSIn(8)
05 SMCLK TCK SMBus and JTAG port pins 54 HSOp(9) Ground Lane 9 transmit data, + and −
06 SMDAT TDI 55 HSOn(9) Ground
07 Ground TDO 56 Ground HSIp(9) Lane 9 receive data, + and −
08 +3.3 V TMS 57 Ground HSIn(9)
09 TRST# +3.3 V 58 HSOp(10) Ground Lane 10 transmit data, + and −
10 +3.3 V aux +3.3 V Aux power & Standby power 59 HSOn(10) Ground
11 WAKE# PERST# Link reactivation; fundamental reset 60 Ground HSIp(10) Lane 10 receive data, + and −
Key notch 61 Ground HSIn(10)
12 CLKREQ# Ground Clock Request Signal 62 HSOp(11) Ground Lane 11 transmit data, + and −
13 Ground REFCLK+ Reference clock differential pair 63 HSOn(11) Ground
14 HSOp(0) REFCLK− Lane 0 transmit data, + and − 64 Ground HSIp(11) Lane 11 receive data, + and −
15 HSOn(0) Ground 65 Ground HSIn(11)
16 Ground HSIp(0) Lane 0 receive data, + and − 66 HSOp(12) Ground Lane 12 transmit data, + and −
17 PRSNT2# HSIn(0) 67 HSOn(12) Ground
18 Ground Ground 68 Ground HSIp(12) Lane 12 receive data, + and −
PCI Express x1 cards end at pin 18 69 Ground HSIn(12)
19 HSOp(1) Reserved Lane 1 transmit data, + and − 70 HSOp(13) Ground Lane 13 transmit data, + and −
20 HSOn(1) Ground 71 HSOn(13) Ground
21 Ground HSIp(1) Lane 1 receive data, + and − 72 Ground HSIp(13) Lane 13 receive data, + and −
22 Ground HSIn(1) 73 Ground HSIn(13)
23 HSOp(2) Ground Lane 2 transmit data, + and − 74 HSOp(14) Ground Lane 14 transmit data, + and −
24 HSOn(2) Ground 75 HSOn(14) Ground
25 Ground HSIp(2) Lane 2 receive data, + and − 76 Ground HSIp(14) Lane 14 receive data, + and −
26 Ground HSIn(2) 77 Ground HSIn(14)
27 HSOp(3) Ground Lane 3 transmit data, + and − 78 HSOp(15) Ground Lane 15 transmit data, + and −
28 HSOn(3) Ground 79 HSOn(15) Ground
29 Ground HSIp(3) Lane 3 receive data, + and −
"Power brake", active-low to reduce device power
80 Ground HSIp(15) Lane 15 receive data, + and −
30 PWRBRK# HSIn(3) 81 PRSNT2# HSIn(15)
31 PRSNT2# Ground 82 Reserved Ground
32 Ground Reserved
PCI Express x4 cards end at pin 32
33 HSOp(4) Reserved Lane 4 transmit data, + and −
34 HSOn(4) Ground
35 Ground HSIp(4) Lane 4 receive data, + and −
36 Ground HSIn(4)
37 HSOp(5) Ground Lane 5 transmit data, + and −
38 HSOn(5) Ground
39 Ground HSIp(5) Lane 5 receive data, + and −
40 Ground HSIn(5)
41 HSOp(6) Ground Lane 6 transmit data, + and −
42 HSOn(6) Ground
43 Ground HSIp(6) Lane 6 receive data, + and − Legend
44 Ground HSIn(6) Ground pin Zero volt reference
45 HSOp(7) Ground Lane 7 transmit data, + and − Power pin Supplies power to the PCIe card
46 HSOn(7) Ground Card-to-host pin Signal from the card to the motherboard
47 Ground HSIp(7) Lane 7 receive data, + and − Host-to-card pin Signal from the motherboard to the card
48 PRSNT2# HSIn(7) Open drain May be pulled low or sensed by multiple cards
49 Ground Ground Sense pin Tied together on card
PCI Express x8 cards end at pin 49 Reserved Not presently used, do not connect

Power

The main 12 V power supply for the PCIe slot is pins B2, B3 (side B) and pins A2, A3 (side A). Power standby 3.3 V is pin B10 and A10. PCIe x1 cards can receive up to 25 W and x16 graphics cards can receive up to 75 W, combined.
Slot power

All PCI express cards may consume up to 3 A at +3.3 V (9.9 W). The amount of +12 V and total power they may consume depends on the form factor and the role of the card:

  • x1 cards are limited to 0.5 A at +12 V (6 W) and 10 W combined.
  • x4 and wider cards are limited to 2.1 A at +12 V (25 W) and 25 W combined.
  • A full-sized x1 card may draw up to the 25 W limits after initialization and software configuration as a high-power device.
  • A full-sized x16 graphics card may draw up to 5.5 A at +12 V (66 W) and 75 W combined after initialization and software configuration as a high-power device.
6- and 8-pin power connectors
8-pin (left) and 6-pin (right) power connectors used on PCI Express cards

Optional connectors add 75 W (6-pin) or 150 W (8-pin) of +12 V power for up to 300 W total (2 × 75 W + 1 × 150 W).

  • Sense0 pin is connected to ground by the cable or power supply, or float on board if cable is not connected.
  • Sense1 pin is connected to ground by the cable or power supply, or float on board if cable is not connected.

Some cards use two 8-pin connectors, but this has not been standardized yet as of 2018, therefore such cards must not carry the official PCI Express logo. This configuration allows 375 W total (1 × 75 W + 2 × 150 W) and will likely be standardized by PCI-SIG with the PCI Express 4.0 standard. The 8-pin PCI Express connector could be confused with the EPS12V connector, which is mainly used for powering SMP and multi-core systems. The power connectors are variants of the Molex Mini-Fit Jr. series connectors.

Molex Mini-Fit Jr. part numbers
Pins Female/receptacle
on PS cable
Male/right-angle
header on PCB
6-pin 45559-0002 45558-0003
8-pin 45587-0004 45586-0005, 45586-0006
6-pin power connector (75 W) 8-pin power connector (150 W)
6 pin power connector pin map
8 pin power connector pin map
Pin Description Pin Description
1 +12 V 1 +12 V
2 Not connected (usually +12 V as well) 2 +12 V
3 +12 V 3 +12 V
4 Sense1 (8-pin connected)
4 Ground 5 Ground
5 Sense 6 Sense0 (6-pin or 8-pin connected)
6 Ground 7 Ground
8 Ground
  1. When a 6-pin connector is plugged into an 8-pin receptacle the card is notified by a missing Sense1 that it may only use up to 75 W.
12VHPWR connector
This section is an excerpt from 16-pin 12VHPWR connector.
12VHPWR adapter (12VHPWR output on the left, four 8-pin inputs on the right) supplied with Nvidia RTX 4090 cards

The 16-pin 12VHPWR connector is a standard for connecting graphics processing units (GPUs) to computer power supplies for up to 600 W power delivery. It was introduced in 2022 to supersede the previous 6- and 8-pin power connectors for GPUs. The primary aim was to cater to the increasing power requirements of high-performance GPUs. The connector was formally adopted as part of PCI Express 5.

The connector was replaced by a minor revision called 12V-2x6 (H++), introduced in 2023, which changed the GPU- and PSU-side connectors to ensure that the sense pins only make contact if the power pins are seated properly. The cables and their connectors remained unchanged.

PCI Express Mini Card

A WLAN PCI Express Mini Card and its connector
MiniPCI and MiniPCI Express cards in comparison

PCI Express Mini Card (also known as Mini PCI Express, Mini PCIe, Mini PCI-E, mPCIe, and PEM), based on PCI Express, is a replacement for the Mini PCI form factor. It is developed by the PCI-SIG. The host device supports both PCI Express and USB 2.0 connectivity, and each card may use either standard. Most laptop computers built after 2005 use PCI Express for expansion cards; however, as of 2015, many vendors are moving toward using the newer M.2 form factor for this purpose.

Due to different dimensions, PCI Express Mini Cards are not physically compatible with standard full-size PCI Express slots; however, passive adapters exist that let them be used in full-size slots.

Physical dimensions

Dimensions of PCI Express Mini Cards are 30 mm × 50.95 mm (width × length) for a Full Mini Card. There is a 52-pin edge connector, consisting of two staggered rows on a 0.8 mm pitch. Each row has eight contacts, a gap equivalent to four contacts, then a further 18 contacts. Boards have a thickness of 1.0 mm, excluding the components. A "Half Mini Card" (sometimes abbreviated as HMC) is also specified, having approximately half the physical length of 26.8 mm. There are also half size mini PCIe cards that are 30 x 31.90 mm which is about half the length of a full size mini PCIe card.

Electrical interface

PCI Express Mini Card edge connectors provide multiple connections and buses:

  • PCI Express x1 (with SMBus)
  • USB 2.0
  • Wires to diagnostics LEDs for wireless network (i.e., Wi-Fi) status on computer's chassis
  • SIM card for GSM and WCDMA applications (UIM signals on spec.)
  • Future extension for another PCIe lane
  • 1.5 V and 3.3 V power

Mini-SATA (mSATA) variant

An Intel mSATA SSD

Despite sharing the Mini PCI Express form factor, an mSATA slot is not necessarily electrically compatible with Mini PCI Express. For this reason, only certain notebooks are compatible with mSATA drives. Most compatible systems are based on Intel's Sandy Bridge processor architecture, using the Huron River platform. Notebooks such as Lenovo's ThinkPad T, W and X series, released in March–April 2011, have support for an mSATA SSD card in their WWAN card slot. The ThinkPad Edge E220s/E420s, and the Lenovo IdeaPad Y460/Y560/Y570/Y580 also support mSATA. On the contrary, the L-series among others can only support M.2 cards using the PCIe standard in the WWAN slot.

Some notebooks (notably the Asus Eee PC, the Apple MacBook Air, and the Dell mini9 and mini10) use a variant of the PCI Express Mini Card as an SSD. This variant uses the reserved and several non-reserved pins to implement SATA and IDE interface passthrough, keeping only USB, ground lines, and sometimes the core PCIe x1 bus intact. This makes the "miniPCIe" flash and solid-state drives sold for netbooks largely incompatible with true PCI Express Mini implementations.

Also, the typical Asus miniPCIe SSD is 71 mm long, causing the Dell 51 mm model to often be (incorrectly) referred to as half length. A true 51 mm Mini PCIe SSD was announced in 2009, with two stacked PCB layers that allow for higher storage capacity. The announced design preserves the PCIe interface, making it compatible with the standard mini PCIe slot. No working product has yet been developed.

Intel has numerous desktop boards with the PCIe x1 Mini-Card slot that typically do not support mSATA SSD. A list of desktop boards that natively support mSATA in the PCIe x1 Mini-Card slot (typically multiplexed with a SATA port) is provided on the Intel Support site.

PCI Express M.2

Main article: M.2

M.2 replaces the mSATA standard and Mini PCIe. Computer bus interfaces provided through the M.2 connector are PCI Express 3.0 (up to four lanes), Serial ATA 3.0, and USB 3.0 (a single logical port for each of the latter two). It is up to the manufacturer of the M.2 host or device to choose which interfaces to support, depending on the desired level of host support and device type.

PCI Express External Cabling

PCI Express External Cabling (also known as External PCI Express, Cabled PCI Express, or ePCIe) specifications were released by the PCI-SIG in February 2007.

Standard cables and connectors have been defined for x1, x4, x8, and x16 link widths, with a transfer rate of 250 MB/s per lane. The PCI-SIG also expects the norm to evolve to reach 500 MB/s, as in PCI Express 2.0. An example of the uses of Cabled PCI Express is a metal enclosure, containing a number of PCIe slots and PCIe-to-ePCIe adapter circuitry. This device would not be possible had it not been for the ePCIe specification.

PCI Express OCuLink

OCuLink (standing for "optical-copper link", since Cu is the chemical symbol for copper) is an extension for the "cable version of PCI Express". Version 1.0 of OCuLink, released in Oct 2015, supports up to 4 PCIe 3.0 lanes (3.9 GB/s) over copper cabling; a fiber optic version may appear in the future.

The most recent version of OCuLink, OCuLink-2, supports up to 16 GB/s (PCIe 4.0 x8) while the maximum bandwidth of a USB 4 cable is 10GB/s.

While initially intended for use in laptops for the connection of powerful external GPU boxes, OCuLink's popularity lies primarily in its use for PCIe interconnections in servers, a more prevalent application.

Derivative forms

Numerous other form factors use, or are able to use, PCIe. These include:

  • Low-height card
  • ExpressCard: Successor to the PC Card form factor (with x1 PCIe and USB 2.0; hot-pluggable)
  • PCI Express ExpressModule: A hot-pluggable modular form factor defined for servers and workstations
  • XQD card: A PCI Express-based flash card standard by the CompactFlash Association with x2 PCIe
  • CFexpress card: A PCI Express-based flash card by the CompactFlash Association in three form factors supporting 1 to 4 PCIe lanes
  • SD card: The SD Express bus, introduced in version 7.0 of the SD specification uses a x1 PCIe link
  • XMC: Similar to the CMC/PMC form factor (VITA 42.3)
  • AdvancedTCA: A complement to CompactPCI for larger applications; supports serial based backplane topologies
  • AMC: A complement to the AdvancedTCA specification; supports processor and I/O modules on ATCA boards (x1, x2, x4 or x8 PCIe).
  • FeaturePak: A tiny expansion card format (43 mm × 65 mm) for embedded and small-form-factor applications, which implements two x1 PCIe links on a high-density connector along with USB, I2C, and up to 100 points of I/O
  • Universal IO: A variant from Super Micro Computer Inc designed for use in low-profile rack-mounted chassis. It has the connector bracket reversed so it cannot fit in a normal PCI Express socket, but it is pin-compatible and may be inserted if the bracket is removed.
  • M.2 (formerly known as NGFF)
  • M-PCIe brings PCIe 3.0 to mobile devices (such as tablets and smartphones), over the M-PHY physical layer.
  • U.2 (formerly known as SFF-8639)
  • SlimSAS

The PCIe slot connector can also carry protocols other than PCIe. Some 9xx series Intel chipsets support Serial Digital Video Out, a proprietary technology that uses a slot to transmit video signals from the host CPU's integrated graphics instead of PCIe, using a supported add-in.

The PCIe transaction-layer protocol can also be used over some other interconnects, which are not electrically PCIe:

  • Thunderbolt: A royalty-free interconnect standard by Intel that combines DisplayPort and PCIe protocols in a form factor compatible with Mini DisplayPort. Thunderbolt 3.0 also combines USB 3.1 and uses the USB-C form factor as opposed to Mini DisplayPort.
  • USB4

History and revisions

While in early development, PCIe was initially referred to as HSI (for High Speed Interconnect), and underwent a name change to 3GIO (for 3rd Generation I/O) before finally settling on its PCI-SIG name PCI Express. A technical working group named the Arapaho Work Group (AWG) drew up the standard. For initial drafts, the AWG consisted only of Intel engineers; subsequently, the AWG expanded to include industry partners.

Since, PCIe has undergone several large and smaller revisions, improving on performance and other features.

Comparison table

PCI Express link performance
Version intro-
duced
Line code Transfer rate
(per lane)
Throughput
x1 x2 x4 x8 x16
1.0 2003 NRZ 8b/10b 2.5 GT/s 0.250 GB/s 0.500 GB/s 1.000 GB/s 2.000 GB/s 4.000 GB/s
2.0 2007 5.0 GT/s 0.500 GB/s 1.000 GB/s 2.000 GB/s 4.000 GB/s 8.000 GB/s
3.0 2010 128b/130b 8.0 GT/s 0.985 GB/s 1.969 GB/s 3.938 GB/s 07.877 GB/s 15.754 GB/s
4.0 2017 16.0 GT/s 1.969 GB/s 3.938 GB/s 07.877 GB/s 15.754 GB/s 031.508 GB/s
5.0 2019 32.0 GT/s 3.938 GB/s 07.877 GB/s 15.754 GB/s 31.508 GB/s 63.015 GB/s
6.0 2022 PAM-4
FEC
1b/1b
242B/256B FLIT
64.0 GT/s
32.0 GBd
7.563 GB/s 15.125 GB/s 30.250 GB/s 60.500 GB/s 121.000 GB/s
7.0 2025
(planned)
128.0 GT/s
64.0 GBd
15.125 GB/s 30.250 GB/s 60.500 GB/s 121.000 GB/s 242.000 GB/s
Notes
  1. ^ In each direction (each lane is a dual simplex channel).
  2. Transfer rate refers to the encoded serial bit rate; 2.5 GT/s means 2.5 Gbit/s serial data rate.
  3. Throughput indicates the usable bandwidth (i.e. only including the payload, not the 8b/10b, 128b/130b, or 242B/256B encoding overhead). The PCIe 1.0 transfer rate of 2.5 GT/s per lane means a 2.5 Gbit/s serial bit rate; after applying a 8b/10b encoding, this corresponds to a useful throughput of 2.0 Gbit/s = 250 MB/s.

PCI Express 1.0a

In 2003, PCI-SIG introduced PCIe 1.0a, with a per-lane data rate of 250 MB/s and a transfer rate of 2.5 gigatransfers per second (GT/s).

Transfer rate is expressed in transfers per second instead of bits per second because the number of transfers includes the overhead bits, which do not provide additional throughput; PCIe 1.x uses an 8b/10b encoding scheme, resulting in a 20% (= 2/10) overhead on the raw channel bandwidth. So in the PCIe terminology, transfer rate refers to the encoded bit rate: 2.5 GT/s is 2.5 Gbit/s on the encoded serial link. This corresponds to 2.0 Gbit/s of pre-coded data or 250 MB/s, which is referred to as throughput in PCIe.

PCI Express 1.1

In 2005, PCI-SIG introduced PCIe 1.1. This updated specification includes clarifications and several improvements, but is fully compatible with PCI Express 1.0a. No changes were made to the data rate.

PCI Express 2.0

A PCI Express 2.0 x1 expansion card that provides USB 3.0 connectivity

PCI-SIG announced the availability of the PCI Express Base 2.0 specification on 15 January 2007. The PCIe 2.0 standard doubles the transfer rate compared with PCIe 1.0 to 5 GT/s and the per-lane throughput rises from 250 MB/s to 500 MB/s. Consequently, a 16-lane PCIe connector (x16) can support an aggregate throughput of up to 8 GB/s.

PCIe 2.0 motherboard slots are fully backward compatible with PCIe v1.x cards. PCIe 2.0 cards are also generally backward compatible with PCIe 1.x motherboards, using the available bandwidth of PCI Express 1.1. Overall, graphic cards or motherboards designed for v2.0 work, with the other being v1.1 or v1.0a.

The PCI-SIG also said that PCIe 2.0 features improvements to the point-to-point data transfer protocol and its software architecture.

Intel's first PCIe 2.0 capable chipset was the X38 and boards began to ship from various vendors (Abit, Asus, Gigabyte) as of 21 October 2007. AMD started supporting PCIe 2.0 with its AMD 700 chipset series and nVidia started with the MCP72. All of Intel's prior chipsets, including the Intel P35 chipset, supported PCIe 1.1 or 1.0a.

Like 1.x, PCIe 2.0 uses an 8b/10b encoding scheme, therefore delivering, per-lane, an effective 4 Gbit/s max. transfer rate from its 5 GT/s raw data rate.

PCI Express 2.1

PCI Express 2.1 (with its specification dated 4 March 2009) supports a large proportion of the management, support, and troubleshooting systems planned for full implementation in PCI Express 3.0. However, the speed is the same as PCI Express 2.0. The increase in power from the slot breaks backward compatibility between PCI Express 2.1 cards and some older motherboards with 1.0/1.0a, but most motherboards with PCI Express 1.1 connectors are provided with a BIOS update by their manufacturers through utilities to support backward compatibility of cards with PCIe 2.1.

PCI Express 3.0

PCI Express 3.0 Base specification revision 3.0 was made available in November 2010, after multiple delays. In August 2007, PCI-SIG announced that PCI Express 3.0 would carry a bit rate of 8 gigatransfers per second (GT/s), and that it would be backward compatible with existing PCI Express implementations. At that time, it was also announced that the final specification for PCI Express 3.0 would be delayed until Q2 2010. New features for the PCI Express 3.0 specification included a number of optimizations for enhanced signaling and data integrity, including transmitter and receiver equalization, PLL improvements, clock data recovery, and channel enhancements of currently supported topologies.

Following a six-month technical analysis of the feasibility of scaling the PCI Express interconnect bandwidth, PCI-SIG's analysis found that 8 gigatransfers per second could be manufactured in mainstream silicon process technology, and deployed with existing low-cost materials and infrastructure, while maintaining full compatibility (with negligible impact) with the PCI Express protocol stack.

PCI Express 3.0 upgraded the encoding scheme to 128b/130b from the previous 8b/10b encoding, reducing the bandwidth overhead from 20% of PCI Express 2.0 to approximately 1.54% (= 2/130). PCI Express 3.0's 8 GT/s bit rate effectively delivers 985 MB/s per lane, nearly doubling the lane bandwidth relative to PCI Express 2.0.

On 18 November 2010, the PCI Special Interest Group officially published the finalized PCI Express 3.0 specification to its members to build devices based on this new version of PCI Express.

PCI Express 3.1

In September 2013, PCI Express 3.1 specification was announced for release in late 2013 or early 2014, consolidating various improvements to the published PCI Express 3.0 specification in three areas: power management, performance and functionality. It was released in November 2014.

PCI Express 4.0

On 29 November 2011, PCI-SIG preliminarily announced PCI Express 4.0, providing a 16 GT/s bit rate that doubles the bandwidth provided by PCI Express 3.0 to 31.5 GB/s in each direction for a 16-lane configuration, while maintaining backward and forward compatibility in both software support and used mechanical interface. PCI Express 4.0 specs also bring OCuLink-2, an alternative to Thunderbolt. OCuLink version 2 has up to 16 GT/s (16 GB/s total for x8 lanes), while the maximum bandwidth of a Thunderbolt 3 link is 5 GB/s.

In June 2016 Cadence, PLDA and Synopsys demonstrated PCIe 4.0 physical-layer, controller, switch and other IP blocks at the PCI SIG’s annual developer’s conference.

Mellanox Technologies announced the first 100 Gbit/s network adapter with PCIe 4.0 on 15 June 2016, and the first 200 Gbit/s network adapter with PCIe 4.0 on 10 November 2016.

In August 2016, Synopsys presented a test setup with FPGA clocking a lane to PCIe 4.0 speeds at the Intel Developer Forum. Their IP has been licensed to several firms planning to present their chips and products at the end of 2016.

On the IEEE Hot Chips Symposium in August 2016 IBM announced the first CPU with PCIe 4.0 support, POWER9.

PCI-SIG officially announced the release of the final PCI Express 4.0 specification on 8 June 2017. The spec includes improvements in flexibility, scalability, and lower-power.

On 5 December 2017 IBM announced the first system with PCIe 4.0 slots, Power AC922.

NETINT Technologies introduced the first NVMe SSD based on PCIe 4.0 on 17 July 2018, ahead of Flash Memory Summit 2018

AMD announced on 9 January 2019 its upcoming Zen 2-based processors and X570 chipset would support PCIe 4.0. AMD had hoped to enable partial support for older chipsets, but instability caused by motherboard traces not conforming to PCIe 4.0 specifications made that impossible.

Intel released their first mobile CPUs with PCI Express 4.0 support in mid-2020, as a part of the Tiger Lake microarchitecture.

PCI Express 5.0

Three PCIe 5.0 x16 (two at x16 and one at x8 throughput) and two PCIe 4.0 x16 slots (one at 4 and one at x8 throughput) on a 2023 workstation mainboard

In June 2017, PCI-SIG announced the PCI Express 5.0 preliminary specification. Bandwidth was expected to increase to 32 GT/s, yielding 63 GB/s in each direction in a 16-lane configuration. The draft spec was expected to be standardized in 2019. Initially, 25.0 GT/s was also considered for technical feasibility.

On 7 June 2017 at PCI-SIG DevCon, Synopsys recorded the first demonstration of PCI Express 5.0 at 32 GT/s.

On 31 May 2018, PLDA announced the availability of their XpressRICH5 PCIe 5.0 Controller IP based on draft 0.7 of the PCIe 5.0 specification on the same day.

On 10 December 2018, the PCI SIG released version 0.9 of the PCIe 5.0 specification to its members, and on 17 January 2019, PCI SIG announced the version 0.9 had been ratified, with version 1.0 targeted for release in the first quarter of 2019.

On 29 May 2019, PCI-SIG officially announced the release of the final PCI Express 5.0 specification.

On 20 November 2019, Jiangsu Huacun presented the first PCIe 5.0 Controller HC9001 in a 12 nm manufacturing process. Production started in 2020.

On 17 August 2020, IBM announced the Power10 processor with PCIe 5.0 and up to 32 lanes per single-chip module (SCM) and up to 64 lanes per double-chip module (DCM).

On 9 September 2021, IBM announced the Power E1080 Enterprise server with planned availability date 17 September. It can have up to 16 Power10 SCMs with maximum of 32 slots per system which can act as PCIe 5.0 x8 or PCIe 4.0 x16. Alternatively they can be used as PCIe 5.0 x16 slots for optional optical CXP converter adapters connecting to external PCIe expansion drawers.

On 27 October 2021, Intel announced the 12th Gen Intel Core CPU family, the world's first consumer x86-64 processors with PCIe 5.0 (up to 16 lanes) connectivity.

On 22 March 2022, Nvidia announced Nvidia Hopper GH100 GPU, the world's first PCIe 5.0 GPU.

On 23 May 2022, AMD announced its Zen 4 architecture with support for up to 24 lanes of PCIe 5.0 connectivity on consumer platforms and 128 lanes on server platforms.

PCI Express 6.0

On 18 June 2019, PCI-SIG announced the development of PCI Express 6.0 specification. Bandwidth is expected to increase to 64 GT/s, yielding 128 GB/s in each direction in a 16-lane configuration, with a target release date of 2021. The new standard uses 4-level pulse-amplitude modulation (PAM-4) with a low-latency forward error correction (FEC) in place of non-return-to-zero (NRZ) modulation. Unlike previous PCI Express versions, forward error correction is used to increase data integrity and PAM-4 is used as line code so that two bits are transferred per transfer. With 64 GT/s data transfer rate (raw bit rate), up to 121 GB/s in each direction is possible in x16 configuration.

On 24 February 2020, the PCI Express 6.0 revision 0.5 specification (a "first draft" with all architectural aspects and requirements defined) was released.

On 5 November 2020, the PCI Express 6.0 revision 0.7 specification (a "complete draft" with electrical specifications validated via test chips) was released.

On 6 October 2021, the PCI Express 6.0 revision 0.9 specification (a "final draft") was released.

On 11 January 2022, PCI-SIG officially announced the release of the final PCI Express 6.0 specification.

On 18 March 2024, Nvidia announced Nvidia Blackwell GB100 GPU, the world's first PCIe 6.0 GPU.

PAM-4 coding results in a vastly higher bit error rate (BER) of 10 (vs. 10 previously), so in place of 128b/130b encoding, a 3-way interlaced forward error correction (FEC) is used in addition to cyclic redundancy check (CRC). A fixed 256 byte Flow Control Unit (FLIT) block carries 242 bytes of data, which includes variable-sized transaction level packets (TLP) and data link layer payload (DLLP); remaining 14 bytes are reserved for 8-byte CRC and 6-byte FEC. 3-way Gray code is used in PAM-4/FLIT mode to reduce error rate; the interface does not switch to NRZ and 128/130b encoding even when retraining to lower data rates.

PCI Express 7.0

On 21 June 2022, PCI-SIG announced the development of PCI Express 7.0 specification. It will deliver 128 GT/s raw bit rate and up to 242 GB/s per direction in x16 configuration, using the same PAM4 signaling as version 6.0. Doubling of the data rate will be achieved by fine-tuning channel parameters to decrease signal losses and improve power efficiency, but signal integrity is expected to be a challenge. The specification is expected to be finalized in 2025.

On 2 April 2024, PCI-SIG announced the release of PCIe 7.0 specification version 0.5; PCI Express 7.0 remains on track for release in 2025.

Extensions and future directions

Some vendors offer PCIe over fiber products, with active optical cables (AOC) for PCIe switching at increased distance in PCIe expansion drawers, or in specific cases where transparent PCIe bridging is preferable to using a more mainstream standard (such as InfiniBand or Ethernet) that may require additional software to support it.

Thunderbolt was co-developed by Intel and Apple as a general-purpose high speed interface combining a logical PCIe link with DisplayPort and was originally intended as an all-fiber interface, but due to early difficulties in creating a consumer-friendly fiber interconnect, nearly all implementations are copper systems. A notable exception, the Sony VAIO Z VPC-Z2, uses a nonstandard USB port with an optical component to connect to an outboard PCIe display adapter. Apple has been the primary driver of Thunderbolt adoption through 2011, though several other vendors have announced new products and systems featuring Thunderbolt. Thunderbolt 3 forms the basis of the USB4 standard.

Mobile PCIe specification (abbreviated to M-PCIe) allows PCI Express architecture to operate over the MIPI Alliance's M-PHY physical layer technology. Building on top of already existing widespread adoption of M-PHY and its low-power design, Mobile PCIe lets mobile devices use PCI Express.

Draft process

There are 5 primary releases/checkpoints in a PCI-SIG specification:

  • Draft 0.3 (Concept): this release may have few details, but outlines the general approach and goals.
  • Draft 0.5 (First draft): this release has a complete set of architectural requirements and must fully address the goals set out in the 0.3 draft.
  • Draft 0.7 (Complete draft): this release must have a complete set of functional requirements and methods defined, and no new functionality may be added to the specification after this release. Before the release of this draft, electrical specifications must have been validated via test silicon.
  • Draft 0.9 (Final draft): this release allows PCI-SIG member companies to perform an internal review for intellectual property, and no functional changes are permitted after this draft.
  • 1.0 (Final release): this is the final and definitive specification, and any changes or enhancements are through Errata documentation and Engineering Change Notices (ECNs) respectively.

Historically, the earliest adopters of a new PCIe specification generally begin designing with the Draft 0.5 as they can confidently build up their application logic around the new bandwidth definition and often even start developing for any new protocol features. At the Draft 0.5 stage, however, there is still a strong likelihood of changes in the actual PCIe protocol layer implementation, so designers responsible for developing these blocks internally may be more hesitant to begin work than those using interface IP from external sources.

Hardware protocol summary

The PCIe link is built around dedicated unidirectional couples of serial (1-bit), point-to-point connections known as lanes. This is in sharp contrast to the earlier PCI connection, which is a bus-based system where all the devices share the same bidirectional, 32-bit or 64-bit parallel bus.

PCI Express is a layered protocol, consisting of a transaction layer, a data link layer, and a physical layer. The Data Link Layer is subdivided to include a media access control (MAC) sublayer. The Physical Layer is subdivided into logical and electrical sublayers. The Physical logical-sublayer contains a physical coding sublayer (PCS). The terms are borrowed from the IEEE 802 networking protocol model.

Physical layer

Connector pins and lengths
Lanes Pins Length
Total Variable Total Variable
0x1 2×18 = 036 2×07 = 014 25 mm 07.65 mm
0x4 2×32 = 064 2×21 = 042 39 mm 21.65 mm
0x8 2×49 = 098 2×38 = 076 56 mm 38.65 mm
0x16 2×82 = 164 2×71 = 142 89 mm 71.65 mm
An open-end PCI Express x1 connector lets longer cards that use more lanes be plugged while operating at x1 speeds.

The PCIe Physical Layer (PHY, PCIEPHY, PCI Express PHY, or PCIe PHY) specification is divided into two sub-layers, corresponding to electrical and logical specifications. The logical sublayer is sometimes further divided into a MAC sublayer and a PCS, although this division is not formally part of the PCIe specification. A specification published by Intel, the PHY Interface for PCI Express (PIPE), defines the MAC/PCS functional partitioning and the interface between these two sub-layers. The PIPE specification also identifies the physical media attachment (PMA) layer, which includes the serializer/deserializer (SerDes) and other analog circuitry; however, since SerDes implementations vary greatly among ASIC vendors, PIPE does not specify an interface between the PCS and PMA.

At the electrical level, each lane consists of two unidirectional differential pairs operating at 2.5, 5, 8, 16 or 32 Gbit/s, depending on the negotiated capabilities. Transmit and receive are separate differential pairs, for a total of four data wires per lane.

A connection between any two PCIe devices is known as a link, and is built up from a collection of one or more lanes. All devices must minimally support single-lane (x1) link. Devices may optionally support wider links composed of up to 32 lanes. This allows for very good compatibility in two ways:

  • A PCIe card physically fits (and works correctly) in any slot that is at least as large as it is (e.g., a x1 sized card works in any sized slot);
  • A slot of a large physical size (e.g., x16) can be wired electrically with fewer lanes (e.g., x1, x4, x8, or x12) as long as it provides the ground connections required by the larger physical slot size.

In both cases, PCIe negotiates the highest mutually supported number of lanes. Many graphics cards, motherboards and BIOS versions are verified to support x1, x4, x8 and x16 connectivity on the same connection.

The width of a PCIe connector is 8.8 mm, while the height is 11.25 mm, and the length is variable. The fixed section of the connector is 11.65 mm in length and contains two rows of 11 pins each (22 pins total), while the length of the other section is variable depending on the number of lanes. The pins are spaced at 1 mm intervals, and the thickness of the card going into the connector is 1.6 mm.

Data transmission

PCIe sends all control messages, including interrupts, over the same links used for data. The serial protocol can never be blocked, so latency is still comparable to conventional PCI, which has dedicated interrupt lines. When the problem of IRQ sharing of pin based interrupts is taken into account and the fact that message signaled interrupts (MSI) can bypass an I/O APIC and be delivered to the CPU directly, MSI performance ends up being substantially better.

Data transmitted on multiple-lane links is interleaved, meaning that each successive byte is sent down successive lanes. The PCIe specification refers to this interleaving as data striping. While requiring significant hardware complexity to synchronize (or deskew) the incoming striped data, striping can significantly reduce the latency of the n byte on a link. While the lanes are not tightly synchronized, there is a limit to the lane to lane skew of 20/8/6 ns for 2.5/5/8 GT/s so the hardware buffers can re-align the striped data. Due to padding requirements, striping may not necessarily reduce the latency of small data packets on a link.

As with other high data rate serial transmission protocols, the clock is embedded in the signal. At the physical level, PCI Express 2.0 utilizes the 8b/10b encoding scheme (line code) to ensure that strings of consecutive identical digits (zeros or ones) are limited in length. This coding was used to prevent the receiver from losing track of where the bit edges are. In this coding scheme every eight (uncoded) payload bits of data are replaced with 10 (encoded) bits of transmit data, causing a 20% overhead in the electrical bandwidth. To improve the available bandwidth, PCI Express version 3.0 instead uses 128b/130b encoding (1.54% overhead). Line encoding limits the run length of identical-digit strings in data streams and ensures the receiver stays synchronised to the transmitter via clock recovery.

A desirable balance (and therefore spectral density) of 0 and 1 bits in the data stream is achieved by XORing a known binary polynomial as a "scrambler" to the data stream in a feedback topology. Because the scrambling polynomial is known, the data can be recovered by applying the XOR a second time. Both the scrambling and descrambling steps are carried out in hardware.

Dual simplex in PCIe means there are two simplex channels on every PCIe lane. Simplex means communication is only possible in one direction. By having two simplex channels, two-way communication is made possible. One differential pair is used for each channel.

Data link layer

The data link layer performs three vital services for the PCIe link:

  1. sequence the transaction layer packets (TLPs) that are generated by the transaction layer,
  2. ensure reliable delivery of TLPs between two endpoints via an acknowledgement protocol (ACK and NAK signaling) that explicitly requires replay of unacknowledged/bad TLPs,
  3. initialize and manage flow control credits

On the transmit side, the data link layer generates an incrementing sequence number for each outgoing TLP. It serves as a unique identification tag for each transmitted TLP, and is inserted into the header of the outgoing TLP. A 32-bit cyclic redundancy check code (known in this context as Link CRC or LCRC) is also appended to the end of each outgoing TLP.

On the receive side, the received TLP's LCRC and sequence number are both validated in the link layer. If either the LCRC check fails (indicating a data error), or the sequence-number is out of range (non-consecutive from the last valid received TLP), then the bad TLP, as well as any TLPs received after the bad TLP, are considered invalid and discarded. The receiver sends a negative acknowledgement message (NAK) with the sequence-number of the invalid TLP, requesting re-transmission of all TLPs forward of that sequence-number. If the received TLP passes the LCRC check and has the correct sequence number, it is treated as valid. The link receiver increments the sequence-number (which tracks the last received good TLP), and forwards the valid TLP to the receiver's transaction layer. An ACK message is sent to remote transmitter, indicating the TLP was successfully received (and by extension, all TLPs with past sequence-numbers.)

If the transmitter receives a NAK message, or no acknowledgement (NAK or ACK) is received until a timeout period expires, the transmitter must retransmit all TLPs that lack a positive acknowledgement (ACK). Barring a persistent malfunction of the device or transmission medium, the link-layer presents a reliable connection to the transaction layer, since the transmission protocol ensures delivery of TLPs over an unreliable medium.

In addition to sending and receiving TLPs generated by the transaction layer, the data-link layer also generates and consumes data link layer packets (DLLPs). ACK and NAK signals are communicated via DLLPs, as are some power management messages and flow control credit information (on behalf of the transaction layer).

In practice, the number of in-flight, unacknowledged TLPs on the link is limited by two factors: the size of the transmitter's replay buffer (which must store a copy of all transmitted TLPs until the remote receiver ACKs them), and the flow control credits issued by the receiver to a transmitter. PCI Express requires all receivers to issue a minimum number of credits, to guarantee a link allows sending PCIConfig TLPs and message TLPs.

Transaction layer

PCI Express implements split transactions (transactions with request and response separated by time), allowing the link to carry other traffic while the target device gathers data for the response.

PCI Express uses credit-based flow control. In this scheme, a device advertises an initial amount of credit for each received buffer in its transaction layer. The device at the opposite end of the link, when sending transactions to this device, counts the number of credits each TLP consumes from its account. The sending device may only transmit a TLP when doing so does not make its consumed credit count exceed its credit limit. When the receiving device finishes processing the TLP from its buffer, it signals a return of credits to the sending device, which increases the credit limit by the restored amount. The credit counters are modular counters, and the comparison of consumed credits to credit limit requires modular arithmetic. The advantage of this scheme (compared to other methods such as wait states or handshake-based transfer protocols) is that the latency of credit return does not affect performance, provided that the credit limit is not encountered. This assumption is generally met if each device is designed with adequate buffer sizes.

PCIe 1.x is often quoted to support a data rate of 250 MB/s in each direction, per lane. This figure is a calculation from the physical signaling rate (2.5 gigabaud) divided by the encoding overhead (10 bits per byte). This means a sixteen lane (x16) PCIe card would then be theoretically capable of 16x250 MB/s = 4 GB/s in each direction. While this is correct in terms of data bytes, more meaningful calculations are based on the usable data payload rate, which depends on the profile of the traffic, which is a function of the high-level (software) application and intermediate protocol levels.

Like other high data rate serial interconnect systems, PCIe has a protocol and processing overhead due to the additional transfer robustness (CRC and acknowledgements). Long continuous unidirectional transfers (such as those typical in high-performance storage controllers) can approach >95% of PCIe's raw (lane) data rate. These transfers also benefit the most from increased number of lanes (x2, x4, etc.) But in more typical applications (such as a USB or Ethernet controller), the traffic profile is characterized as short data packets with frequent enforced acknowledgements. This type of traffic reduces the efficiency of the link, due to overhead from packet parsing and forced interrupts (either in the device's host interface or the PC's CPU). Being a protocol for devices connected to the same printed circuit board, it does not require the same tolerance for transmission errors as a protocol for communication over longer distances, and thus, this loss of efficiency is not particular to PCIe.

Efficiency of the link

As for any network-like communication links, some of the raw bandwidth is consumed by protocol overhead:

A PCIe 1.x lane for example offers a data rate on top of the physical layer of 250 MB/s (simplex). This is not the payload bandwidth but the physical layer bandwidth – a PCIe lane has to carry additional information for full functionality.

Gen 2 Transaction Layer Packet
Layer PHY Data Link Layer Transaction Data Link Layer PHY
Data Start Sequence Header Payload ECRC LCRC End
Size (Bytes) 1 2 12 or 16 0 to 4096 4 (optional) 4 1

The Gen2 overhead is then 20, 24, or 28 bytes per transaction.

Gen 3 Transaction Layer Packet
Layer PHY Data Link Layer Transaction Layer Data Link Layer
Data Start Sequence Header Payload ECRC LCRC
Size (Bytes) 4 2 12 or 16 0 to 4096 4 (optional) 4

The Gen3 overhead is then 22, 26 or 30 bytes per transaction.

The Packet Efficiency = Payload Payload + Overhead {\displaystyle {\text{Packet Efficiency}}={\frac {\text{Payload}}{{\text{Payload}}+{\text{Overhead}}}}} for a 128 byte payload is 86%, and 98% for a 1024 byte payload. For small accesses like register settings (4 bytes), the efficiency drops as low as 16%.

The maximum payload size (MPS) is set on all devices based on smallest maximum on any device in the chain. If one device has an MPS of 128 bytes, all devices of the tree must set their MPS to 128 bytes. In this case the bus will have a peak efficiency of 86% for writes.

Applications

Asus Nvidia GeForce GTX 650 Ti, a PCI Express 3.0 x16 graphics card
The Nvidia GeForce GTX 1070, a PCI Express 3.0 x16 Graphics card
Intel 82574L Gigabit Ethernet NIC, a PCI Express x1 card
A Marvell-based SATA 3.0 controller, as a PCI Express x1 card

PCI Express operates in consumer, server, and industrial applications, as a motherboard-level interconnect (to link motherboard-mounted peripherals), a passive backplane interconnect and as an expansion card interface for add-in boards.

In virtually all modern (as of 2012) PCs, from consumer laptops and desktops to enterprise data servers, the PCIe bus serves as the primary motherboard-level interconnect, connecting the host system-processor with both integrated peripherals (surface-mounted ICs) and add-on peripherals (expansion cards). In most of these systems, the PCIe bus co-exists with one or more legacy PCI buses, for backward compatibility with the large body of legacy PCI peripherals.

As of 2013, PCI Express has replaced AGP as the default interface for graphics cards on new systems. Almost all models of graphics cards released since 2010 by AMD (ATI) and Nvidia use PCI Express. Nvidia used the high-bandwidth data transfer of PCIe for its Scalable Link Interface (SLI) technology, which allowed multiple graphics cards of the same chipset and model number to run in tandem, allowing increased performance. This interface has, since, been discontinued. AMD has also developed a multi-GPU system based on PCIe called CrossFire. AMD, Nvidia, and Intel have released motherboard chipsets that support as many as four PCIe x16 slots, allowing tri-GPU and quad-GPU card configurations.

External GPUs

Theoretically, external PCIe could give a notebook the graphics power of a desktop, by connecting a notebook with any PCIe desktop video card (enclosed in its own external housing, with a power supply and cooling); this is possible with an ExpressCard or Thunderbolt interface. An ExpressCard interface provides bit rates of 5 Gbit/s (0.5 GB/s throughput), whereas a Thunderbolt interface provides bit rates of up to 40 Gbit/s (5 GB/s throughput).

In 2006, Nvidia developed the Quadro Plex external PCIe family of GPUs that can be used for advanced graphic applications for the professional market. These video cards require a PCI Express x8 or x16 slot for the host-side card, which connects to the Plex via a VHDCI carrying eight PCIe lanes.

In 2008, AMD announced the ATI XGP technology, based on a proprietary cabling system that is compatible with PCIe x8 signal transmissions. This connector is available on the Fujitsu Amilo and the Acer Ferrari One notebooks. Fujitsu launched their AMILO GraphicBooster enclosure for XGP soon thereafter. Around 2010 Acer launched the Dynavivid graphics dock for XGP.

In 2010, external card hubs were introduced that can connect to a laptop or desktop through a PCI ExpressCard slot. These hubs can accept full-sized graphics cards. Examples include MSI GUS, Village Instrument's ViDock, the Asus XG Station, Bplus PE4H V3.2 adapter, as well as more improvised DIY devices. However such solutions are limited by the size (often only x1) and version of the available PCIe slot on a laptop.

The Intel Thunderbolt interface has provided a new option to connect with a PCIe card externally. Magma has released the ExpressBox 3T, which can hold up to three PCIe cards (two at x8 and one at x4). MSI also released the Thunderbolt GUS II, a PCIe chassis dedicated for video cards. Other products such as the Sonnet's Echo Express and mLogic's mLink are Thunderbolt PCIe chassis in a smaller form factor.

In 2017, more fully featured external card hubs were introduced, such as the Razer Core, which has a full-length PCIe x16 interface.

Storage devices

An OCZ RevoDrive SSD, a full-height x4 PCI Express card
See also: SATA Express and NVMe

The PCI Express protocol can be used as data interface to flash memory devices, such as memory cards and solid-state drives (SSDs).

The XQD card is a memory card format utilizing PCI Express, developed by the CompactFlash Association, with transfer rates of up to 1 GB/s.

Many high-performance, enterprise-class SSDs are designed as PCI Express RAID controller cards. Before NVMe was standardized, many of these cards utilized proprietary interfaces and custom drivers to communicate with the operating system; they had much higher transfer rates (over 1 GB/s) and IOPS (over one million I/O operations per second) when compared to Serial ATA or SAS drives. For example, in 2011 OCZ and Marvell co-developed a native PCI Express solid-state drive controller for a PCI Express 3.0 x16 slot with maximum capacity of 12 TB and a performance of to 7.2 GB/s sequential transfers and up to 2.52 million IOPS in random transfers.

SATA Express was an interface for connecting SSDs through SATA-compatible ports, optionally providing multiple PCI Express lanes as a pure PCI Express connection to the attached storage device. M.2 is a specification for internally mounted computer expansion cards and associated connectors, which also uses multiple PCI Express lanes.

PCI Express storage devices can implement both AHCI logical interface for backward compatibility, and NVM Express logical interface for much faster I/O operations provided by utilizing internal parallelism offered by such devices. Enterprise-class SSDs can also implement SCSI over PCI Express.

Cluster interconnect

Certain data-center applications (such as large computer clusters) require the use of fiber-optic interconnects due to the distance limitations inherent in copper cabling. Typically, a network-oriented standard such as Ethernet or Fibre Channel suffices for these applications, but in some cases the overhead introduced by routable protocols is undesirable and a lower-level interconnect, such as InfiniBand, RapidIO, or NUMAlink is needed. Local-bus standards such as PCIe and HyperTransport can in principle be used for this purpose, but as of 2015, solutions are only available from niche vendors such as Dolphin ICS, and TTTech Auto.

Competing protocols

Other communications standards based on high bandwidth serial architectures include InfiniBand, RapidIO, HyperTransport, Intel QuickPath Interconnect, the Mobile Industry Processor Interface (MIPI), and NVLink. Differences are based on the trade-offs between flexibility and extensibility vs latency and overhead. For example, making the system hot-pluggable, as with Infiniband but not PCI Express, requires that software track network topology changes.

Another example is making the packets shorter to decrease latency (as is required if a bus must operate as a memory interface). Smaller packets mean packet headers consume a higher percentage of the packet, thus decreasing the effective bandwidth. Examples of bus protocols designed for this purpose are RapidIO and HyperTransport.

PCI Express falls somewhere in the middle, targeted by design as a system interconnect (local bus) rather than a device interconnect or routed network protocol. Additionally, its design goal of software transparency constrains the protocol and raises its latency somewhat.

Delays in PCIe 4.0 implementations led to the Gen-Z consortium, the CCIX effort and an open Coherent Accelerator Processor Interface (CAPI) all being announced by the end of 2016.

On 11 March 2019, Intel presented Compute Express Link (CXL), a new interconnect bus, based on the PCI Express 5.0 physical layer infrastructure. The initial promoters of the CXL specification included: Alibaba, Cisco, Dell EMC, Facebook, Google, HPE, Huawei, Intel and Microsoft.

Integrators list

The PCI-SIG Integrators List lists products made by PCI-SIG member companies that have passed compliance testing. The list include switches, bridges, NICs, SSDs, etc.

See also

Notes

  1. Switches can create multiple endpoints out of one to allow sharing it with multiple devices.
  2. The card's Serial ATA power connector is present because the USB 3.0 ports require more power than the PCI Express bus can supply. More often, a 4-pin Molex power connector is used.

References

  1. IBM Power 770 and 780 Technical Overview and Introduction. IBM Redbooks. 6 June 2013. ISBN 978-0-7384-5121-3.
  2. Mayhew, D.; Krishnan, V. (August 2003). "PCI express and advanced switching: Evolutionary path to building next generation interconnects". 11th Symposium on High Performance Interconnects, 2003. Proceedings. pp. 21–29. doi:10.1109/CONECT.2003.1231473. ISBN 0-7695-2012-X. S2CID 7456382.
  3. "Definition of PCI Express". PCMag.
  4. Zhang, Yanmin; Nguyen, T Long (June 2007). "Enable PCI Express Advanced Error Reporting in the Kernel" (PDF). Proceedings of the Linux Symposium. Fedora project. Archived from the original (PDF) on 10 March 2016. Retrieved 8 May 2012.
  5. https://www.hyperstone.com Flash Memory Form Factors – The Fundamentals of Reliable Flash Storage, Retrieved 19 April 2018
  6. ^ Ravi Budruk (21 August 2007). "PCI Express Basics". PCI-SIG. Archived from the original (PDF) on 15 July 2014. Retrieved 15 July 2014.
  7. "What are PCIe Slots and Their Uses". PC Guide 101. 18 May 2021. Retrieved 21 June 2021.
  8. "How PCI Express Works". How Stuff Works. 17 August 2005. Archived from the original on 3 December 2009. Retrieved 7 December 2009.
  9. "4.2.4.9. Link Width and Lane Sequence Negotiation", PCI Express Base Specification, Revision 2.1., 4 March 2009
  10. ^ "PCI Express Architecture Frequently Asked Questions". PCI-SIG. Archived from the original on 13 November 2008. Retrieved 23 November 2008.
  11. "PCI Express Bus". Interface bus. Archived from the original on 8 December 2007. Retrieved 12 June 2010.
  12. 32 lanes are defined by the PCIe Base Specification up to PCIe 5.0 but there's no card standard in the PCIe Card Electromechanical Specification and that lane number was never implemented.
  13. "PCI Express – An Overview of the PCI Express Standard". Developer Zone. National Instruments. 13 August 2009. Archived from the original on 5 January 2010. Retrieved 7 December 2009.
  14. Qazi, Atif. "What are PCIe Slots?". PC Gear Lab. Retrieved 8 April 2020.
  15. "New PCIe Form Factor Enables Greater PCIe SSD Adoption". NVM Express. 12 June 2012. Archived from the original on 6 September 2015.
  16. "Memblaze PBlaze4 AIC NVMe SSD Review". StorageReview. 21 December 2015.
  17. July 2015, Kane Fulton 20 (20 July 2015). "19 graphics cards that shaped the future of gaming". TechRadar.{{cite web}}: CS1 maint: numeric names: authors list (link)
  18. Leadbetter, Richard (16 September 2020). "Nvidia GeForce RTX 3080 review: welcome to the next level". Eurogamer.
  19. Discuss, btarunr (6 January 2023). "ASUS x Noctua RTX 4080 Graphics Card is 5 Slots Thick, We Go Hands-on". TechPowerUp. Retrieved 19 September 2024.
  20. "Sapphire Radeon RX 5700 XT Pulse Review | bit-tech.net". bit-tech.net. Retrieved 26 August 2019.
  21. "AMD Radeon™ RX 5700 XT 8GB GDDR6 THICC II – RX-57XT8DFD6". xfxforce.com. Archived from the original on 1 September 2019. Retrieved 25 August 2019.
  22. "ROG Strix GeForce RTX 3080 OC Edition 10GB GDDR6X | Graphics Cards". rog.asus.com.
  23. "What is the A side, B side configuration of PCI cards". Frequently Asked Questions. Adex Electronics. 1998. Archived from the original on 2 November 2011. Retrieved 24 October 2011.
  24. ^ PCI Express Card Electromechanical Specification Revision 2.0
  25. "PCI Express Card Electromechanical Specification Revision 4.0, Version 1.0 (Clean)".
  26. "L1 PM Substates with CLKREQ, Revision 1.0a" (PDF). PCI-SIG. Archived from the original (PDF) on 4 December 2018. Retrieved 8 November 2018.
  27. "Emergency Power Reduction Mechanism with PWRBRK Signal ECN" (PDF). PCI-SIG. Archived from the original (PDF) on 9 November 2018. Retrieved 8 November 2018.
  28. "Where Does PCIe Cable Go?". 16 January 2022. Retrieved 10 June 2022.
  29. PCI Express Card Electromechanical Specification Revision 1.1
  30. Schoenborn, Zale (2004), Board Design Guidelines for PCI Express Architecture (PDF), PCI-SIG, pp. 19–21, archived (PDF) from the original on 27 March 2016
  31. PCI Express Base Specification, Revision 1.1 Page 332
  32. ^ "Mini-Fit® PCI Express®* Wire to Board Connector System" (PDF). Retrieved 4 December 2020.
  33. PCI Express x16 Graphics 150W-ATX Specification Revision 1.0
  34. PCI Express 225 W/300 W High Power Card Electromechanical Specification Revision 1.0
  35. PCI Express Card Electromechanical Specification Revision 3.0
  36. Yun Ling (16 May 2008). "PCIe Electromechanical Updates". Archived from the original on 5 November 2015. Retrieved 7 November 2015.
  37. "12VHPWR Sideband Allocation and Requirements - PCIe 5.x ECN". PCI SIG. 12 May 2022.
  38. "12V-2x6 Connector Updates to PCIe Base 6.0 - PCIe 6.x ECN". PCI SIG. 31 August 2023. This ECN defines Connector Type encodings for the new 12V-2x6 connector. This connector, defined in CEM 5.1, replaces the 12VHPWR connector.
  39. "Rest in Peace 12VHPWR Connector - Welcome 12V-2×6 Connector, important modifications and PCIe Base 6 | Exclusive". 3 July 2023.
  40. "12VHPWR and 12V-2x6 Compared | CORSAIR".
  41. "Understanding M.2, the interface that will speed up your next SSD". 8 February 2015.
  42. "MP1: Mini PCI Express / PCI Express Adapter". hwtools.net. 18 July 2014. Archived from the original on 3 October 2014. Retrieved 28 September 2014.
  43. IT Essentials Companion Guide v8. Cisco Press. 9 July 2023. ISBN 978-0-13-816625-0.
  44. Mobile Computing Deployment and Management: Real World Skills for CompTIA Mobility+ Certification and Beyond. John Wiley & Sons. 24 February 2015. ISBN 978-1-118-82461-0.
  45. "mSATA FAQ: A Basic Primer". Notebook review. Archived from the original on 12 February 2012.
  46. "Eee PC Research". ivc (wiki). Archived from the original on 30 March 2010. Retrieved 26 October 2009.
  47. "Desktop Board Solid-state drive (SSD) compatibility". Intel. Archived from the original on 2 January 2016.
  48. "How to distinguish the differences between M.2 cards | Dell US". www.dell.com. Retrieved 24 March 2020.
  49. "PCI Express External Cabling 1.0 Specification". Archived from the original on 10 February 2007. Retrieved 9 February 2007.
  50. "PCI Express External Cabling Specification Completed by PCI-SIG". PCI SIG. 7 February 2007. Archived from the original on 26 November 2013. Retrieved 7 December 2012.
  51. ^ "OCuLink connectors and cables support new PCIe standard". www.connectortips.com. Archived from the original on 13 March 2017.
  52. Mokosiy, Vitaliy (9 October 2020). "Untangling terms: M.2, NVMe, USB-C, SAS, PCIe, U.2, OCuLink". Medium. Retrieved 26 March 2021.
  53. "Supermicro Universal I/O (UIO) Solutions". Supermicro.com. Archived from the original on 24 March 2014. Retrieved 24 March 2014.
  54. "Get ready for M-PCIe testing", PC board design, EDN
  55. ^ "PCI SIG discusses M-PCIe oculink & 4th gen PCIe", The Register, UK, 13 September 2013, archived from the original on 29 June 2017
  56. "PCI Express 4.0 Frequently Asked Questions". pcisig.com. PCI-SIG. Archived from the original on 18 May 2014. Retrieved 18 May 2014.
  57. ^ "PCI Express 3.0 Frequently Asked Questions". pcisig.com. PCI-SIG. Archived from the original on 1 February 2014. Retrieved 1 May 2014.
  58. "What does GT/s mean, anyway?". TM World. Archived from the original on 14 August 2012. Retrieved 7 December 2012.
  59. "Deliverable 12.2". SE: Eiscat. Archived from the original on 17 August 2010. Retrieved 7 December 2012.
  60. PCI SIG, archived from the original on 6 July 2008
  61. "PCI Express Base 2.0 specification announced" (PDF) (Press release). PCI-SIG. 15 January 2007. Archived from the original (PDF) on 4 March 2007. Retrieved 9 February 2007. — note that in this press release the term aggregate bandwidth refers to the sum of incoming and outgoing bandwidth; using this terminology the aggregate bandwidth of full duplex 100BASE-TX is 200 Mbit/s.
  62. Smith, Tony (11 October 2006). "PCI Express 2.0 final draft spec published". The Register. Archived from the original on 29 January 2007. Retrieved 9 February 2007.
  63. Key, Gary; Fink, Wesley (21 May 2007). "Intel P35: Intel's Mainstream Chipset Grows Up". AnandTech. Archived from the original on 23 May 2007. Retrieved 21 May 2007.
  64. Huynh, Anh (8 February 2007). "NVIDIA "MCP72" Details Unveiled". AnandTech. Archived from the original on 10 February 2007. Retrieved 9 February 2007.
  65. "Intel P35 Express Chipset Product Brief" (PDF). Intel. Archived (PDF) from the original on 26 September 2007. Retrieved 5 September 2007.
  66. Hachman, Mark (5 August 2009). "PCI Express 3.0 Spec Pushed Out to 2010". PC Mag. Archived from the original on 7 January 2014. Retrieved 7 December 2012.
  67. "PCI Express 3.0 Bandwidth: 8.0 Gigatransfers/s". ExtremeTech. 9 August 2007. Archived from the original on 24 October 2007. Retrieved 5 September 2007.
  68. "PCI Special Interest Group Publishes PCI Express 3.0 Standard". X bit labs. 18 November 2010. Archived from the original on 21 November 2010. Retrieved 18 November 2010.
  69. "PCIe 3.1 and 4.0 Specifications Revealed". eteknix.com. July 2013. Archived from the original on 1 February 2016.
  70. "Trick or Treat… PCI Express 3.1 Released!". synopsys.com. Archived from the original on 23 March 2015.
  71. "PCI Express 4.0 evolution to 16 GT/s, twice the throughput of PCI Express 3.0 technology" (press release). PCI-SIG. 29 November 2011. Archived from the original on 23 December 2012. Retrieved 7 December 2012.
  72. "Frequently Asked Questions | PCI-SIG". pcisig.com. Archived from the original on 20 October 2016.
  73. "PCIe 4.0 Heads to Fab, 5.0 to Lab". EE Times. 26 June 2016. Archived from the original on 28 August 2016. Retrieved 27 August 2016.
  74. "Mellanox Announces ConnectX-5, the Next Generation of 100G InfiniBand and Ethernet Smart Interconnect Adapter | NVIDIA". www.mellanox.com.
  75. "Mellanox Announces 200Gb/s HDR InfiniBand Solutions Enabling Record Levels of Performance and Scalability | NVIDIA". www.mellanox.com.
  76. "IDF: PCIe 4.0 läuft, PCIe 5.0 in Arbeit". Heise Online (in German). 18 August 2016. Archived from the original on 19 August 2016. Retrieved 18 August 2016.
  77. Brian Thompto, POWER9 Processor for the Cognitive Era
  78. 2016 IEEE Hot Chips 28 Symposium (HCS), 21–23 Aug. 2016
  79. ^ Born, Eric (8 June 2017). "PCIe 4.0 specification finally out with 16 GT/s on tap". Tech Report. Archived from the original on 8 June 2017. Retrieved 8 June 2017.
  80. "IBM Unveils Most Advanced Server for AI". www-03.ibm.com. 5 December 2017. Archived from the original on 8 December 2017.
  81. IBM Power System AC922 (8335-GTG) server helps you to harness breakthrough accelerated AI, HPDA, and HPC performance for faster time to insight, IBM Europe Hardware Announcement ZG17-0147
  82. "NETINT Introduces Codensity with Support for PCIe 4.0 – NETINT Technologies". NETINT Technologies. 17 July 2018. Archived from the original on 29 September 2018. Retrieved 28 September 2018.
  83. Mujtaba, Hassan (9 January 2019). "AMD Ryzen 3000 Series CPUs Based on Zen 2 Launching in Mid of 2019".
  84. Alcorn, Paul (3 June 2019). "AMD Nixes PCIe 4.0 Support on Older Socket AM4 Motherboards, Here's Why". Tom's Hardware. Archived from the original on 10 June 2019. Retrieved 10 June 2019.
  85. Alcorn, Paul (10 January 2019). "PCIe 4.0 May Come to all AMD Socket AM4 Motherboards (Updated)". Tom's Hardware. Archived from the original on 10 June 2019. Retrieved 10 June 2019.
  86. Cutress, Dr. Ian (13 August 2020). "Tiger Lake IO and Power". Anandtech.
  87. "1,2,3,4,5... It's Official, PCIe 5.0 is Announced | synopsys.com". www.synopsys.com. Retrieved 7 June 2017.
  88. "PLDA Announces Availability of XpressRICH5™ PCIe 5.0 Controller IP | PLDA.com". www.plda.com. Retrieved 28 June 2018.
  89. "XpressRICH5 for ASIC | PLDA.com". www.plda.com. Retrieved 28 June 2018.
  90. "Doubling Bandwidth in Under Two Years: PCI Express® Base Specification Revision 5.0, Version 0.9 is Now Available to Members". pcisig.com. Retrieved 12 December 2018.
  91. "PCIe 5.0 Is Ready For Prime Time". tomshardware.com. 17 January 2019. Retrieved 18 January 2019.
  92. "PCI-SIG® Achieves 32GT/s with New PCI Express® 5.0 Specification". www.businesswire.com. 29 May 2019.
  93. "PCI-Express 5.0: China stellt ersten Controller vor". PC Games Hardware. 18 November 2019.
  94. IBM’s POWER10 Processor, Hot Chips 32, August 16–18, 2020
  95. Power E1080 Enterprise server delivers a uniquely architected platform to help securely and efficiently scale core operational and AI applications in a hybrid cloud, IBM Europe Hardware Announcement ZG21-0059
  96. ^ IBM Power E1080 Technical Overview and Introduction
  97. "Intel Unveils 12th Gen Intel Core, Launches World's Best Gaming". Intel.com. Retrieved 16 February 2022.
  98. "NVIDIA Announces Hopper Architecture, the Next Generation of Accelerated Computing".
  99. "AMD Showcases Industry-Leading Gaming, Commercial, and Mainstream PC Technologies at COMPUTEX 2022". AMD.com. Retrieved 23 May 2022.
  100. "4th Gen AMD EPYC™ Processor Architecture". AMD.com. Retrieved 12 November 2022.
  101. ^ "PCI-SIG® Announces Upcoming PCI Express® 6.0 Specification to Reach 64 GT/s". www.businesswire.com. 18 June 2019.
  102. Smith, Ryan. "PCI Express Bandwidth to Be Doubled Again: PCIe 6.0 Announced, Spec to Land in 2021". www.anandtech.com.
  103. "PCI Express 6.0 Reaches Version 0.5 Ahead Of Finalization Next Year – Phoronix". www.phoronix.com.
  104. Shilov, Anton (4 November 2020). "PCIe 6.0 Specification Hits Milestone: Complete Draft Is Ready". Tom's Hardware.
  105. Yanes, Al. "PCIe® 6.0 Specification, Version 0.9: One Step Closer to Final Release | PCI-SIG". pcisig.com. Retrieved 6 October 2021.
  106. "PCI-SIG® Releases PCIe® 6.0 Specification Delivering Record Performance to Power Big Data Applications". Business Wire. 11 January 2022. Retrieved 16 February 2022.
  107. "NVIDIA Blackwell Platform Arrives to Power a New Era of Computing".
  108. "The Evolution of the PCI Express Specification: On its Sixth Generation, Third Decade and Still Going Strong". Pci-Sig. 11 January 2022. Retrieved 16 February 2022.
  109. Debendra Das Sharma (8 June 2020). "PCIe 6.0 Specification: The Interconnect for I/O Needs of the Future". PCI-SIG. p. 8. Archived from the original on 30 October 2021.
  110. "Pushing the Envelope with PCIe 6.0: Bringing PAM4 to PCIe" (PDF). Retrieved 16 February 2022.
  111. "PowerPoint Presentation" (PDF). Retrieved 16 February 2022.
  112. "PCI-SIG® Announces PCI Express® 7.0 Specification to Reach 128 GT/s". Business Wire. 21 June 2022. Retrieved 25 June 2022.
  113. "PCIe® 7.0 Specification, Version 0.5 Now Available: Full Draft Available to Members". pcisig.com. Retrieved 3 April 2024.
  114. "PLX demo shows PCIe over fiber as data center clustering interconnect". Cabling install. Penn Well. Retrieved 29 August 2012.
  115. "Introduced second generation PCI Express Gen 2 over fiber optic systems". Adnaco. 22 April 2011. Archived from the original on 4 October 2012. Retrieved 29 August 2012.
  116. "PCIe Active Optical Cable System". Archived from the original on 30 December 2014. Retrieved 23 October 2015.
  117. IBM Power Systems E870 and E880 Technical Overview and Introduction
  118. "Acer, Asus to Bring Intel's Thunderbolt Speed Technology to Windows PCs". PC World. 14 September 2011. Archived from the original on 18 January 2012. Retrieved 7 December 2012.
  119. Kevin Parrish (28 June 2013). "PCIe for Mobile Launched; PCIe 3.1, 4.0 Specs Revealed". Tom's Hardware. Retrieved 10 July 2014.
  120. "PCI Express 4.0 Draft 0.7 & PIPE 4.4 Specifications – What Do They Mean to Designers? — Synopsys Technical Article | ChipEstimate.com". www.chipestimate.com. Retrieved 28 June 2018.
  121. "PCI Express 1x, 4x, 8x, 16x bus pinout and wiring @". RU: Pinouts. Archived from the original on 25 November 2009. Retrieved 7 December 2009.
  122. "PHY Interface for the PCI Express Architecture" (PDF) (version 2.00 ed.). Intel. Archived from the original (PDF) on 17 March 2008. Retrieved 21 May 2008.
  123. PCI Express System Architecture
  124. PCI Express Architecture, intel.com
  125. "Mechanical Drawing for PCI Express Connector". Interface bus. Retrieved 7 December 2007.
  126. "FCi schematic for PCIe connectors" (PDF). FCI connect. Retrieved 7 December 2007.
  127. Reducing Interrupt Latency Through the Use of Message Signaled Interrupts
  128. PCI Express Base Specification, Revision 3.0 Table 4-24
  129. https://ww1.microchip.com/downloads/aemDocuments/documents/TCG/ProductDocuments/Brochures/00003818.pdf
  130. IBM Power 770 and 780 Technical Overview and Introduction. IBM Redbooks. 6 June 2013. ISBN 978-0-7384-5121-3.
  131. CompTIA A+ Exam Cram (Exams 220-602, 220-603, 220-604). Pearson Education. 19 July 2007. ISBN 978-0-7686-9003-3.
  132. Computer Peripherals And Interfaces. Technical Publications Pune. 2008. ISBN 9788184313086. Archived from the original on 25 February 2014. Retrieved 23 July 2009.
  133. ^ Lawley, Jason (28 October 2014). "Understanding Performance of PCI Express Systems" (PDF). 1.2. Xilinx.
  134. "NVIDIA Introduces NVIDIA Quadro® Plex – A Quantum Leap in Visual Computing". Nvidia. 1 August 2006. Archived from the original on 24 August 2006. Retrieved 14 July 2018.
  135. "Quadro Plex VCS – Advanced visualization and remote graphics". nVidia. Archived from the original on 28 April 2011. Retrieved 11 September 2010.
  136. "XGP". ATI. AMD. Archived from the original on 29 January 2010. Retrieved 11 September 2010.
  137. Fujitsu-Siemens Amilo GraphicBooster External Laptop GPU Released, 3 December 2008, archived from the original on 16 October 2015, retrieved 9 August 2015
  138. DynaVivid Graphics Dock from Acer arrives in France, what about the US?, 11 August 2010, archived from the original on 16 October 2015, retrieved 9 August 2015
  139. Dougherty, Steve (22 May 2010), "MSI to showcase 'GUS' external graphics solution for laptops at Computex", TweakTown
  140. Hellstrom, Jerry (9 August 2011), "ExpressCard trying to pull a (not so) fast one?", PC Perspective (editorial), archived from the original on 1 February 2016
  141. "PE4H V3.2 (PCIe x16 Adapter)". Hwtools.net. Archived from the original on 14 February 2014. Retrieved 5 February 2014.
  142. O'Brien, Kevin (8 September 2010), "How to Upgrade Your Notebook Graphics Card Using DIY ViDOCK", Notebook review, archived from the original on 13 December 2013
  143. Lal Shimpi, Anand (7 September 2011), "The Thunderbolt Devices Trickle In: Magma's ExpressBox 3T", AnandTech, archived from the original on 4 March 2016
  144. "MSI GUS II external GPU enclosure with Thunderbolt". The Verge (hands-on). 10 January 2012. Archived from the original on 13 February 2012. Retrieved 12 February 2012.
  145. "PCI express graphics, Thunderbolt", Tom’s hardware, 17 September 2012
  146. "M logics M link Thunderbold chassis no shipping", Engadget, 13 December 2012, archived from the original on 25 June 2017
  147. Burns, Chris (17 October 2017), "2017 Razer Blade Stealth and Core V2 detailed", SlashGear, archived from the original on 17 October 2017
  148. "CompactFlash Association readies next-gen XQD format, promises write speeds of 125 MB/s and up". Engadget. 8 December 2011. Archived from the original on 19 May 2014. Retrieved 18 May 2014.
  149. Zsolt Kerekes (December 2011). "What's so very different about the design of Fusion-io's ioDrives / PCIe SSDs?". storagesearch.com. Archived from the original on 23 September 2013. Retrieved 2 October 2013.
  150. "Fusion-io ioDrive Duo Enterprise PCIe Review". storagereview.com. 16 July 2012. Archived from the original on 4 October 2013. Retrieved 2 October 2013.
  151. "OCZ Demos 4 TiB, 16 TiB Solid-State Drives for Enterprise". X-bit labs. Archived from the original on 25 March 2013. Retrieved 7 December 2012.
  152. "Enabling Higher Speed Storage Applications with SATA Express". SATA-IO. Archived from the original on 27 November 2012. Retrieved 7 December 2012.
  153. "SATA M.2 Card". SATA-IO. Archived from the original on 3 October 2013. Retrieved 14 September 2013.
  154. "SCSI Express". SCSI Trade Association. Archived from the original on 27 January 2013. Retrieved 27 December 2012.
  155. Meduri, Vijay (24 January 2011). "A Case for PCI Express as a High-Performance Cluster Interconnect". HPCwire. Archived from the original on 14 January 2013. Retrieved 7 December 2012.
  156. Evan Koblentz (3 February 2017). "New PCI Express 4.0 delay may empower next-gen alternatives". Tech Republic. Archived from the original on 1 April 2017. Retrieved 31 March 2017.
  157. Cutress, Ian. "CXL Specification 1.0 Released: New Industry High-Speed Interconnect From Intel". www.anandtech.com. Retrieved 9 August 2019.
  158. "Integrators List | PCI-SIG". pcisig.com. Retrieved 27 March 2019.


Further reading

  • Budruk, Ravi; Anderson, Don; Shanley, Tom (2003), Winkles, Joseph ‘Joe’ (ed.), PCI Express System Architecture, Mind share PC system architecture, Addison-Wesley, ISBN 978-0-321-15630-3, 1120 pp.
  • Solari, Edward; Congdon, Brad (2003), Complete PCI Express Reference: Design Implications for Hardware and Software Developers, Intel, ISBN 978-0-9717861-9-6, 1056 pp.
  • Wilen, Adam; Schade, Justin P; Thornburg, Ron (April 2003), Introduction to PCI Express: A Hardware and Software Developer's Guide, Intel, ISBN 978-0-9702846-9-3, 325 pp.

External links

Technical and de facto standards for wired computer buses
General
Standards
Storage
Peripheral
Audio
Portable
Embedded
Interfaces are listed by their speed in the (roughly) ascending order, so the interface at the end of each section should be the fastest.
Category
Basic computer components
Input devices
Pointing devices
Other
Output devices
Removable
data storage
Computer case
Ports
Current
Obsolete
Related
Categories:
PCI Express: Difference between revisions Add topic