

# Introduction to PCI Express

Transceiver Portfolio Workshops 2009





## **PCI Express Overview**

- PCI Express (Peripheral Component Interconnect Express) is a computer expansion standard introduced by Intel in 2004
  - Officially abbreviated as PCIe
     (PCI-E is also commonly used)
- PCIe replaces PCI, PCI-X, and AGP
- PCIe complements SERDESbased bus interface to the CPU





## **PCIe Technology Timeline**



#### Note:

Link BW =  $0.8 \times (raw \ bit \ rate)$  in Gen1/Gen2 due to 8B/10B encoding Dotted line is for projected numbers

© 2009 Altera Corporation—Public



### **PCI Express Protocol Stack**





# PCI Express – Point-to-Point Serial Interconnect

- Link: Full-duplex connection between two PCI Express devices
- Lane: Consists of differential signal pairs in each direction
  - 8b10b encoded in Gen1 or Gen2
  - 2.5 Gbps or 5.0 Gbps
  - x1, x2, x4, x8, x16...





#### **PCIe Functional Elements**

#### Root complex

- Connects host CPU/memory complex to PCIe hierarchy
- One or more downstream ports (= rootports)
- Rootport discovers, initializes, and enumerates PCIe topology

#### Switch

- Assembly of logical PCIe-to-PCIe bridges
- One upstream port directed towards root complex
- One or more downstream ports

#### Endpoint

 Legacy and native endpoints e.g. terminal point to PCI, USB, InfiniBand, Fibre Channel, Ethernet...







## **Auto Speed Negotiation**

- Initially link trains to L0 (normal operation) in 2.5G data rate
- Speeds advertised in training sequence (TS) ordered sets
  - Supported speeds by the other component noted
- Speed change occurs when the link is in electrical idle





#### Future PCIe Direction: I/O Virtualization

- May be useful in multi-core, multi-CPU or multi-line card systems
- PCIe supports single-root or multi-root I/O virtualization modes



Virtualization is the concept of sharing a single platform (a physical set of hardware like CPU, IO, memory, etc) among multiple software operating environments (e.g. OSs)

© 2009 Altera Corporation—Public





# Altera PCI Express Landscape



## **Altera PCI Express Focus**



- Ensuring customer success by:
  - Providing complete PCI Express solutions
  - Low-cost/high-volume designs to highperformance device families
  - Altera IP for PCI Express applications
    - Endpoint, switch, root complex, non-transparent/transparent bridging support also using partner IP
  - With a focus on ease of use
  - A solid commitment to hardware validation



## **Altera PCI Express Solutions**

#### Value proposition of hard IP

- Reduce device cost
  - Users can fit designs in smaller FPGA
    - Up to 40 KLE (x8 Gen2 configuration)
- > 50% power savings relative to equivalent soft IP core
- Shorter design and compile times
  - Easier timing closure
- Pre-verified complex IP

|                     | Hard PCI<br>Express IP                                                          | Soft PCI<br>Express IP                                                                                   |  |
|---------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--|
| Generation          | Gen1 and Gen2                                                                   | Gen1                                                                                                     |  |
| Configuration       | X1, x4, x8                                                                      | X1, x4, x8                                                                                               |  |
| Supported devices   | Stratix IV GX,<br>HardCopy IV GX,<br>Stratix IV GT,<br>and Arria II GX<br>FPGAs | Stratix GX, Stratix II GX, Stratix IV GX, HardCopy IV GX, Stratix IV GT, Arria GX, and Arria II GX FPGAs |  |
| Development<br>kits | Stratix IV GX and<br>Arria II GX FPGAs                                          | Arria GX,<br>Arria II GX,<br>Stratix IV GX, and<br>Stratix II GX<br>FPGAs                                |  |



## **PCIe Support in Altera Devices**

