# Implementing Switch Fabrics in FPGAs ### **Agenda** - Stratix GX Introduction - System Overview - Centralized Switch Fabrics - Distributed Switch Fabrics - Summary #### **Stratix GX Introduction** ### **Typical Networking Equipment** #### **Typical Data Flow** #### **Line Card** #### **Switch Fabric Card** Data Path Function Backplane 4 x 3.125 Gbps #### **Backplane Architectures** - Centralized Switch Fabrics - Each Line Card Connects to Switch Fabric Card - Switch Fabric Card Routes Data - Redundant Switch Fabric Cards Needed - Distributed Switch Fabrics - Each Line Card Connects to Every Other Line Card - Switch Module on Each Line Card Routes Data - No Need for Redundancy # **Centralized Switch Fabrics** #### Centralized: Crossbar Fabrics Switch Fabric Card #### **Crossbar Function** #### **Crossbar Function – Reverse** #### **Crossbar Function – Reverse** MUX Structure Repeated for All Ports #### **Head-of-Line Blocking Problem** A: Input Port **B: Output Port** ### Virtual Output Queuing (VOQ) #### **Switch Fabric Scheduling Methods** - Switch Fabric Operates on Time Slots - Switch Fabric Must Be "Configured" During Each Time Slot - Methods of Scheduling Packets/Cells for Switch Fabrics - SLIP, Islip, Parallel Iterative Matching (PIM), Least Recently Used (LRU) #### Stratix GX Devices for Crossbars - Supports Many Links in One Device - Up to 20 Integrated 3.125 Gbps Transceivers - Output Port Queuing - Up To 183 M4K RAM Blocks (183 x 4KBits) - More Queuing - Up to 4 M-RAM Blocks (4 x 512 Kbits) - Scheduling & Flow Control Functions - Over 41K Logic Elements (LEs) #### **Centralized Switch Fabric** Stratix Stratix 4 x 3.125 Gbps Stratix Switch Fabric - Backplane Transceiver - Queue/Buffer Managemer - Traffic Management # Stratix GX Crossbar Implementation - Programmable Scheduler - Design to Your Traffic Pattern - Integrated Transceiver, Crossbar & Scheduler - Buffering Capabilities | RAM Block | Size | Number of<br>Blocks in<br>EP1SGX40 | |-----------|------------|------------------------------------| | M512 | 512 Bits | 384 | | M4K | 4,096 Bits | 183 | | M-RAM | 512 KBits | 4 | #### Switch Fabric Card #### **Crossbar Sample Implementation** - 8x8 Crossbar Fabric - Fixed Cell Size - 16-Bit Data Path - VOQ Depth: 8 Cells - Output Queue Depth: 32 Cells - Round Robin Scheduler Switch Fabric Card #### **Design Results** | M4K RAM Blocks | 96 | | | |----------------------|---------|--|--| | Logic Elements | 10K | | | | f <sub>MAX</sub> | 160 MHz | | | | Transceiver Channels | 8 | | | Stratix #### Stratix GX Devices for Line Cards - Programmable Traffic Manager - Integrated Transceiver & Traffic Manager /Buffer Manager - Superior Buffer Management Capabilities ### Common Crossbar Design Needs | Needs | ASIC | Standard<br>Part | Stratix™ GX | |----------------------------------------------|----------|------------------|-------------| | Customizable Scheduling, Buffering, & Fabric | <b>√</b> | | <b>✓</b> | | Real-Time Design & Debug | | | ✓ | | Design Updates/Corrections in Field | | | <b>✓</b> | | Time-to-Market | | <b>√</b> | ✓ | # Distributed Switch Fabrics #### **Distributed Switch Fabric** Every Line Card Connects to Every Other Line Card via High-Speed Serial Links **Backplane** ### **Typical Data Flow** - Control Function - Data Path Function #### **Distributed Switch Module** **Stratix GX Logic** #### **Distributed Switch Module** #### **Distributed Switch Module** **Stratix GX Logic** To Other Line Cards ## Integrated Traffic & Buffer Management Ingress Traffic Egress Traffic Stratux\* Buffer Management **External** TX RX Memory **Traffic FIFO FIFO** Management **40 Gbps Memory** Interface **RX N-1 TX 1-N** (DDR, QDR/QDRII) **Switch** Aggregator **FIFO FIFO FIFO Xcvr Xcvr Xcvr** Stratix GX Transceiver **Stratix GX Logic** #### **Stratix GX Solution** Distributed Switch Fabric Sample Implementation 16 Line Card System Fixed Cell Size 64-Bit Data Path FIFO Depth (Tx & Rx) Line Side: 128 Cells Backplane Side: 32 Cells Includes Buffer & Traffic Manager with External Memory Interface #### **Design Results** | M-RAM Block | 1 | | | |----------------------|---------|--|--| | M4K RAM Blocks | 160 | | | | Logic Elements | 35K | | | | f <sub>MAX</sub> | 160 MHz | | | | Transceiver Channels | 16 | | | ### Stratix GX for Distributed Switch #### **Fabrics** - Can Support Many Links in One Device - Up to 20 Integrated 3.125-Gbps Transceivers - Abundant Queuing Resources - Up to 183 M4K RAM Blocks (183 x 4KBits) - Up to 4 M-RAM Blocks (4 x 512 Kbits) - Traffic Management, Buffer Management & Flow Control Functions - Over 41K LEs Available - Enhanced Memory Interface Support # Common Distributed Switch Fabric Design Needs | Needs | ASIC | Standard<br>Part | Stratix GX | |----------------------------------------------------|----------|------------------|------------| | Customizable Traffic & Buffer Management | <b>✓</b> | N/A | <b>√</b> | | Customizable Scheduling,<br>Buffering, & Switching | <b>✓</b> | N/A | <b>√</b> | | Real-Time Design & Debug | | N/A | <b>√</b> | | Design Updates/Corrections in Field | | N/A | <b>√</b> | | Time-to-Market | | N/A | <b>√</b> | #### Switch Fabrics: Stratix GX Devices Deliver! - Backplane Interface - Up to 20 Integrated 3.125-Gbps Transceivers - High-Speed Chip-to-Chip Interfaces - 1-Gbps Source-Synchronous Channels with Dynamic Phase Alignment (DPA) - Programmable Digital Functions - Stratix Device-Based Programmable Logic Architecture - External Memory Buffering - DDR, FCRAM, SDR, ZBT, QDR/QDRII - Internal Buffering - Over 400-KBytes of TriMatrix Memory - Proprietary & Atypical Implementations - Designed to Provide Superior Flexibility