|                                 | Hard IP Gen1/2          |                           | Soft IP Gen1            |                           |
|---------------------------------|-------------------------|---------------------------|-------------------------|---------------------------|
| Device                          | Supported               | PCI Express configuration | Supported               | PCI Express configuration |
| Arria II GX<br>(PCIe Gen1 only) | ✓<br>1 per device       | X1, x4, x8                | <b></b> ✓               | X1, x4                    |
| Stratix IV GX                   | 2 to 4 per device       | x1, x4, x8                | <b>✓</b>                | x1, x4                    |
| HardCopy IV GX                  | ✓<br>1 to 2 per device  | x1, x4, x8                | <b>✓</b>                | x1, x4                    |
| Stratix IV GT <sup>(1)</sup>    | $\overline{\mathbf{Q}}$ | X1, x4                    | $\overline{\checkmark}$ | X1, x4                    |
| Arria GX                        |                         |                           | <b>V</b>                | x1, x4                    |
| Stratix II GX                   |                         |                           | $\overline{\checkmark}$ | x1, x4, x8                |
| Stratix GX                      |                         |                           | <b>V</b>                | x1, x4                    |
| Cyclone II <sup>(2)</sup>       |                         |                           | <b>V</b>                | x1                        |

<sup>&</sup>lt;sup>(1)</sup>Only supported by one quad in devices with F1932 package



<sup>(2)</sup>Cyclone II FPGA uses an external PCIe PHY

<sup>© 2009</sup> Altera Corporation—Public

#### **Altera PCI Express Solutions**

#### Industry-leading solutions

- Stratix IV GX FPGA is industry's only shipping FPGA solution with hard IP support for PCIe Gen2
- Stratix IV GX FPGA is industry's only FPGA solution with hard IP support for Gen2 x8 configurations
- Arria II GX FPGA is the industry's first low-cost 40-nm FPGA with hard IP support for PCIe Gen1 x1, x4, x8

#### Low-risk, hardware-verified solutions

- PCI-SIG compliance workshops
- Interoperability with multiple ASSP vendors
- 5 generations of transceiver-based FPGAs with PCI Express support
- Development kits/demo boards





# **PCI Express IP Cores**



#### **Altera PCIe Hard IP Features**

- Endpoint (EP)/rootport (RP) dual-mode core
  - RP for embedded applications only
  - Can dynamically switch between EP and RP modes
- PCIe Base rev 1.1 or 2.0 compliant protocol stack
  - Integrated TL, DLL, PHY MAC, and transceivers
    - 2.5 Gbps (Gen1) and 5.0 Gbps<sup>(\*)</sup> (Gen2) per lane
- x1, x4, x8 initial link width configurations
  - Supporting down-configuration (including x2)
- Configurable maximum payload size
  - 128, 256, 512, **1K**(\*) and **2K**(\*\*) bytes
- 1, **2**<sup>(\*)</sup> or **4**<sup>(\*)</sup> hard IP cores per device
- 1 or **2**<sup>(\*)</sup> virtual channels
- Single function support
- High-performance throughput
  - Close to the maximum theoretical bandwidth

(\*) Available only in Stratix IV GX and HardCopy IV GX devices (\*\*) Not available in HardCopy IV GX ASIC

#### Notes:

 The HIP does not support:: x16 link width, IO Virtualization, Gen3





## **PCI Express Made Easy**

- Built-in, pre-verified PCIe hard IP
- Guaranteed timing
- Flexible Gen1 and Gen2 x8, x4, x2, x1, rootport, and endpoint configurations
  - Stratix IV GX/GT and HardCopy IV GX devices
    - PCle Gen1 and Gen2
  - Arria II GX FPGA PCle Gen1
- SOPC Builder ready
- Configured with PCIe Compiler MegaWizard<sup>™</sup>
- Complete example design provided
- Reduced costs
  - Saves up to 15K LEs
  - No license fees



PCI Express hard IP









## **Transaction Layer Bypass Block Diagram**



#### **CDC = Clock domain crossing FIFO**

© 2009 Altera Corporation—Public





#### **Soft IP Core for PCI Express**



- ~150 licenses issued
- PCI Express 1.1 compliance
- Extensive performance benchmarking data across multiple chipsets/platforms
- Additional interoperability with multiple ASSPs

#### Flexible and feature rich

- Easy timing closure with support for incremental compilation
- Easy integration using SOPC Builder (x1, x4)
- Configurable maximum payload up to 2 Kbyte and configurable retry buffer
- Optional end-to-end cyclic redundancy code (ECRC) generation/checking and advanced error reporting (AER)
- Flexible reference clock support (100, 125, or 156.25 MHz)

© 2009 Altera Corporation—Public





# **PCI Express Testing**



# Preliminary PCI Express Characterization Testing

- PMA and PCS Gen1 and Gen2 compliant
- HIP Gen1 and Gen2 complete (x8 Gen2 in process)

| Characterization test                                                                            | Compliant to spec. |
|--------------------------------------------------------------------------------------------------|--------------------|
| Tx electrical buffer                                                                             | ✓                  |
| Tx AC/DC parameters                                                                              | ✓                  |
| CMU jitter generation across modes                                                               | ✓                  |
| CMU jitter generation statistical analysis                                                       | ✓                  |
| CMU jitter transfer                                                                              | ✓                  |
| CDR jitter transfer                                                                              | ✓                  |
| CDR jitter tolerance                                                                             | ✓                  |
| Rx signal detect threshold                                                                       | ✓                  |
| Rx signal detect timing                                                                          | ✓                  |
| Rx / Tx return loss                                                                              | ✓                  |
| Rx / Tx impedance                                                                                | ✓                  |
| CDR lock to data                                                                                 | ✓                  |
| CDR f <sub>MAX</sub> vs V <sub>ID</sub> and V <sub>CM</sub>                                      | ✓                  |
| PMA PCIe compliance test using PCI<br>Express electrical test software: SIGtest<br>version 3.1.9 | ·                  |

| Characterization test                         | Compliant spec. |
|-----------------------------------------------|-----------------|
| PIPE power state transition                   | ✓               |
| PIPE forcing negative disparity               | ✓               |
| PIPE auto speed negotiation                   | ✓               |
| PPM detector behavior after speed negotiation | ✓               |
| PIPE Tx electrical idle response time         | ✓               |
| PIPE rate match FIFO clock tolerance          | ✓               |
| PIPE pipestatus signal verification           | ✓               |
| PCIe HIP PHY and data link layer bring up     | ✓               |
| PCIe HIP Gen1 ×1 stress test                  | ✓               |
| PCle HIP Gen1 → Gen2 auto speed negotiation   | ✓               |
| Tx lane-to-lane skew                          | ✓               |
| Tx detect Rx                                  | ✓               |
| Tx intra differential pair skew               | ✓               |
| CDR run-length violation                      | ✓               |
| CDR clock PPM difference tolerance            | ✓               |
| CDR lock to reference                         | ✓               |
|                                               |                 |

© 2009 Altera Corporation—Public



## **PCIe Hard IP Testing**

#### Interoperability testing

- Compatibility/functionality with chipsets
  - Core generator with verifying payloads (built in DMA engine)
- Test for PCIe compliance using PCI-SIG tests

#### Performance testing

- Testing throughput of PCIe link
- Stress test using the chain DMA architecture

#### Test configurations

- Modes
  - PCI Express Gen1 x1, x4, x8
  - PCI Express Gen2 x1, x4

#### Altera PCIe Gen2 development card



|       | PCle Gen2 platforms |             |           |  |
|-------|---------------------|-------------|-----------|--|
|       | Motherboard         | Chipset     | Processor |  |
| AMD   | Asus M3A78-T        | 790GX/SB750 | AMD790GX  |  |
| Intel | Asus P5Q-EN         | Intel-645   | LGA775    |  |
| Intel | DX58S0              | Tylersburg  | Core I7   |  |



# Preliminary Results of PCI Express Hard IP Bandwidth Testing – Tylersburg Chipset

| HIP configuration    | DMA write  | DMA read   | Simultaneous read/<br>write |
|----------------------|------------|------------|-----------------------------|
| HIP:Gen1:x8:128 bits | 1,691 Mbps | 1,695 Mbps | 1,683/1,449 Mbps            |
| HIP:Gen1:x8:64 bits  | 1,774 Mbps | 1,522 Mbps | 1,524/1,631 Mbps            |
| HIP:Gen2:x4:64 bits  | 1,772 Mbps | 1,528 Mbps | 1,528/1,634 Mbps            |
| HIP:Gen2:x4:128 bits | 1,670 Mbps | 1,613 Mbps | 1,607/1,402 Mbps            |

- Theoretical maximum bandwidth
  - Gen1 x8, Gen2 x4: 2,000 Mbps
- Stratix IV GX hard IP is close to theoretical maximum now



## **PCI-SIG Industry Testing – PCI-SIG**

| FPGA/PHY                       | Config.    | PCle IP | PCI-SIG qualification |
|--------------------------------|------------|---------|-----------------------|
| Arria II GX (Gen1)             | X1, x4, x8 | Hard IP | Q309                  |
| Stratix IV GX (Gen1 and Gen2)  | X1, x4, x8 | Hard IP | <b>☑</b> 1Q09         |
| Arria GX (Gen1)                | x1,x4      | Soft IP | <b>☑</b> 2Q07         |
| Stratix II GX (Gen1)           | x1, x4, x8 | Soft IP | <b>☑</b> 2Q06         |
| Cyclone II/TI x1 (Gen1)        | <b>x1</b>  | Soft IP | <b>☑</b> 1Q06         |
| Cyclone II/Philips x1 V (Gen1) | <b>x</b> 1 | Soft IP | <b>☑</b> 4Q05         |
| Stratix GX (Gen1)              | x1, x4     | Soft IP | <b>☑</b> 1Q05         |

#### PCI-SIG qualification across all target lane configurations







# **Development Kits**



# Stratix IV GX and HardCopy IV GX Development Kit

- PCI Express short form factor
- Included daughtercards
  - HSMC loop-back
  - HSMC debug
- Included software
  - Quartus II Development Kit Edition
    - 12-month license
  - Example designs
    - Board design test system
    - Nios II web server features system remote update
    - myFirst Nios and FPGA
- Documentation
  - User guide
  - Reference manual
  - Schematics
  - Layout design files



| Preliminary schedule    |                |  |
|-------------------------|----------------|--|
| Book orders             | March 28, 2009 |  |
| FAE boards              | March 28, 2009 |  |
| Production May 15, 2009 |                |  |



#### **Arria II GX Development Kit**

- PCI Express short form factor
- Included daughtercards
  - HSMC loop-back
  - HSMC debug
- Included software
  - Quartus II Development Kit Edition
    - 12-month license
  - Example designs
    - Board design test system
    - Nios II web server features system remote update
    - myFirst Nios and FPGA

#### Documentation

- User guide
- Reference manual
- Schematics
- Layout design files



| Preliminary schedule |                                                      |  |
|----------------------|------------------------------------------------------|--|
| Book orders          | July 2009                                            |  |
| FAE boards           | July 2009                                            |  |
| Production           | Aug. *Limited quantities End Sept **1-week lead-time |  |



## Stratix II GX Development Kit

- ~500 developments kits shipped
- Complete PCI Express experience
  - PCI-SIG compliant Stratix II GX EP2SGX90F1508C3 FPGA/board
  - PCI-SIG compliant x1, x4, x8 IP core (OpenCore Plus)
  - 1-year Quartus II software license
  - Board schematics, layout information
  - Example design and supporting documentation
- Modular and scalable design
- System level memory
  - DDR2 333-MHz components
  - QDR2 300-MHz components



Out-of-the-box proven PCI Express experience



## **Arria GX Development Kit**

- PCI Express x1, x4 compliance
- Gigabit Ethernet (with daughtercard)
- Serial RapidIO<sup>®</sup> 1.25 and
   2.5 Gbps (with daughtercard)
- DDR2
- 1 HSMC connector
- JTAG header
- Complete documentation and support







#### Hard IP and Soft IP Features Comparison

|                         | Hard IP                    | Soft IP                |              |
|-------------------------|----------------------------|------------------------|--------------|
| Features                | MegaWizard™<br>Plug-In Mgr | MegaWizard Plug-In Mgr | SOPC Builder |
| Gen1/Gen2               | Yes/Yes                    | Yes/No                 | Yes/No       |
| x1/x4/x8                | Yes/Yes/Yes                | Yes/Yes/Yes            | Yes/Yes/No   |
| Avalon®-MM Interface    | Yes (with a wrapper)       | No                     | Yes          |
| Avalon-ST 64b/128b I/F  | Yes/Yes                    | Yes/No                 | No/No        |
| Desc/data interface     | No                         | Yes                    | No           |
| Legacy endpoint         | Yes                        | Yes                    | No           |
| I/O and messages        | Yes                        | Yes                    | No           |
| Max payload size        | 128B-2KB                   | 128B-2KB               | 128B-256B    |
| Num of VC               | 2                          | 1-4                    | 1            |
| Reordering of OOC       | No                         | No                     | Yes          |
| Reqs cross 4KB boundary | No                         | No                     | Yes          |
| Nr of tags (NP reqs)    | 32 or 64                   | 4 to 256               | 16           |
| ECRC forwarding         | Yes                        | No                     | No           |
| MSI-X                   | Yes                        | No                     | No           |
| Rootport                | Yes                        | No                     | No           |
| License required        | No                         | Yes                    | Yes          |



